diff options
-rw-r--r-- | app-portage/qfile/ChangeLog | 11 | ||||
-rw-r--r-- | app-portage/qfile/Manifest | 5 | ||||
-rw-r--r-- | app-portage/qfile/files/digest-qfile-0.0.1 | 0 | ||||
-rw-r--r-- | app-portage/qfile/files/qfile.c | 170 | ||||
-rw-r--r-- | app-portage/qfile/metadata.xml | 9 | ||||
-rw-r--r-- | app-portage/qfile/qfile-0.0.1.ebuild | 29 |
6 files changed, 224 insertions, 0 deletions
diff --git a/app-portage/qfile/ChangeLog b/app-portage/qfile/ChangeLog new file mode 100644 index 000000000000..5b52c0a1a266 --- /dev/null +++ b/app-portage/qfile/ChangeLog @@ -0,0 +1,11 @@ +# ChangeLog for app-portage/qfile +# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/app-portage/qfile/ChangeLog,v 1.1 2005/05/10 12:41:51 solar Exp $ + +*qfile-0.0.1 (10 May 2005) + + 10 May 2005; <solar@gentoo.org> +metadata.xml, +files/qfile.c, + +qfile-0.0.1.ebuild: + - initial creation of qfile package. A very small and fast c implementation of + portage query file tool + diff --git a/app-portage/qfile/Manifest b/app-portage/qfile/Manifest new file mode 100644 index 000000000000..1d8a5ee2c660 --- /dev/null +++ b/app-portage/qfile/Manifest @@ -0,0 +1,5 @@ +MD5 cffbd3ee4f59f2a8812fd0e476d6de9a qfile-0.0.1.ebuild 729 +MD5 c2533cd492bf3cbb1320c8ed3121906c ChangeLog 342 +MD5 01cd2009d0c8237db444e250643f9438 metadata.xml 248 +MD5 d41d8cd98f00b204e9800998ecf8427e files/digest-qfile-0.0.1 0 +MD5 6cf97214567873e16a84a57a8ff40ee8 files/qfile.c 4314 diff --git a/app-portage/qfile/files/digest-qfile-0.0.1 b/app-portage/qfile/files/digest-qfile-0.0.1 new file mode 100644 index 000000000000..e69de29bb2d1 --- /dev/null +++ b/app-portage/qfile/files/digest-qfile-0.0.1 diff --git a/app-portage/qfile/files/qfile.c b/app-portage/qfile/files/qfile.c new file mode 100644 index 000000000000..aa37718c45ab --- /dev/null +++ b/app-portage/qfile/files/qfile.c @@ -0,0 +1,170 @@ +/* + * Copyright 2003-2005 Gentoo Foundation + * Distributed under the terms of the GNU General Public License v2 + * $Header: /var/cvsroot/gentoo-x86/app-portage/qfile/files/qfile.c,v 1.1 2005/05/10 12:41:51 solar Exp $ + * + * 2005 Ned Ludd <solar@gentoo.org> + * + ******************************************************************** + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, + * MA 02111-1307, USA. + * + */ + +#define _GNU_SOURCE + +#include <stdio.h> +#include <stdlib.h> +#include <sys/types.h> +#include <string.h> +#include <unistd.h> +#include <sys/stat.h> +#include <dirent.h> +#include <getopt.h> + +/* static const char *rcsid = "$Id: qfile.c,v 1.1 2005/05/10 12:41:51 solar Exp $"; */ + +int color = 1; +int exact = 0; +int found = 0; + +void qfile(char *path, char *fname) +{ + FILE *fp; + DIR *dir; + struct dirent *dentry; + char *p, *newp; + int flen = strlen(fname); + int base = 0; + char buffer[1024]; + + if (chdir(path) != 0 || (dir = opendir(path)) == NULL) + return; + + if (!strchr(fname, '/')) + base = 1; + else + base = 0; + + readdir(dir); + readdir(dir); /* skip . & .. */ + while ((dentry = readdir(dir))) { + if ((asprintf(&p, "%s/%s/CONTENTS", path, dentry->d_name)) == (-1)) + continue; + if ((fp = fopen(p, "r")) == NULL) { + free(p); + continue; + } + free(p); + while ((fgets(buffer, sizeof(buffer), fp)) != NULL) { + if ((p = strchr(buffer, ' ')) == NULL) + continue; + *p++; + newp = strdup(p); + if (!newp) + continue; + if ((p = strchr(newp, ' ')) != NULL) + *p++ = 0; + if (strncmp(!base ? newp : basename(newp), fname, flen) != 0 + || strlen(!base ? newp : basename(newp)) != flen) { + free(newp); + continue; + } + /* If the d_name is something like foo-3DVooDoo-0.0-r0 doing non + * exact matches would fail to display the name properly. + * /var/cvsroot/gentoo-x86/app-dicts/canna-2ch/ + * /var/cvsroot/gentoo-x86/net-dialup/intel-536ep/ + * /var/cvsroot/gentoo-x86/net-misc/cisco-vpnclient-3des/ + * /var/cvsroot/gentoo-x86/sys-cluster/openmosix-3dmon-stats/ + * /var/cvsroot/gentoo-x86/sys-cluster/openmosix-3dmon/ + */ + if (!exact && (p = strchr(dentry->d_name, '-')) != NULL) { + ++p; + if (*p >= '0' && *p <= '9') { + --p; + *p = 0; + } else { + /* tricky tricky.. I wish to advance to the second - */ + /* and repeat the first p strchr matching */ + char *q = strdup(p); + if (!q) { + free(newp); + continue; + } + if ((p = strchr(q, '-')) != NULL) { + int l = 0; + ++p; + if (*p >= '0' && *p <= '9') { + --p; + *p = 0; + ++p; + l = strlen(dentry->d_name) - strlen(p) - 1; + dentry->d_name[l] = 0; + } + } + free(q); + } + } + + if (color) + printf("\e[0;01m%s/\e[36;01m%s\e[0m (%s)\n", basename(path), + dentry->d_name, newp); + else + printf("%s/%s (%s)\n", basename(path), dentry->d_name, newp); + + free(newp); + fclose(fp); + closedir(dir); + found++; + return; + } + fclose(fp); + } + closedir(dir); + return; +} + +int main(int argc, char **argv) +{ + DIR *dir; + struct dirent *dentry; + int i; + char *p, *path = "/var/db/pkg"; + + if ((chdir(path) == 0) && ((dir = opendir(path)))) { + readdir(dir); + readdir(dir); /* skip . & .. */ + while ((dentry = readdir(dir))) { + for (i = 1; i < argc; i++) { + if (argv[i][0] != '-') { + if ((asprintf(&p, "%s/%s", path, dentry->d_name)) != (-1)) { + qfile(p, argv[i]); + free(p); + } + } else { + if (((strcmp(argv[i], "-nc")) == 0) + || ((strcmp(argv[i], "-C")) == 0)) + color = 0; + + if (((strcmp(argv[i], "-e")) == 0) + || ((strcmp(argv[i], "-exact")) == 0)) + exact = 1; + } + } + } + closedir(dir); + } + exit(found ? EXIT_SUCCESS : EXIT_FAILURE); +} diff --git a/app-portage/qfile/metadata.xml b/app-portage/qfile/metadata.xml new file mode 100644 index 000000000000..567723f81625 --- /dev/null +++ b/app-portage/qfile/metadata.xml @@ -0,0 +1,9 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> + <herd>no-herd</herd> + <maintainer> + <email>solar@gentoo.org</email> + <name>Ned Ludd</name> + </maintainer> +</pkgmetadata> diff --git a/app-portage/qfile/qfile-0.0.1.ebuild b/app-portage/qfile/qfile-0.0.1.ebuild new file mode 100644 index 000000000000..f938846a2c41 --- /dev/null +++ b/app-portage/qfile/qfile-0.0.1.ebuild @@ -0,0 +1,29 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/app-portage/qfile/qfile-0.0.1.ebuild,v 1.1 2005/05/10 12:41:51 solar Exp $ + +inherit toolchain-funcs + +DESCRIPTION="very small and fast c implementation of portage query file tool" +HOMEPAGE="http://www.gentoo.org/" +SRC_URI="" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86" +IUSE="" +DEPEND="virtual/libc" + +S=${WORKDIR} + +src_compile() { + cd ${S} + $(tc-getCC) ${CFLAGS} -o qfile \ + ${FILESDIR}/qfile.c ${LDFLAGS} || die "compile" +} + +src_install() { + dodir /usr/bin + exeinto /usr/bin + newexe ${S}/qfile ${PN} || die +} |