public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2007-10-24 16:50 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2007-10-24 16:50 UTC (permalink / raw
  To: gentoo-commits

solar       07/10/24 16:50:31

  Modified:             qmerge.c
  Log:
  - qmerge updates that I needed to commit for a while

Revision  Changes    Path
1.77                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.77&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.77&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.76&r2=1.77

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.76
retrieving revision 1.77
diff -u -r1.76 -r1.77
--- qmerge.c	4 Jun 2007 16:53:53 -0000	1.76
+++ qmerge.c	24 Oct 2007 16:50:31 -0000	1.77
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.76 2007/06/04 16:53:53 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.77 2007/10/24 16:50:31 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -24,6 +24,8 @@
 /* #define BUSYBOX "/bin/busybox" */
 #define BUSYBOX ""
 
+int old_repo = 0;
+
 #define QMERGE_FLAGS "fFsKUpuyO5" COMMON_FLAGS
 static struct option const qmerge_long_opts[] = {
 	{"fetch",   no_argument, NULL, 'f'},
@@ -53,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.76 2007/06/04 16:53:53 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.77 2007/10/24 16:50:31 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -238,7 +240,7 @@
 	char *p;
 
 	/* if defined(EBUG) this spits out incorrect versions. */
-	snprintf(buf, sizeof(buf), "qlist -CIev %s%s%s 2>/dev/null | tr '\n' ' '",
+	snprintf(buf, sizeof(buf), "qlist -CIev '%s%s%s' 2>/dev/null | tr '\n' ' '",
 		(CATEGORY != NULL ? CATEGORY : ""), (CATEGORY != NULL ? "/" : ""), PN);
 
 	if ((fp = popen(buf, "r")) == NULL)
@@ -361,10 +363,7 @@
 				case OLDER: c = 'D'; break;
 				default: c = '?'; break;
 			}
-			if (subatom->PR_int)
-				snprintf(buf, sizeof(buf), "%s-r%i", subatom->PV, subatom->PR_int);
-			else
-				snprintf(buf, sizeof(buf), "%s", subatom->PV);
+			strncpy(buf, subatom->P, sizeof(buf));
 			snprintf(install_ver, sizeof(install_ver), "[%s%s%s] ", DKBLUE, buf, NORM);
 			atom_implode(subatom);
 		}
@@ -586,7 +585,7 @@
 						if (strcmp(pkg->SLOT, slot) != 0)
 							u = 0;
 					}
-					if (u) pkg_unmerge(atom->CATEGORY, basename(pf));
+					if (u) pkg_unmerge(atom->CATEGORY, basename(pf)); /* We need to really set this unmerge pending after we look at contents of the new pkg */
 					break;
 				default:
 					warn("no idea how we reached here.");
@@ -765,7 +764,7 @@
 		mkdirhier(buf, 0755);
 	strncat(buf, pkg->PF, sizeof(buf));
 
-	/* FIXME */
+	/* FIXME */ /* move unmerging to around here ? */
 	/* not perfect when a version is already installed */
 	if (access(buf, X_OK) == 0) {
 		char buf2[sizeof(buf)] = "";
@@ -1043,13 +1042,15 @@
 
 		/* fetch the package */
 		/* Check CATEGORY first */
-		snprintf(buf, sizeof(buf), "%s/%s.tbz2", atom->CATEGORY, pkg->PF);
-		fetch(str, buf);
-
+		if (!old_repo) {
+			snprintf(buf, sizeof(buf), "%s/%s.tbz2", atom->CATEGORY, pkg->PF);
+			fetch(str, buf);
+		}
 		snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
 		if (access(buf, R_OK) != 0) {
 			snprintf(buf, sizeof(buf), "%s.tbz2", pkg->PF);
 			fetch(str, buf);
+			old_repo = 1;
 		}
 
 		/* verify the pkg exists now. unlink if zero bytes */
@@ -1455,6 +1456,7 @@
 	queue *world = NULL;
 	char *fname = (char *) "/var/lib/portage/world";
 
+	/* FIXME: Add ROOT= checks here */
 	if ((fp = fopen(fname, "r")) == NULL) {
 		warn("fopen(\"%s\", \"r\"); = -1 (%s)", fname, strerror(errno));
 		return NULL;



-- 
gentoo-commits@gentoo.org mailing list



^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2008-05-10 20:21 Diego Petteno (flameeyes)
  0 siblings, 0 replies; 39+ messages in thread
From: Diego Petteno (flameeyes) @ 2008-05-10 20:21 UTC (permalink / raw
  To: gentoo-commits

flameeyes    08/05/10 20:21:12

  Modified:             qmerge.c
  Log:
  Instead of checking for portroot's address (always valid, as it's an array), check if it's not empty or the default value (/), which seems to be the logic wanted in this case.

Revision  Changes    Path
1.80                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.80&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.80&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.79&r2=1.80

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.79
retrieving revision 1.80
diff -u -r1.79 -r1.80
--- qmerge.c	12 Apr 2008 17:25:59 -0000	1.79
+++ qmerge.c	10 May 2008 20:21:12 -0000	1.80
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.79 2008/04/12 17:25:59 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.80 2008/05/10 20:21:12 flameeyes Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.79 2008/04/12 17:25:59 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.80 2008/05/10 20:21:12 flameeyes Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1461,7 +1461,7 @@
 	queue *world = NULL;
 	char fname[_Q_PATH_MAX];
 
-	if (portroot)
+	if (*portroot && strcmp(portroot, "/") != 0)
 		snprintf(fname, sizeof(fname), "%s/var/lib/portage/world", portroot);
 	else
 		strncpy(fname,  "/var/lib/portage/world", sizeof(fname));



-- 
gentoo-commits@lists.gentoo.org mailing list



^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2009-03-21  6:37 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2009-03-21  6:37 UTC (permalink / raw
  To: gentoo-commits

solar       09/03/21 06:37:10

  Modified:             qmerge.c
  Log:
  - display the repo in verbose mode when it is not gentoo

Revision  Changes    Path
1.81                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.81&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.81&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.80&r2=1.81

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.80
retrieving revision 1.81
diff -u -r1.80 -r1.81
--- qmerge.c	10 May 2008 20:21:12 -0000	1.80
+++ qmerge.c	21 Mar 2009 06:37:10 -0000	1.81
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.80 2008/05/10 20:21:12 flameeyes Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.81 2009/03/21 06:37:10 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.80 2008/05/10 20:21:12 flameeyes Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.81 2009/03/21 06:37:10 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -84,6 +84,7 @@
 	char SLOT[64];
 	size_t SIZE;
 	char USE[BUFSIZ];
+	char REPO[64];
 } Pkg;
 
 struct llist_char_t {
@@ -1120,6 +1121,9 @@
 		printf(" %sRdepend%s:%s %s\n", DKGREEN, YELLOW, NORM, pkg->RDEPEND);
 	if (pkg->USE[0])
 		printf(" %sUse%s:%s %s\n", DKGREEN, YELLOW, NORM, pkg->USE);
+	if (pkg->REPO[0])
+		if (strcmp(pkg->REPO, "gentoo") != 0)
+			printf(" %sRepo%s:%s %s\n", DKGREEN, YELLOW, NORM, pkg->REPO);
 
 	snprintf(buf, sizeof(buf), "%s/%s", pkg->CATEGORY, pkg->PF);
 	atom = atom_explode(buf);
@@ -1245,6 +1249,8 @@
 				strncpy(pkg->PF, value, sizeof(Pkg.PF));
 			if ((strcmp(buf, "CATEGORY:")) == 0)
 				strncpy(pkg->CATEGORY, value, sizeof(Pkg.CATEGORY));
+			if ((strcmp(buf, "REPO:")) == 0)
+				strncpy(pkg->REPO, value, sizeof(Pkg.REPO));
 
 			if ((strcmp(buf, "CPV:")) == 0) {
 				if ((atom = atom_explode(value)) != NULL) {
@@ -1423,6 +1429,7 @@
 				if ((strcmp(buf, "MD5:")) == 0) strncpy(Pkg.MD5, value, sizeof(Pkg.MD5));
 				break;
 			case 'R':
+				if ((strcmp(buf, "REPO:")) == 0) strncpy(Pkg.REPO, value, sizeof(Pkg.REPO));
 				if ((strcmp(buf, "RDEPEND:")) == 0) strncpy(Pkg.RDEPEND, value, sizeof(Pkg.RDEPEND));
 				break;
 			case 'L':






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2009-04-17 14:44 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2009-04-17 14:44 UTC (permalink / raw
  To: gentoo-commits

solar       09/04/17 14:44:55

  Modified:             qmerge.c
  Log:
  - make sure we can fetch foo/pkg:slot

Revision  Changes    Path
1.82                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.82&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.82&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.81&r2=1.82

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.81
retrieving revision 1.82
diff -u -r1.81 -r1.82
--- qmerge.c	21 Mar 2009 06:37:10 -0000	1.81
+++ qmerge.c	17 Apr 2009 14:44:55 -0000	1.82
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.81 2009/03/21 06:37:10 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.82 2009/04/17 14:44:55 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.81 2009/03/21 06:37:10 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.82 2009/04/17 14:44:55 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -922,6 +922,7 @@
 	depend_atom *atom;
 	char buf[255], buf2[255];
 	int match = 0;
+	char *ptr;
 
 	snprintf(buf, sizeof(buf), "%s/%s", pkg->CATEGORY, pkg->PF);
 	if ((atom = atom_explode(buf)) == NULL)
@@ -942,6 +943,19 @@
 	if ((strcmp(name, atom->PN)) == 0)
 		match = 4;
 
+	if (match)
+		goto match_done;
+
+	if ((ptr = strchr(name, ':')) != NULL) {
+		depend_atom *subatom = atom_explode(name);
+		if (subatom == NULL)
+			goto match_done;
+		if (strcmp(atom->PN, subatom->PN) == 0)
+			match = 1;
+		atom_implode(subatom);
+	}
+
+match_done:
 	atom_implode(atom);
 
 	return match;






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2009-05-03 17:19 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2009-05-03 17:19 UTC (permalink / raw
  To: gentoo-commits

solar       09/05/03 17:19:13

  Modified:             qmerge.c
  Log:
  - Refactor fetching logic (Zdenek Behan <behanz[@]seznam[dot]cz>). bug 266455

Revision  Changes    Path
1.83                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.83&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.83&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.82&r2=1.83

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.82
retrieving revision 1.83
diff -u -r1.82 -r1.83
--- qmerge.c	17 Apr 2009 14:44:55 -0000	1.82
+++ qmerge.c	3 May 2009 17:19:13 -0000	1.83
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.82 2009/04/17 14:44:55 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.83 2009/05/03 17:19:13 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.82 2009/04/17 14:44:55 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.83 2009/05/03 17:19:13 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -98,10 +98,11 @@
 void fetch(const char *, const char *);
 void qmerge_initialize(const char *);
 char *best_version(const char *, const char  *);
+void pkg_fetch(int, depend_atom *, struct pkg_t *);
 void pkg_merge(int, depend_atom *, struct pkg_t *);
 int pkg_unmerge(char *, char *);
 int unlink_empty(char *);
-void pkg_fetch(int, char **, struct pkg_t *);
+void pkg_process(int, char **, struct pkg_t *);
 void print_Pkg(int, struct pkg_t *);
 int parse_packages(const char *, int, char **);
 int config_protected(const char *, int, char **);
@@ -509,7 +510,7 @@
 						IF_DEBUG(fprintf(stderr, "+Installed: %s\n", p));
 						if (strlen(p) < 1)
 							if (!((strcmp(pkg->PF, subpkg->PF) == 0) && (strcmp(pkg->CATEGORY, subpkg->CATEGORY) == 0)))
-								pkg_merge(level+1, ratom, subpkg);
+								pkg_fetch(level+1, ratom, subpkg);
 
 						atom_implode(subatom);
 						atom_implode(ratom);
@@ -1004,23 +1005,18 @@
 	return ret;
 }
 
-void pkg_fetch(int argc, char **argv, struct pkg_t *pkg)
+void pkg_process(int argc, char **argv, struct pkg_t *pkg)
 {
 	depend_atom *atom;
-	char savecwd[_POSIX_PATH_MAX];
-	char buf[255], str[255];
+	char buf[255];
 	int i;
 
 	memset(buf, 0, sizeof(buf));
-	memset(str, 0, sizeof(str));
 
 	snprintf(buf, sizeof(buf), "%s/%s", pkg->CATEGORY, pkg->PF);
 	if ((atom = atom_explode(buf)) == NULL)
 		errf("%s/%s is not a valid atom", pkg->CATEGORY, pkg->PF);
 
-	snprintf(str, sizeof(str), "%s/%s", pkgdir, pkg->CATEGORY);
-	mkdir(str, 0755);
-
 	for (i = 1; i < argc; i++) {
 		if (argv[i][0] == '-')
 			continue;
@@ -1029,79 +1025,93 @@
 		if (match_pkg(argv[i], pkg) < 1)
 			continue;
 
-		/* qmerge -pv patch */
-		if (pretend) {
-			int level = 0;
-			if (!install) install++;
-			/* qprint_tree_node(level, atom, pkg); */
-			pkg_merge(level, atom, pkg);
-			continue;
-		}
+		pkg_fetch(0, atom, pkg);
+	}
+	/* free the atom */
+	atom_implode(atom);
+}
 
-		/* check to see if file exists and it's checksum matches */
-		snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, pkg->CATEGORY, pkg->PF);
-		unlink_empty(buf);
-
-		if ((force_download) && (access(buf, R_OK) == 0) && ((pkg->SHA1[0]) || (pkg->MD5[0]))) {
-			if ((pkg_verify_checksums(buf, pkg, atom, 0, 0)) != 0)
-				unlink(buf);
-		}
-		if (access(buf, R_OK) == 0) {
-			if ((!pkg->SHA1[0]) && (!pkg->MD5[0])) {
-				warn("No checksum data for %s", buf);
-				continue;
-			} else {
-				if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
-					pkg_merge(0, atom, pkg);
-					continue;
-				}
-			}
-		}
-		if (verbose)
-			printf("Fetching %s/%s.tbz2\n", atom->CATEGORY, pkg->PF);
+void pkg_fetch(int level, depend_atom *atom, struct pkg_t *pkg)
+{
+	char savecwd[_POSIX_PATH_MAX];
+	char buf[255], str[255];
+	memset(str, 0, sizeof(str));
 
-		/* fetch the package */
-		/* Check CATEGORY first */
-		if (!old_repo) {
-			snprintf(buf, sizeof(buf), "%s/%s.tbz2", atom->CATEGORY, pkg->PF);
-			fetch(str, buf);
-		}
-		snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
-		if (access(buf, R_OK) != 0) {
-			snprintf(buf, sizeof(buf), "%s.tbz2", pkg->PF);
-			fetch(str, buf);
-			old_repo = 1;
-		}
-
-		/* verify the pkg exists now. unlink if zero bytes */
-		snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
-		unlink_empty(buf);
-
-		if (access(buf, R_OK) != 0) {
-			warn("Failed to fetch %s.tbz2 from %s", pkg->PF, binhost);
-			fflush(stderr);
-			continue;
-		}
-		getcwd(savecwd, sizeof(savecwd));
-		assert(chdir(pkgdir) == 0);
-		if (chdir("All/") == 0) {
-			snprintf(buf, sizeof(buf), "%s.tbz2", pkg->PF);
-			snprintf(str, sizeof(str), "../%s/%s.tbz2", atom->CATEGORY, pkg->PF);
+	/* qmerge -pv patch */
+	if (pretend) {
+		if (!install) install++;
+		/* qprint_tree_node(level, atom, pkg); */
+		pkg_merge(level, atom, pkg);
+		return;
+	}
+
+	/* check to see if file exists and it's checksum matches */
+	snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, pkg->CATEGORY, pkg->PF);
+	unlink_empty(buf);
+
+	snprintf(str, sizeof(str), "%s/%s", pkgdir, pkg->CATEGORY);
+	mkdir(str, 0755);
+
+	if ((force_download) && (access(buf, R_OK) == 0) && ((pkg->SHA1[0]) || (pkg->MD5[0]))) {
+		if ((pkg_verify_checksums(buf, pkg, atom, 0, 0)) != 0)
 			unlink(buf);
-			symlink(str, buf);
+	}
+	if (access(buf, R_OK) == 0) {
+		if ((!pkg->SHA1[0]) && (!pkg->MD5[0])) {
+			warn("No checksum data for %s", buf);
+			return;
+		} else {
+			if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
+				pkg_merge(0, atom, pkg);
+				return;
+			}
 		}
-		chdir(savecwd);
+	}
+	if (verbose)
+		printf("Fetching %s/%s.tbz2\n", atom->CATEGORY, pkg->PF);
 
-		snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
-		if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
-			pkg_merge(0, atom, pkg);
-			continue;
-		}
+	/* fetch the package */
+	/* Check CATEGORY first */
+	if (!old_repo) {
+		snprintf(buf, sizeof(buf), "%s/%s.tbz2", atom->CATEGORY, pkg->PF);
+		fetch(str, buf);
+	}
+	snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
+	if (access(buf, R_OK) != 0) {
+		snprintf(buf, sizeof(buf), "%s.tbz2", pkg->PF);
+		fetch(str, buf);
+		old_repo = 1;
+	}
+
+	/* verify the pkg exists now. unlink if zero bytes */
+	snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
+	unlink_empty(buf);
+
+	if (access(buf, R_OK) != 0) {
+		warn("Failed to fetch %s.tbz2 from %s", pkg->PF, binhost);
+		fflush(stderr);
+		return;
+	}
+	getcwd(savecwd, sizeof(savecwd));
+	assert(chdir(pkgdir) == 0);
+	if (chdir("All/") == 0) {
+		snprintf(buf, sizeof(buf), "%s.tbz2", pkg->PF);
+		snprintf(str, sizeof(str), "../%s/%s.tbz2", atom->CATEGORY, pkg->PF);
+		unlink(buf);
+		symlink(str, buf);
+	}
+	chdir(savecwd);
+
+	snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
+	if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
+		pkg_merge(0, atom, pkg);
+		return;
 	}
-	/* free the atom */
-	atom_implode(atom);
 }
 
+
+
+
 void print_Pkg(int full, struct pkg_t *pkg)
 {
 	char *p = NULL;
@@ -1407,8 +1417,7 @@
 						print_Pkg(verbose, pkg);
 					}
 				} else {
-					/* this name is misleading */
-					pkg_fetch(argc, argv, pkg);
+					pkg_process(argc, argv, pkg);
 				}
 				free(pkg);
 			}






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2010-01-13  6:14 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2010-01-13  6:14 UTC (permalink / raw
  To: gentoo-commits

solar       10/01/13 06:14:40

  Modified:             qmerge.c
  Log:
  - Be less restrictive on allowing merges when rdeps are not used

Revision  Changes    Path
1.85                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.85&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.85&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.84&r2=1.85

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.84
retrieving revision 1.85
diff -u -r1.84 -r1.85
--- qmerge.c	8 Sep 2009 03:05:40 -0000	1.84
+++ qmerge.c	13 Jan 2010 06:14:40 -0000	1.85
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.84 2009/09/08 03:05:40 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.85 2010/01/13 06:14:40 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.84 2009/09/08 03:05:40 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.85 2010/01/13 06:14:40 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1556,7 +1556,7 @@
 
 	/* Short circut this. */
 	if ((install || uninstall) && !pretend) {
-		if (getenv("QMERGE") == NULL) {
+		if (follow_rdepends && getenv("QMERGE") == NULL) {
 			uninstall = 0;
 			install = 0;
 			warn("Using these options are likely to break your system at this point. export QMERGE=1; if you think you know what your doing.");






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2010-01-13 19:15 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2010-01-13 19:15 UTC (permalink / raw
  To: gentoo-commits

vapier      10/01/13 19:15:17

  Modified:             qmerge.c
  Log:
  introduce and use xsystem()

Revision  Changes    Path
1.91                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.91&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.91&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.90&r2=1.91

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.90
retrieving revision 1.91
diff -u -r1.90 -r1.91
--- qmerge.c	13 Jan 2010 19:11:02 -0000	1.90
+++ qmerge.c	13 Jan 2010 19:15:16 -0000	1.91
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.90 2010/01/13 19:11:02 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.91 2010/01/13 19:15:16 vapier Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.90 2010/01/13 19:11:02 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.91 2010/01/13 19:15:16 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -197,7 +197,7 @@
 		snprintf(buf, sizeof(buf), "%s " BUSYBOX " wget %s -P %s %s/%s", (force_download || install) ? "" : pretend ? "echo " : "",
 			(quiet ? "-q" : ""), destdir, binhost, src);
 	}
-	system(buf);
+	xsystem(buf);
 	fflush(stdout);
 	fflush(stderr);
 }
@@ -294,7 +294,7 @@
 	}
 	qprintf("%s<<<%s %s\n", YELLOW, NORM, buf);
 	snprintf(buf, size, BUSYBOX " rm -rf ./%s", fname);
-	system(buf);
+	xsystem(buf);
 }
 
 void install_mask_pwd(int argc, char **argv, const struct stat st);
@@ -531,7 +531,7 @@
 	/* mkdir(pkg->PF, 0710); */
 	xchdir(pkg->PF);
 
-	system(BUSYBOX " rm -rf ./*"); /* this line does funny things to nano's highlighting. */
+	xsystem(BUSYBOX " rm -rf ./*"); /* this line does funny things to nano's highlighting. */
 
 	/* split the tbz and xpak data */
 	snprintf(tarball, sizeof(tarball), "%s.tbz2", pkg->PF);
@@ -558,11 +558,11 @@
 	/* list and extract vdb files from the xpak */
 	snprintf(buf, sizeof(buf), "qxpak -d %s/%s/vdb -x %s.xpak `qxpak -l %s.xpak`",
 		port_tmpdir, pkg->PF, pkg->PF, pkg->PF);
-	system(buf);
+	xsystem(buf);
 
 	/* extrct the binary package data */
 	snprintf(buf, sizeof(buf), BUSYBOX " tar -jx%sf %s.tar.bz2 -C image/", ((verbose > 1) ? "v" : ""), pkg->PF);
-	system(buf);
+	xsystem(buf);
 	fflush(stdout);
 
 	/* check for an already installed pkg */
@@ -610,9 +610,9 @@
 	makeargv(install_mask, &iargc, &iargv);
 	install_mask_pwd(iargc, iargv, st);
 
-	if ((strstr(features, "noinfo")) != NULL) if (access("./usr/share/info", R_OK) == 0) system(BUSYBOX " rm -rf ./usr/share/info");
-	if ((strstr(features, "noman"))  != NULL) if (access("./usr/share/man",  R_OK) == 0) system(BUSYBOX " rm -rf ./usr/share/man");
-	if ((strstr(features, "nodoc"))  != NULL) if (access("./usr/share/doc",  R_OK) == 0) system(BUSYBOX " rm -rf ./usr/share/doc");
+	if ((strstr(features, "noinfo")) != NULL) if (access("./usr/share/info", R_OK) == 0) xsystem(BUSYBOX " rm -rf ./usr/share/info");
+	if ((strstr(features, "noman"))  != NULL) if (access("./usr/share/man",  R_OK) == 0) xsystem(BUSYBOX " rm -rf ./usr/share/man");
+	if ((strstr(features, "nodoc"))  != NULL) if (access("./usr/share/doc",  R_OK) == 0) xsystem(BUSYBOX " rm -rf ./usr/share/doc");
 
 	/* we dont care about the return code */
 	rmdir("./usr/share");
@@ -688,7 +688,7 @@
 					qprintf("%s***%s %s\n", BRYELLOW, NORM, &buf[1]);
 					if (verbose) {
 						snprintf(newbuf, sizeof(newbuf), "diff -u %s %s", buf, dest);
-						system(newbuf);
+						xsystem(newbuf);
 					}
 					continue;
 				}
@@ -775,7 +775,7 @@
 		char buf2[sizeof(buf)] = "";
 		/* we need to compare CONTENTS in it and remove any file not provided by our CONTENTS */
 		snprintf(buf2, sizeof(buf2), BUSYBOX " rm -rf %s", buf);
-		system(buf2);
+		xsystem(buf2);
 	}
 	if ((fp = fopen("vdb/COUNTER", "w")) != NULL) {
 		fputs("0", fp);
@@ -787,7 +787,7 @@
 	if (which("ebuild") != NULL) {
 		char *tbuf;
 		xasprintf(&tbuf, "ebuild %s/%s.ebuild postinst", buf, basename(buf));
-		system(tbuf);
+		xsystem(tbuf);
 		free(tbuf);
 	}
 
@@ -795,7 +795,7 @@
 	unlink_q(buf);
 	xchdir(port_tmpdir);
 	snprintf(buf, sizeof(buf), "rm -rf %s", pkg->PF);
-	system(buf);
+	xsystem(buf);
 
 	snprintf(buf, sizeof(buf), "%s/%s.tbz2", pkgdir, pkg->PF);
 	unlink(buf);
@@ -902,7 +902,7 @@
 
 	if (!pretend) {
 		snprintf(buf, sizeof(buf), BUSYBOX " rm -rf %s/%s/%s/%s", portroot, portvdb, cat, pkgname);
-		system(buf);
+		xsystem(buf);
 	}
 	return 1;
 }






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2010-01-18  6:30 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2010-01-18  6:30 UTC (permalink / raw
  To: gentoo-commits

solar       10/01/18 06:30:26

  Modified:             qmerge.c
  Log:
  - when DEFINED_PHASES exists no longer run postinst unless it is defined

Revision  Changes    Path
1.93                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.93&view=markup
plain: http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?rev=1.93&content-type=text/plain
diff : http://sources.gentoo.org/viewcvs.py/gentoo-projects/portage-utils/qmerge.c?r1=1.92&r2=1.93

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.92
retrieving revision 1.93
diff -u -r1.92 -r1.93
--- qmerge.c	13 Jan 2010 19:16:22 -0000	1.92
+++ qmerge.c	18 Jan 2010 06:30:26 -0000	1.93
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2007 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.92 2010/01/13 19:16:22 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.93 2010/01/18 06:30:26 solar Exp $
  *
  * Copyright 2005-2007 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2007 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.92 2010/01/13 19:16:22 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.93 2010/01/18 06:30:26 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -402,6 +402,18 @@
 	return c;
 }
 
+int has_postinst(char *vdbroot);
+int has_postinst(char *vdbroot) {
+	FILE *fp;
+	char buf[1024];
+	snprintf(buf, sizeof(buf), "%s/%s", vdbroot, "DEFINED_PHASES");
+	if ((fp = fopen(buf,  "r")) == NULL)
+		return 1;
+	fgets(buf, sizeof(buf), fp);
+	fclose(fp);
+	return ((strstr(buf, "postinst") == NULL) ? 0 : 2);
+}
+
 /* oh shit getting into pkg mgt here. FIXME: write a real dep resolver. */
 void pkg_merge(int level, depend_atom *atom, struct pkg_t *pkg)
 {
@@ -784,7 +796,7 @@
 	interactive_rename("vdb", buf, pkg);
 
 	/* run postinst on non embedded systems */
-	if (which("ebuild") != NULL) {
+	if ((which("ebuild") != NULL) && has_postinst(buf)) {
 		char *tbuf;
 		xasprintf(&tbuf, "ebuild %s/%s.ebuild postinst", buf, basename(buf));
 		xsystem(tbuf);






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2010-06-08  4:52 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2010-06-08  4:52 UTC (permalink / raw
  To: gentoo-commits

vapier      10/06/08 04:52:42

  Modified:             qmerge.c
  Log:
  fix unused fgets() result warning

Revision  Changes    Path
1.95                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.95&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.95&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.94&r2=1.95

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.94
retrieving revision 1.95
diff -u -r1.94 -r1.95
--- qmerge.c	7 Apr 2010 05:58:16 -0000	1.94
+++ qmerge.c	8 Jun 2010 04:52:42 -0000	1.95
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.94 2010/04/07 05:58:16 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.95 2010/06/08 04:52:42 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.94 2010/04/07 05:58:16 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.95 2010/06/08 04:52:42 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -402,16 +402,20 @@
 	return c;
 }
 
-int has_postinst(char *vdbroot);
-int has_postinst(char *vdbroot) {
+static int has_postinst(char *vdbroot)
+{
 	FILE *fp;
+	int ret;
 	char buf[1024];
 	snprintf(buf, sizeof(buf), "%s/%s", vdbroot, "DEFINED_PHASES");
 	if ((fp = fopen(buf,  "r")) == NULL)
 		return 1;
-	fgets(buf, sizeof(buf), fp);
+	if (fgets(buf, sizeof(buf), fp))
+		ret = (strstr(buf, "postinst") == NULL) ? 0 : 2;
+	else
+		ret = 0;
 	fclose(fp);
-	return ((strstr(buf, "postinst") == NULL) ? 0 : 2);
+	return ret;
 }
 
 /* oh shit getting into pkg mgt here. FIXME: write a real dep resolver. */






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-02-21  1:52 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-02-21  1:52 UTC (permalink / raw
  To: gentoo-commits

vapier      11/02/21 01:52:46

  Modified:             qmerge.c
  Log:
  clean up style a bit

Revision  Changes    Path
1.98                 portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.98&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.98&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.97&r2=1.98

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.97
retrieving revision 1.98
diff -u -r1.97 -r1.98
--- qmerge.c	21 Feb 2011 01:33:47 -0000	1.97
+++ qmerge.c	21 Feb 2011 01:52:46 -0000	1.98
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.97 2011/02/21 01:33:47 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.98 2011/02/21 01:52:46 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.97 2011/02/21 01:33:47 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.98 2011/02/21 01:52:46 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -113,8 +113,8 @@
 
 struct pkg_t *grab_binpkg_info(const char *);
 
-int mkdirhier(char *dname, mode_t mode);
-int mkdirhier(char *dname, mode_t mode) {
+static int mkdirhier(char *dname, mode_t mode)
+{
 	char buf[BUFSIZ];
 	int i;
 	strncpy(buf, dname, sizeof(buf));
@@ -157,7 +157,7 @@
 		snprintf(buf, sizeof(buf), "qfile -Cqev %s 2>/dev/null", dst);
 		if ((fp = popen(buf, "r")) != NULL) {
 			buf[0] = '\0';
-			if ((fgets(buf, sizeof(buf), fp)) != NULL)
+			if (fgets(buf, sizeof(buf), fp) != NULL)
 				if ((p = strchr(buf, '\n')) != NULL) {
 					*p = 0;
 					p = xstrdup(buf);
@@ -218,7 +218,7 @@
 		errf("PORTAGE_BINHOST= does not appear to be valid");
 
 	if (!search_pkgs && !pretend) {
-		if ((access(pkgdir, R_OK|W_OK|X_OK)) != 0)
+		if (access(pkgdir, R_OK|W_OK|X_OK) != 0)
 			errf("Wrong perms on PKGDIR='%s'", pkgdir);
 		mkdir(port_tmpdir, 0755);
 	}
@@ -230,11 +230,11 @@
 		unlink(Packages);
 
 	if ((access(Packages, R_OK) != 0) && (force_download != 2)) {
-			char *tbuf = NULL;
-			xasprintf(&tbuf, "%s/portage/", port_tmpdir);
-		        if ((access(Packages, R_OK) != 0))
-				fetch(tbuf, Packages);
-			free(tbuf);
+		char *tbuf = NULL;
+		xasprintf(&tbuf, "%s/portage/", port_tmpdir);
+		if (access(Packages, R_OK) != 0)
+			fetch(tbuf, Packages);
+		free(tbuf);
 	}
 }
 
@@ -252,7 +252,7 @@
 		return NULL;
 
 	buf[0] = '\0';
-	if ((fgets(buf, sizeof(buf), fp)) != NULL)
+	if (fgets(buf, sizeof(buf), fp) != NULL)
 		if ((p = strchr(buf, '\n')) != NULL)
 			*p = 0;
 	pclose(fp);
@@ -267,14 +267,14 @@
 	snprintf(dest, sizeof(dest), "%s%s", portroot, buf);
 
 	for (i = 1; i < ARGC; i++)
-		if ((strncmp(ARGV[i], buf, strlen(ARGV[i]))) == 0)
+		if (strncmp(ARGV[i], buf, strlen(ARGV[i])) == 0)
 			if ((access(dest, R_OK)) == 0)
 				return 1;
 
-	if ((strncmp("/etc", buf, 4)) == 0)
-		if ((access(dest, R_OK)) == 0)
+	if (strncmp("/etc", buf, 4) == 0)
+		if (access(dest, R_OK) == 0)
 			return 1;
-	if ((strcmp("/bin/sh", buf)) == 0)
+	if (strcmp("/bin/sh", buf) == 0)
 		return 1;
 	return 0;
 }
@@ -315,7 +315,7 @@
 			glob_t globbuf;
 
 			globbuf.gl_offs = 0;
-			if ((glob(buf, GLOB_DOOFFS|GLOB_BRACE, NULL, &globbuf)) == 0) {
+			if (glob(buf, GLOB_DOOFFS|GLOB_BRACE, NULL, &globbuf) == 0) {
 				for (g = 0; g < globbuf.gl_pathc; g++) {
 					strncpy(buf, globbuf.gl_pathv[g], sizeof(buf));
 					/* qprintf("globbed: %s\n", globbuf.gl_pathv[g]); */
@@ -374,11 +374,11 @@
 		}
 		if (update_only && c != 'U')
 			return c;
-		if (((c == 'R') || (c == 'D')) && update_only && level)
+		if ((c == 'R' || c == 'D') && update_only && level)
 			return c;
 		if (c == 'R')
 			snprintf(buf, sizeof(buf), "%s%c%s", YELLOW, c, NORM);
-		if ((c == 'U') || (c == 'D'))
+		if (c == 'U' || c == 'D')
 			snprintf(buf, sizeof(buf), "%s%c%s", BLUE, c, NORM);
 #if 0
 		if (level) {
@@ -393,7 +393,8 @@
 #endif
 	}
 	printf("[%s] ", buf);
-	for (i = 0; i < level; i++) putchar(' ');
+	for (i = 0; i < level; ++i)
+		putchar(' ');
 	if (verbose)
 		printf("%s%s/%s%s %s%s%s%s%s%s\n", DKGREEN, pkg->CATEGORY, pkg->PF, NORM,
 			install_ver, strlen(pkg->USE) > 0 ? "(" : "", RED, pkg->USE, NORM, strlen(pkg->USE) > 0 ? ")" : "");
@@ -493,7 +494,7 @@
 							if (virtuals == NULL)
 								virtuals = resolve_virtuals();
 							resolved = find_binpkg(virtual(name, virtuals));
-							if ((resolved == NULL) || (!strlen(resolved)))
+							if (resolved == NULL || !strlen(resolved))
 								resolved = find_binpkg(name);
 						} else
 							resolved = NULL;
@@ -643,7 +644,7 @@
 
 	makeargv(config_protect, &ARGC, &ARGV);
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		char line[BUFSIZ];
 		int protected = 0;
 		char matched = 0;
@@ -655,7 +656,7 @@
 		if (buf[0] != '.')
 			continue;
 
-		if (((strcmp(buf, ".")) == 0) || ((strcmp(buf, "..")) == 0))
+		if ((strcmp(buf, ".") == 0) || (strcmp(buf, "..") == 0))
 			continue;
 
 		for (i = 1; i < iargc; i++) {
@@ -676,8 +677,8 @@
 
 		/* portage has code that handes fifo's but it looks unused */
 
-		if ((S_ISCHR(st.st_mode)) || \
-			(S_ISBLK(st.st_mode))); /* block or character device */
+		if (S_ISCHR(st.st_mode) ||
+			S_ISBLK(st.st_mode)); /* block or character device */
 		if (S_ISFIFO(st.st_mode));	/* FIFO (named pipe) */
 		if (S_ISSOCK(st.st_mode));	/* socket? (Not in POSIX.1-1996.) */
 
@@ -711,7 +712,7 @@
 					continue;
 				}
 			}
-			if ((lstat(dest, &lst)) != (-1)) {
+			if (lstat(dest, &lst) != -1) {
 				if (S_ISLNK(lst.st_mode)) {
 					warn("%s exists and is a symlink and we are going to overwrite it with a file", dest);
 					unlink_q(dest);
@@ -844,7 +845,7 @@
 	argv = NULL;
 	makeargv(config_protect, &argc, &argv);
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		contents_entry *e;
 		char zing[20];
 		int protected = 0;
@@ -928,10 +929,10 @@
 int unlink_empty(char *buf)
 {
 	struct stat st;
-	if ((stat(buf, &st)) != (-1))
+	if (stat(buf, &st) != -1)
 		if (st.st_size == 0)
 			return unlink(buf);
-	return (-1);
+	return -1;
 }
 
 int match_pkg(const char *name, struct pkg_t *pkg)
@@ -946,18 +947,18 @@
 		errf("%s/%s is not a valid atom", pkg->CATEGORY, pkg->PF);
 
 	/* verify this is the requested package */
-	if ((strcmp(name, buf)) == 0)
+	if (strcmp(name, buf) == 0)
 		match = 1;
 
-	if ((strcmp(name, pkg->PF)) == 0)
+	if (strcmp(name, pkg->PF) == 0)
 		match = 2;
 
 	snprintf(buf2, sizeof(buf2), "%s/%s", pkg->CATEGORY, atom->PN);
 
-	if ((strcmp(name, buf2)) == 0)
+	if (strcmp(name, buf2) == 0)
 		match = 3;
 
-	if ((strcmp(name, atom->PN)) == 0)
+	if (strcmp(name, atom->PN) == 0)
 		match = 4;
 
 	if (match)
@@ -1068,16 +1069,16 @@
 	snprintf(str, sizeof(str), "%s/%s", pkgdir, pkg->CATEGORY);
 	mkdir(str, 0755);
 
-	if ((force_download) && (access(buf, R_OK) == 0) && ((pkg->SHA1[0]) || (pkg->MD5[0]))) {
-		if ((pkg_verify_checksums(buf, pkg, atom, 0, 0)) != 0)
+	if (force_download && (access(buf, R_OK) == 0) && (pkg->SHA1[0] || pkg->MD5[0])) {
+		if (pkg_verify_checksums(buf, pkg, atom, 0, 0) != 0)
 			unlink(buf);
 	}
 	if (access(buf, R_OK) == 0) {
-		if ((!pkg->SHA1[0]) && (!pkg->MD5[0])) {
+		if (!pkg->SHA1[0] && !pkg->MD5[0]) {
 			warn("No checksum data for %s", buf);
 			return;
 		} else {
-			if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
+			if (pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1) == 0) {
 				pkg_merge(0, atom, pkg);
 				return;
 			}
@@ -1120,7 +1121,7 @@
 	xchdir(savecwd);
 
 	snprintf(buf, sizeof(buf), "%s/%s/%s.tbz2", pkgdir, atom->CATEGORY, pkg->PF);
-	if ((pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1)) == 0) {
+	if (pkg_verify_checksums(buf, pkg, atom, qmerge_strict, 1) == 0) {
 		pkg_merge(0, atom, pkg);
 		return;
 	}
@@ -1231,7 +1232,7 @@
 	if ((fp = fopen(buf, "r")) == NULL)
 		errp("Unable to open package file %s", buf);
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		if (*buf == '\n') {
 			if (pkg->PF[0] && pkg->CATEGORY[0]) {
 				int ret;
@@ -1281,16 +1282,16 @@
 
 		if (*buf) {
 			/* we dont need all the info */
-			if ((strcmp(buf, "RDEPEND:")) == 0)
+			if (strcmp(buf, "RDEPEND:") == 0)
 				strncpy(pkg->RDEPEND, value, sizeof(Pkg.RDEPEND));
-			if ((strcmp(buf, "PF:")) == 0)
+			if (strcmp(buf, "PF:") == 0)
 				strncpy(pkg->PF, value, sizeof(Pkg.PF));
-			if ((strcmp(buf, "CATEGORY:")) == 0)
+			if (strcmp(buf, "CATEGORY:") == 0)
 				strncpy(pkg->CATEGORY, value, sizeof(Pkg.CATEGORY));
-			if ((strcmp(buf, "REPO:")) == 0)
+			if (strcmp(buf, "REPO:") == 0)
 				strncpy(pkg->REPO, value, sizeof(Pkg.REPO));
 
-			if ((strcmp(buf, "CPV:")) == 0) {
+			if (strcmp(buf, "CPV:") == 0) {
 				if ((atom = atom_explode(value)) != NULL) {
 					snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
 					if (atom->PR_int)
@@ -1300,15 +1301,15 @@
 					atom_implode(atom);
 				}
 			}
-			if ((strcmp(buf, "SLOT:")) == 0)
+			if (strcmp(buf, "SLOT:") == 0)
 				strncpy(pkg->SLOT, value, sizeof(Pkg.SLOT));
-			if ((strcmp(buf, "USE:")) == 0)
+			if (strcmp(buf, "USE:") == 0)
 				strncpy(pkg->USE, value, sizeof(Pkg.USE));
 
 			/* checksums. We must have 1 or the other unless --*/
-			if ((strcmp(buf, "MD5:")) == 0)
+			if (strcmp(buf, "MD5:") == 0)
 				strncpy(pkg->MD5, value, sizeof(Pkg.MD5));
-			if ((strcmp(buf, "SHA1:")) == 0)
+			if (strcmp(buf, "SHA1:") == 0)
 				strncpy(pkg->SHA1, value, sizeof(Pkg.SHA1));
 		}
 	}
@@ -1337,7 +1338,7 @@
 	if ((fp = fopen(buf, "r")) == NULL)
 		errp("Unable to open package file %s", buf);
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		if (*buf == '\n') {
 			if (PF[0] && CATEGORY[0]) {
 				int ret;
@@ -1381,7 +1382,7 @@
 		strncpy(value, p, sizeof(value));
 
 		if (*buf) {
-			if ((strcmp(buf, "CPV:")) == 0) {
+			if (strcmp(buf, "CPV:") == 0) {
 				depend_atom *atom;
 				if ((atom = atom_explode(value)) != NULL) {
 					snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
@@ -1392,9 +1393,9 @@
 					atom_implode(atom);
 				}
 			}
-			if ((strcmp(buf, "PF:")) == 0)
+			if (strcmp(buf, "PF:") == 0)
 				strncpy(PF, value, sizeof(PF));
-			if ((strcmp(buf, "CATEGORY:")) == 0)
+			if (strcmp(buf, "CATEGORY:") == 0)
 				strncpy(CATEGORY, value, sizeof(CATEGORY));
 		}
 	}
@@ -1416,7 +1417,7 @@
 
 	memset(&Pkg, 0, sizeof(Pkg));
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		lineno++;
 		if (*buf == '\n') {
 			if ((strlen(Pkg.PF) > 0) && (strlen(Pkg.CATEGORY) > 0)) {
@@ -1452,29 +1453,29 @@
 
 		switch (*buf) {
 			case 'U':
-				if ((strcmp(buf, "USE:")) == 0) strncpy(Pkg.USE, value, sizeof(Pkg.USE));
+				if (strcmp(buf, "USE:") == 0) strncpy(Pkg.USE, value, sizeof(Pkg.USE));
 				break;
 			case 'P':
-				if ((strcmp(buf, "PF:")) == 0) strncpy(Pkg.PF, value, sizeof(Pkg.PF));
+				if (strcmp(buf, "PF:") == 0) strncpy(Pkg.PF, value, sizeof(Pkg.PF));
 				break;
 			case 'S':
-				if ((strcmp(buf, "SIZE:")) == 0) Pkg.SIZE = atol(value);
-				if ((strcmp(buf, "SLOT:")) == 0) strncpy(Pkg.SLOT, value, sizeof(Pkg.SLOT));
-				if ((strcmp(buf, "SHA1:")) == 0) strncpy(Pkg.SHA1, value, sizeof(Pkg.SHA1));
+				if (strcmp(buf, "SIZE:") == 0) Pkg.SIZE = atol(value);
+				if (strcmp(buf, "SLOT:") == 0) strncpy(Pkg.SLOT, value, sizeof(Pkg.SLOT));
+				if (strcmp(buf, "SHA1:") == 0) strncpy(Pkg.SHA1, value, sizeof(Pkg.SHA1));
 				break;
 			case 'M':
-				if ((strcmp(buf, "MD5:")) == 0) strncpy(Pkg.MD5, value, sizeof(Pkg.MD5));
+				if (strcmp(buf, "MD5:") == 0) strncpy(Pkg.MD5, value, sizeof(Pkg.MD5));
 				break;
 			case 'R':
-				if ((strcmp(buf, "REPO:")) == 0) strncpy(Pkg.REPO, value, sizeof(Pkg.REPO));
-				if ((strcmp(buf, "RDEPEND:")) == 0) strncpy(Pkg.RDEPEND, value, sizeof(Pkg.RDEPEND));
+				if (strcmp(buf, "REPO:") == 0) strncpy(Pkg.REPO, value, sizeof(Pkg.REPO));
+				if (strcmp(buf, "RDEPEND:") == 0) strncpy(Pkg.RDEPEND, value, sizeof(Pkg.RDEPEND));
 				break;
 			case 'L':
-				if ((strcmp(buf, "LICENSE:")) == 0) strncpy(Pkg.LICENSE, value, sizeof(Pkg.LICENSE));
+				if (strcmp(buf, "LICENSE:") == 0) strncpy(Pkg.LICENSE, value, sizeof(Pkg.LICENSE));
 				break;
 			case 'C':
-				if ((strcmp(buf, "CATEGORY:")) == 0) strncpy(Pkg.CATEGORY, value, sizeof(Pkg.CATEGORY));
-				if ((strcmp(buf, "CPV:")) == 0) {
+				if (strcmp(buf, "CATEGORY:") == 0) strncpy(Pkg.CATEGORY, value, sizeof(Pkg.CATEGORY));
+				if (strcmp(buf, "CPV:") == 0) {
 					depend_atom *atom;
 					if ((atom = atom_explode(value)) != NULL) {
 						snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
@@ -1487,7 +1488,7 @@
 				}
 				break;
 			case 'D':
-				if ((strcmp(buf, "DESC:")) == 0) strncpy(Pkg.DESC, value, sizeof(Pkg.DESC));
+				if (strcmp(buf, "DESC:") == 0) strncpy(Pkg.DESC, value, sizeof(Pkg.DESC));
 				break;
 			default:
 				break;
@@ -1499,7 +1500,8 @@
 }
 
 queue *get_world(void);
-queue *get_world(void) {
+queue *get_world(void)
+{
 	FILE *fp;
 	char buf[BUFSIZ];
 	queue *world = NULL;
@@ -1515,7 +1517,7 @@
 		return NULL;
 	}
 
-	while ((fgets(buf, sizeof(buf), fp)) != NULL) {
+	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		char *p;
 		char *slot = (char *) "0";
 
@@ -1532,12 +1534,13 @@
 }
 
 queue *qmerge_load_set(char *, queue *);
-queue *qmerge_load_set(char *buf, queue *set) {
+queue *qmerge_load_set(char *buf, queue *set)
+{
 	if (set != NULL)
 		return set;
-	if ((strcmp(buf, "world") == 0))
+	if (strcmp(buf, "world") == 0)
 		return get_world();
-	if ((strcmp(buf, "all") == 0))
+	if (strcmp(buf, "all") == 0)
 		return get_vdb_atoms(0);
 	return NULL;
 }
@@ -1545,7 +1548,7 @@
 int qmerge_main(int argc, char **argv)
 {
 	int i;
-	const char *Packages = "Packages";
+	const char Packages[] = "Packages";
 	int ARGC = argc;
 	char **ARGV = argv;
 






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-02-21 22:02 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-02-21 22:02 UTC (permalink / raw
  To: gentoo-commits

vapier      11/02/21 22:02:59

  Modified:             qmerge.c
  Log:
  add support for CONFIG_PROTECT_MASK when unmerging, as well as running the pkg_{pre,post}rm funcs

Revision  Changes    Path
1.100                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.100&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.100&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.99&r2=1.100

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.99
retrieving revision 1.100
diff -u -r1.99 -r1.100
--- qmerge.c	21 Feb 2011 06:20:24 -0000	1.99
+++ qmerge.c	21 Feb 2011 22:02:59 -0000	1.100
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.99 2011/02/21 06:20:24 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.100 2011/02/21 22:02:59 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.99 2011/02/21 06:20:24 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.100 2011/02/21 22:02:59 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -105,7 +105,6 @@
 void pkg_process(int, char **, struct pkg_t *);
 void print_Pkg(int, struct pkg_t *);
 int parse_packages(const char *, int, char **);
-int config_protected(const char *, int, char **);
 int match_pkg(const char *, struct pkg_t *);
 int pkg_verify_checksums(char *, struct pkg_t *, depend_atom *, int strict, int display);
 int unmerge_packages(int, char **);
@@ -129,8 +128,7 @@
 	return mkdir(dname, mode);
 }
 
-int q_unlink_q(char *, const char *, int);
-int q_unlink_q(char *path, const char *func, int line)
+static int q_unlink_q(char *path, const char *func, int line)
 {
 	if ((strcmp(path, "/bin/sh") == 0) || (strcmp(path, BUSYBOX) == 0)) {
 		warn("Oh hell no: unlink(%s) from %s line %d", path, func, line);
@@ -153,7 +151,7 @@
 	struct stat st;
 	char check_interactive = interactive;
 
-	if (check_interactive && (stat(dst, &st) != (-1))) {
+	if (check_interactive && (stat(dst, &st) != -1)) {
 		snprintf(buf, sizeof(buf), "qfile -Cqev %s 2>/dev/null", dst);
 		if ((fp = popen(buf, "r")) != NULL) {
 			buf[0] = '\0';
@@ -260,22 +258,29 @@
 	return (char *) buf;
 }
 
-int config_protected(const char *buf, int ARGC, char **ARGV)
+static int
+config_protected(const char *buf, int cp_argc, char **cp_argv,
+                 int cpm_argc, char **cpm_argv)
 {
 	int i;
 	char dest[_Q_PATH_MAX];
 	snprintf(dest, sizeof(dest), "%s%s", portroot, buf);
 
-	for (i = 1; i < ARGC; i++)
-		if (strncmp(ARGV[i], buf, strlen(ARGV[i])) == 0)
-			if ((access(dest, R_OK)) == 0)
+	/* Check CONFIG_PROTECT_MASK */
+	for (i = 1; i < cpm_argc; ++i)
+		if (strncmp(cpm_argv[i], buf, strlen(cpm_argv[i])) == 0)
+			return 0;
+
+	/* Check CONFIG_PROTECT */
+	for (i = 1; i < cp_argc; ++i)
+		if (strncmp(cp_argv[i], buf, strlen(cp_argv[i])) == 0)
+			if (access(dest, R_OK) == 0)
 				return 1;
 
-	if (strncmp("/etc", buf, 4) == 0)
-		if (access(dest, R_OK) == 0)
-			return 1;
+	/* this would probably be bad */
 	if (strcmp("/bin/sh", buf) == 0)
 		return 1;
+
 	return 0;
 }
 
@@ -286,7 +291,7 @@
 
 	assert(pretend == 0);
 
-	if (lstat(buf, &lst) == (-1))
+	if (lstat(buf, &lst) == -1)
 		return;
 	if (lst.st_dev != st.st_dev) {
 		warn("skipping crossmount install masking: %s", buf);
@@ -623,7 +628,7 @@
 	}
 	xchdir("image");
 
-	if (stat("./", &st) == (-1))
+	if (stat("./", &st) == -1)
 		err("Cant stat pwd");
 
 	makeargv(install_mask, &iargc, &iargv);
@@ -699,7 +704,7 @@
 			snprintf(line, sizeof(line), "obj %s %s %lu", &buf[1], hash, st.st_mtime);
 			/* /etc /usr/kde/2/share/config /usr/kde/3/share/config	/var/qmail/control */
 
-			protected = config_protected(&buf[1], ARGC, ARGV);
+			protected = config_protected(&buf[1], ARGC, ARGV, 0, NULL);
 			if (protected) {
 				unsigned char *target_hash = hash_file(dest, HASH_MD5);
 				if (memcmp(target_hash, hash, 16) != 0) {
@@ -757,7 +762,7 @@
 
 			xgetcwd(pwd, sizeof(pwd));
 			xchdir(dirname(tmp)); /* tmp gets eatten up now by the dirname call */
-			if (lstat(path, &lst) != (-1))
+			if (lstat(path, &lst) != -1)
 				unlink_q(dest);
 			/* if (path[0] != '/')
 				puts("path does not start with /");
@@ -822,12 +827,19 @@
 
 int pkg_unmerge(const char *cat, const char *pkgname)
 {
-	char buf[BUFSIZ];
+	size_t buflen;
+	char *buf, *vdb_path;
 	FILE *fp;
-	int argc;
-	char **argv;
+	int ret, fd, vdb_fd;
+	int cp_argc, cpm_argc;
+	char **cp_argv, **cpm_argv;
 	llist_char *dirs = NULL;
 
+	ret = 1;
+	buf = NULL;
+	vdb_path = NULL;
+	vdb_fd = fd = -1;
+
 	if ((strchr(pkgname, ' ') != NULL) || (strchr(cat, ' ') != NULL)) {
 		qfprintf(stderr, "%s!!!%s '%s' '%s' (ambiguous name) specify fully-qualified pkgs\n", RED, NORM, cat, pkgname);
 		qfprintf(stderr, "%s!!!%s %s/%s (ambiguous name) specify fully-qualified pkgs\n", RED, NORM, cat, pkgname);
@@ -839,16 +851,44 @@
 	if (pretend == 100)
 		return 0;
 
-	snprintf(buf, sizeof(buf), "%s/%s/%s/%s/CONTENTS", portroot, portvdb, cat, pkgname);
-
-	if ((fp = fopen(buf, "r")) == NULL)
-		return 1;
+	/* Get a handle on the vdb path which we'll use everywhere else */
+	xasprintf(&vdb_path, "%s/%s/%s/%s/", portroot, portvdb, cat, pkgname);
+	vdb_fd = open(vdb_path, O_RDONLY | O_CLOEXEC);
+	if (vdb_fd == -1) {
+		warnp("unable to read %s", vdb_path);
+		goto done;
+	}
 
-	argc = 0;
-	argv = NULL;
-	makeargv(config_protect, &argc, &argv);
+	/* First execute the pkg_prerm step */
+	if (!pretend) {
+		qprintf(">>> pkg_prerm\n");
+		xchdir(vdb_path);
+		xsystembash(
+			"bzip2 -dc environment.bz2 > environment && "
+			"pkg_prerm() { :; } && "
+			". ./environment && "
+			"pkg_prerm"
+		);
+	}
+
+	/* Now start removing all the installed files */
+	fd = openat(vdb_fd, "CONTENTS", O_RDONLY | O_CLOEXEC);
+	if (fd == -1) {
+		warnp("unable to read %s", "CONTENTS");
+		goto done;
+	}
+	fp = fdopen(fd, "r");
+	if (fp == NULL)
+		goto done;
+
+	/* XXX: be nice to pull this out of the current func
+	 *      so we don't keep reparsing the same env var
+	 *      when unmerging multiple packages.
+	 */
+	makeargv(config_protect, &cp_argc, &cp_argv);
+	makeargv(config_protect_mask, &cpm_argc, &cpm_argv);
 
-	while (fgets(buf, sizeof(buf), fp) != NULL) {
+	while (getline(&buf, &buflen, fp) != -1) {
 		contents_entry *e;
 		char zing[20];
 		int protected = 0;
@@ -858,8 +898,9 @@
 		e = contents_parse_line(buf);
 		if (!e) continue;
 		snprintf(dst, sizeof(dst), "%s%s", portroot, e->name);
-		protected = config_protected(e->name, argc, argv);
+		protected = config_protected(e->name, cp_argc, cp_argv, cpm_argc, cpm_argv);
 		snprintf(zing, sizeof(zing), "%s%s%s", protected ? YELLOW : GREEN, protected ? "***" : "<<<" , NORM);
+
 		/* Should we remove in order symlinks,objects,dirs ? */
 		switch (e->type) {
 			case CONTENTS_DIR:
@@ -870,17 +911,19 @@
 					list->next = dirs;
 					dirs = list;
 				}
-				qprintf("%s %s%s%s/\n", zing, DKBLUE, dst, NORM);
 				break;
 			case CONTENTS_OBJ:
-				if (!protected)	unlink_q(dst);
+				if (!protected)
+					unlink_q(dst);
 				qprintf("%s %s\n", zing, dst);
 				break;
 			case CONTENTS_SYM:
-				if (protected) break;
-				if (e->name[0] != '/') break;
+				if (protected)
+					break;
+				if (e->name[0] != '/')
+					break;
 				if (e->sym_target[0] != '/') {
-					if (lstat(dst, &lst) != (-1)) {
+					if (lstat(dst, &lst) != -1) {
 						if (S_ISLNK(lst.st_mode)) {
 							qprintf("%s %s%s -> %s%s\n", zing, CYAN, dst, e->sym_target, NORM);
 							unlink_q(dst);
@@ -892,7 +935,7 @@
 					warn("!!! %s -> %s", e->name, e->sym_target);
 					break;
 				}
-				if (lstat(dst, &lst) != (-1)) {
+				if (lstat(dst, &lst) != -1) {
 					if (S_ISLNK(lst.st_mode)) {
 						qprintf("%s %s%s -> %s%s\n", zing, CYAN, dst, e->sym_target, NORM);
 						unlink_q(dst);
@@ -910,23 +953,68 @@
 	}
 
 	fclose(fp);
+	fd = -1;
 
-	/* remove all dirs in reverse order */
+	/* Then remove all dirs in reverse order */
 	while (dirs != NULL) {
 		llist_char *list = dirs;
-		dirs = dirs->next;
-		rmdir(list->data);
+		char *dir = list->data;
+		int rm;
+
+		rm = pretend ? -1 : rmdir(dir);
+		qprintf("%s%s%s %s%s%s/\n", rm ? YELLOW : GREEN, rm ? "---" : "<<<",
+			NORM, DKBLUE, dir, NORM);
+
 		free(list->data);
 		free(list);
+		dirs = dirs->next;
 	}
 
-	freeargv(argc, argv);
+	freeargv(cp_argc, cp_argv);
+	freeargv(cpm_argc, cpm_argv);
 
+	/* Then execute the pkg_postrm step */
 	if (!pretend) {
-		snprintf(buf, sizeof(buf), BUSYBOX " rm -rf %s/%s/%s/%s", portroot, portvdb, cat, pkgname);
-		xsystem(buf);
+		qprintf(">>> pkg_postrm\n");
+		xsystembash(
+			/* "bzip2 -dc environment.bz2 > environment && " */
+			"pkg_postrm() { :; } && "
+			". ./environment && "
+			"pkg_postrm"
+		);
 	}
-	return 1;
+
+	if (!pretend) {
+		/* Finally delete the vdb entry */
+		DIR *dir;
+		struct dirent *de;
+
+		dir = fdopendir(vdb_fd);
+		if (!dir)
+			goto done;
+
+		while ((de = readdir(dir)) != NULL)
+			unlinkat(vdb_fd, de->d_name, 0);
+
+		closedir(dir);
+		vdb_fd = -1;
+
+		rmdir(vdb_path);
+
+		/* XXX: Really only needed because we shell out to qlist and such ... */
+		xchdir("/");
+	}
+
+	ret = 0;
+ done:
+	if (fd != -1)
+		close(fd);
+	if (vdb_fd != -1)
+		close(vdb_fd);
+	free(buf);
+	free(vdb_path);
+
+	return ret;
 }
 
 int unlink_empty(char *buf)






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-02-22  6:10 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-02-22  6:10 UTC (permalink / raw
  To: gentoo-commits

vapier      11/02/22 06:10:16

  Modified:             qmerge.c
  Log:
  unify the pkg_{pre,post}rm steps a bit, and seed the env with stub debug-print funcs like the pm does

Revision  Changes    Path
1.101                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.101&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.101&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.100&r2=1.101

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.100
retrieving revision 1.101
diff -u -r1.100 -r1.101
--- qmerge.c	21 Feb 2011 22:02:59 -0000	1.100
+++ qmerge.c	22 Feb 2011 06:10:16 -0000	1.101
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.100 2011/02/21 22:02:59 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.101 2011/02/22 06:10:16 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.100 2011/02/21 22:02:59 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.101 2011/02/22 06:10:16 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -424,6 +424,20 @@
 	return ret;
 }
 
+#define pkg_run_func(func, setup) \
+	do { \
+		qprintf(">>> %s\n", func); \
+		xsystembash( \
+			"debug-print() { :; }; " \
+			"debug-print-function() { :; }; " \
+			"debug-print-section() { :; }; " \
+			func "() { :; }; " \
+			setup \
+			". ./environment && " \
+			func \
+		); \
+	} while (0)
+
 /* oh shit getting into pkg mgt here. FIXME: write a real dep resolver. */
 void pkg_merge(int level, depend_atom *atom, struct pkg_t *pkg)
 {
@@ -861,14 +875,8 @@
 
 	/* First execute the pkg_prerm step */
 	if (!pretend) {
-		qprintf(">>> pkg_prerm\n");
 		xchdir(vdb_path);
-		xsystembash(
-			"bzip2 -dc environment.bz2 > environment && "
-			"pkg_prerm() { :; } && "
-			". ./environment && "
-			"pkg_prerm"
-		);
+		pkg_run_func("pkg_prerm", "bzip2 -dc environment.bz2 > environment && ");
 	}
 
 	/* Now start removing all the installed files */
@@ -974,15 +982,8 @@
 	freeargv(cpm_argc, cpm_argv);
 
 	/* Then execute the pkg_postrm step */
-	if (!pretend) {
-		qprintf(">>> pkg_postrm\n");
-		xsystembash(
-			/* "bzip2 -dc environment.bz2 > environment && " */
-			"pkg_postrm() { :; } && "
-			". ./environment && "
-			"pkg_postrm"
-		);
-	}
+	if (!pretend)
+		pkg_run_func("pkg_postrm", "");
 
 	if (!pretend) {
 		/* Finally delete the vdb entry */






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-02-24  1:29 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-02-24  1:29 UTC (permalink / raw
  To: gentoo-commits

vapier      11/02/24 01:29:27

  Modified:             qmerge.c
  Log:
  use a proper linked list structure for the package todo rather than building up and breaking down strings all the time

Revision  Changes    Path
1.104                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.104&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.104&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.103&r2=1.104

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.103
retrieving revision 1.104
diff -u -r1.103 -r1.104
--- qmerge.c	23 Feb 2011 22:58:51 -0000	1.103
+++ qmerge.c	24 Feb 2011 01:29:27 -0000	1.104
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.103 2011/02/23 22:58:51 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.104 2011/02/24 01:29:27 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.103 2011/02/23 22:58:51 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.104 2011/02/24 01:29:27 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -67,6 +67,7 @@
 char nomd5 = 0;
 char qmerge_strict = 0;
 char update_only = 0;
+const char Packages[] = "Packages";
 
 /*
 	"CHOST", "DEPEND", "DESCRIPTION", "EAPI",
@@ -96,18 +97,13 @@
 
 int interactive_rename(const char *, const char *, struct pkg_t *);
 void fetch(const char *, const char *);
-void qmerge_initialize(const char *);
 char *best_version(const char *, const char  *);
 void pkg_fetch(int, depend_atom *, struct pkg_t *);
 void pkg_merge(int, depend_atom *, struct pkg_t *);
 int pkg_unmerge(const char *, const char *);
 int unlink_empty(char *);
-void pkg_process(int, char **, struct pkg_t *);
 void print_Pkg(int, struct pkg_t *);
-int parse_packages(const char *, int, char **);
-int match_pkg(const char *, struct pkg_t *);
 int pkg_verify_checksums(char *, struct pkg_t *, depend_atom *, int strict, int display);
-int unmerge_packages(int, char **);
 char *find_binpkg(const char *);
 
 struct pkg_t *grab_binpkg_info(const char *);
@@ -184,7 +180,7 @@
 	fflush(stderr);
 }
 
-void qmerge_initialize(const char *Packages)
+static void qmerge_initialize(void)
 {
 	if (strlen(BUSYBOX))
 		if (access(BUSYBOX, X_OK) != 0)
@@ -930,6 +926,8 @@
 
 	snprintf(buf, sizeof(buf), "%s/%s.tbz2", pkgdir, pkg->PF);
 	unlink(buf);
+
+	printf("%s>>>%s %s%s%s/%s%s%s\n", YELLOW, NORM, WHITE, atom->CATEGORY, NORM, CYAN, atom->PN, NORM);
 }
 
 int pkg_unmerge(const char *cat, const char *pkgname)
@@ -1113,37 +1111,36 @@
 	return -1;
 }
 
-int match_pkg(const char *name, struct pkg_t *pkg)
+static int match_pkg(queue *ll, struct pkg_t *pkg)
 {
 	depend_atom *atom;
 	char buf[255], buf2[255];
 	int match = 0;
-	char *ptr;
 
 	snprintf(buf, sizeof(buf), "%s/%s", pkg->CATEGORY, pkg->PF);
 	if ((atom = atom_explode(buf)) == NULL)
 		errf("%s/%s is not a valid atom", pkg->CATEGORY, pkg->PF);
 
 	/* verify this is the requested package */
-	if (strcmp(name, buf) == 0)
+	if (strcmp(ll->name, buf) == 0)
 		match = 1;
 
-	if (strcmp(name, pkg->PF) == 0)
+	if (strcmp(ll->name, pkg->PF) == 0)
 		match = 2;
 
 	snprintf(buf2, sizeof(buf2), "%s/%s", pkg->CATEGORY, atom->PN);
 
-	if (strcmp(name, buf2) == 0)
+	if (strcmp(ll->name, buf2) == 0)
 		match = 3;
 
-	if (strcmp(name, atom->PN) == 0)
+	if (strcmp(ll->name, atom->PN) == 0)
 		match = 4;
 
 	if (match)
 		goto match_done;
 
-	if ((ptr = strchr(name, ':')) != NULL) {
-		depend_atom *subatom = atom_explode(name);
+	if (ll->item) {
+		depend_atom *subatom = atom_explode(ll->name);
 		if (subatom == NULL)
 			goto match_done;
 		if (strcmp(atom->PN, subatom->PN) == 0)
@@ -1200,28 +1197,26 @@
 	return ret;
 }
 
-void pkg_process(int argc, char **argv, struct pkg_t *pkg)
+static void pkg_process(queue *todo, struct pkg_t *pkg)
 {
+	queue *ll;
 	depend_atom *atom;
 	char buf[255];
-	int i;
-
-	memset(buf, 0, sizeof(buf));
 
 	snprintf(buf, sizeof(buf), "%s/%s", pkg->CATEGORY, pkg->PF);
 	if ((atom = atom_explode(buf)) == NULL)
 		errf("%s/%s is not a valid atom", pkg->CATEGORY, pkg->PF);
 
-	for (i = 1; i < argc; i++) {
-		if (argv[i][0] == '-')
-			continue;
-
-		/* verify this is the requested package */
-		if (match_pkg(argv[i], pkg) < 1)
-			continue;
+	ll = todo;
+	while (ll) {
+		if (ll->name[0] != '-' && match_pkg(ll, pkg)) {
+			/* fetch all requested packages */
+			pkg_fetch(0, atom, pkg);
+		}
 
-		pkg_fetch(0, atom, pkg);
+		ll = ll->next;
 	}
+
 	/* free the atom */
 	atom_implode(atom);
 }
@@ -1349,13 +1344,13 @@
 	if ((p = best_version(pkg->CATEGORY, atom->PN)) != NULL) {
 		if (*p) {
 			int ret;
-			char *icolor = (char *) RED;
+			const char *icolor = RED;
 			ret = atom_compare_str(buf, p);
 			switch (ret) {
-				case EQUAL: icolor = (char *) RED; break;
-				case NEWER: icolor = (char *) YELLOW; break;
-				case OLDER: icolor = (char *) BLUE; break;
-				default: icolor = (char *) NORM; break;
+				case EQUAL: icolor = RED;    break;
+				case NEWER: icolor = YELLOW; break;
+				case OLDER: icolor = BLUE;   break;
+				default:    icolor = NORM;   break;
 			}
 			printf(" %sInstalled%s:%s %s%s%s\n", DKGREEN, YELLOW, NORM, icolor, p, NORM);
 		}
@@ -1363,28 +1358,30 @@
 	atom_implode(atom);
 }
 
-int unmerge_packages(int argc, char **argv)
+static int unmerge_packages(queue *todo)
 {
 	depend_atom *atom;
 	char *p;
-	int i;
 
-	if (argc == optind)
-		return 1;
-
-	for (i = 1; i < argc; i++) {
+	while (todo) {
 		char buf[512];
 
-		if (argv[i][0] == '-')
-			continue;
+		if (todo->name[0] == '-')
+			goto next;
 
-		p = best_version(NULL, argv[i]);
-		if (!*p) continue;
-		if ((atom = atom_explode(p)) == NULL) continue;
+		p = best_version(NULL, todo->name);
+		if (!*p)
+			goto next;
+		if ((atom = atom_explode(p)) == NULL)
+			goto next;
 		atom2str(atom, buf, sizeof(buf));
 		pkg_unmerge(atom->CATEGORY, buf);
 		atom_implode(atom);
+
+ next:
+		todo = todo->next;
 	}
+
 	return 0;
 }
 
@@ -1392,7 +1389,6 @@
 {
 	FILE *fp;
 	char buf[BUFSIZ];
-	char value[BUFSIZ];
 	char *p;
 	depend_atom *atom;
 
@@ -1449,28 +1445,26 @@
 		if ((p = strchr(buf, '\n')) != NULL)
 			*p = 0;
 
-		memset(value, 0, sizeof(value));
 		if ((p = strchr(buf, ':')) == NULL)
 			continue;
 		if ((p = strchr(buf, ' ')) == NULL)
 			continue;
 		*p = 0;
 		++p;
-		strncpy(value, p, sizeof(value));
 
 		if (*buf) {
 			/* we dont need all the info */
 			if (strcmp(buf, "RDEPEND:") == 0)
-				strncpy(pkg->RDEPEND, value, sizeof(Pkg.RDEPEND));
+				strncpy(pkg->RDEPEND, p, sizeof(Pkg.RDEPEND));
 			if (strcmp(buf, "PF:") == 0)
-				strncpy(pkg->PF, value, sizeof(Pkg.PF));
+				strncpy(pkg->PF, p, sizeof(Pkg.PF));
 			if (strcmp(buf, "CATEGORY:") == 0)
-				strncpy(pkg->CATEGORY, value, sizeof(Pkg.CATEGORY));
+				strncpy(pkg->CATEGORY, p, sizeof(Pkg.CATEGORY));
 			if (strcmp(buf, "REPO:") == 0)
-				strncpy(pkg->REPO, value, sizeof(Pkg.REPO));
+				strncpy(pkg->REPO, p, sizeof(Pkg.REPO));
 
 			if (strcmp(buf, "CPV:") == 0) {
-				if ((atom = atom_explode(value)) != NULL) {
+				if ((atom = atom_explode(p)) != NULL) {
 					snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
 					if (atom->PR_int)
 						snprintf(buf, sizeof(buf), "%s-%s-r%i", atom->PN, atom->PV, atom->PR_int);
@@ -1480,15 +1474,15 @@
 				}
 			}
 			if (strcmp(buf, "SLOT:") == 0)
-				strncpy(pkg->SLOT, value, sizeof(Pkg.SLOT));
+				strncpy(pkg->SLOT, p, sizeof(Pkg.SLOT));
 			if (strcmp(buf, "USE:") == 0)
-				strncpy(pkg->USE, value, sizeof(Pkg.USE));
+				strncpy(pkg->USE, p, sizeof(Pkg.USE));
 
 			/* checksums. We must have 1 or the other unless --*/
 			if (strcmp(buf, "MD5:") == 0)
-				strncpy(pkg->MD5, value, sizeof(Pkg.MD5));
+				strncpy(pkg->MD5, p, sizeof(Pkg.MD5));
 			if (strcmp(buf, "SHA1:") == 0)
-				strncpy(pkg->SHA1, value, sizeof(Pkg.SHA1));
+				strncpy(pkg->SHA1, p, sizeof(Pkg.SHA1));
 		}
 	}
 	fclose(fp);
@@ -1500,7 +1494,6 @@
 {
 	FILE *fp;
 	char buf[BUFSIZ];
-	char value[BUFSIZ];
 	char *p;
 	char PF[sizeof(Pkg.PF)];
 	char CATEGORY[sizeof(Pkg.CATEGORY)];
@@ -1550,19 +1543,17 @@
 		if ((p = strchr(buf, '\n')) != NULL)
 			*p = 0;
 
-		memset(&value, 0, sizeof(value));
 		if ((p = strchr(buf, ':')) == NULL)
 			continue;
 		if ((p = strchr(buf, ' ')) == NULL)
 			continue;
 		*p = 0;
 		++p;
-		strncpy(value, p, sizeof(value));
 
 		if (*buf) {
 			if (strcmp(buf, "CPV:") == 0) {
 				depend_atom *atom;
-				if ((atom = atom_explode(value)) != NULL) {
+				if ((atom = atom_explode(p)) != NULL) {
 					snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
 					if (atom->PR_int)
 						snprintf(buf, sizeof(buf), "%s-%s-r%i", atom->PN, atom->PV, atom->PR_int);
@@ -1572,22 +1563,20 @@
 				}
 			}
 			if (strcmp(buf, "PF:") == 0)
-				strncpy(PF, value, sizeof(PF));
+				strncpy(PF, p, sizeof(PF));
 			if (strcmp(buf, "CATEGORY:") == 0)
-				strncpy(CATEGORY, value, sizeof(CATEGORY));
+				strncpy(CATEGORY, p, sizeof(CATEGORY));
 		}
 	}
 	fclose(fp);
 	return best_match;
 }
 
-int parse_packages(const char *Packages, int argc, char **argv)
+static int parse_packages(queue *todo)
 {
 	FILE *fp;
-	char buf[BUFSIZ];
-	char value[BUFSIZ];
-	char *p;
-	int i;
+	size_t buflen;
+	char *buf, *p;
 	long lineno = 0;
 
 	if ((fp = fopen(Packages, "r")) == NULL)
@@ -1595,23 +1584,27 @@
 
 	memset(&Pkg, 0, sizeof(Pkg));
 
-	while (fgets(buf, sizeof(buf), fp) != NULL) {
+	buf = NULL;
+	while (getline(&buf, &buflen, fp) != -1) {
 		lineno++;
 		if (*buf == '\n') {
 			if ((strlen(Pkg.PF) > 0) && (strlen(Pkg.CATEGORY) > 0)) {
-				struct pkg_t *pkg = xmalloc(sizeof(struct pkg_t));
-				memcpy(pkg, &Pkg, sizeof(struct pkg_t));
+				struct pkg_t *pkg = xmalloc(sizeof(*pkg));
+				*pkg = Pkg;
+
 				if (search_pkgs) {
-					if (argc != optind) {
-						for (i = 0; i < argc; i++)
-							if ((match_pkg(argv[i], pkg) > 0) || (strcmp(argv[i], pkg->CATEGORY) == 0))
+					if (todo) {
+						queue *ll = todo;
+						while (ll) {
+							if ((match_pkg(ll, pkg) > 0) || (strcmp(ll->name, pkg->CATEGORY) == 0))
 								print_Pkg(verbose, pkg);
-					} else {
+							ll = ll->next;
+						}
+					} else
 						print_Pkg(verbose, pkg);
-					}
-				} else {
-					pkg_process(argc, argv, pkg);
-				}
+				} else
+					pkg_process(todo, pkg);
+
 				free(pkg);
 			}
 			memset(&Pkg, 0, sizeof(Pkg));
@@ -1620,115 +1613,137 @@
 		if ((p = strchr(buf, '\n')) != NULL)
 			*p = 0;
 
-		memset(&value, 0, sizeof(value));
 		if ((p = strchr(buf, ':')) == NULL)
 			continue;
 		if ((p = strchr(buf, ' ')) == NULL)
 			continue;
 		*p = 0;
 		++p;
-		strncpy(value, p, sizeof(value));
 
 		switch (*buf) {
 			case 'U':
-				if (strcmp(buf, "USE:") == 0) strncpy(Pkg.USE, value, sizeof(Pkg.USE));
+				if (strcmp(buf, "USE:") == 0) strncpy(Pkg.USE, p, sizeof(Pkg.USE));
 				break;
 			case 'P':
-				if (strcmp(buf, "PF:") == 0) strncpy(Pkg.PF, value, sizeof(Pkg.PF));
+				if (strcmp(buf, "PF:") == 0) strncpy(Pkg.PF, p, sizeof(Pkg.PF));
 				break;
 			case 'S':
-				if (strcmp(buf, "SIZE:") == 0) Pkg.SIZE = atol(value);
-				if (strcmp(buf, "SLOT:") == 0) strncpy(Pkg.SLOT, value, sizeof(Pkg.SLOT));
-				if (strcmp(buf, "SHA1:") == 0) strncpy(Pkg.SHA1, value, sizeof(Pkg.SHA1));
+				if (strcmp(buf, "SIZE:") == 0) Pkg.SIZE = atol(p);
+				if (strcmp(buf, "SLOT:") == 0) strncpy(Pkg.SLOT, p, sizeof(Pkg.SLOT));
+				if (strcmp(buf, "SHA1:") == 0) strncpy(Pkg.SHA1, p, sizeof(Pkg.SHA1));
 				break;
 			case 'M':
-				if (strcmp(buf, "MD5:") == 0) strncpy(Pkg.MD5, value, sizeof(Pkg.MD5));
+				if (strcmp(buf, "MD5:") == 0) strncpy(Pkg.MD5, p, sizeof(Pkg.MD5));
 				break;
 			case 'R':
-				if (strcmp(buf, "REPO:") == 0) strncpy(Pkg.REPO, value, sizeof(Pkg.REPO));
-				if (strcmp(buf, "RDEPEND:") == 0) strncpy(Pkg.RDEPEND, value, sizeof(Pkg.RDEPEND));
+				if (strcmp(buf, "REPO:") == 0) strncpy(Pkg.REPO, p, sizeof(Pkg.REPO));
+				if (strcmp(buf, "RDEPEND:") == 0) strncpy(Pkg.RDEPEND, p, sizeof(Pkg.RDEPEND));
 				break;
 			case 'L':
-				if (strcmp(buf, "LICENSE:") == 0) strncpy(Pkg.LICENSE, value, sizeof(Pkg.LICENSE));
+				if (strcmp(buf, "LICENSE:") == 0) strncpy(Pkg.LICENSE, p, sizeof(Pkg.LICENSE));
 				break;
 			case 'C':
-				if (strcmp(buf, "CATEGORY:") == 0) strncpy(Pkg.CATEGORY, value, sizeof(Pkg.CATEGORY));
+				if (strcmp(buf, "CATEGORY:") == 0) strncpy(Pkg.CATEGORY, p, sizeof(Pkg.CATEGORY));
 				if (strcmp(buf, "CPV:") == 0) {
 					depend_atom *atom;
-					if ((atom = atom_explode(value)) != NULL) {
-						snprintf(buf, sizeof(buf), "%s-%s", atom->PN, atom->PV);
+					if ((atom = atom_explode(p)) != NULL) {
 						if (atom->PR_int)
-							snprintf(buf, sizeof(buf), "%s-%s-r%i", atom->PN, atom->PV, atom->PR_int);
-						strncpy(Pkg.PF, buf, sizeof(Pkg.PF));
+							snprintf(Pkg.PF, sizeof(Pkg.PF), "%s-%s-r%i", atom->PN, atom->PV, atom->PR_int);
+						else
+							snprintf(Pkg.PF, sizeof(Pkg.PF), "%s-%s", atom->PN, atom->PV);
 						strncpy(Pkg.CATEGORY, atom->CATEGORY, sizeof(Pkg.CATEGORY));
 						atom_implode(atom);
 					}
 				}
 				break;
 			case 'D':
-				if (strcmp(buf, "DESC:") == 0) strncpy(Pkg.DESC, value, sizeof(Pkg.DESC));
+				if (strcmp(buf, "DESC:") == 0) strncpy(Pkg.DESC, p, sizeof(Pkg.DESC));
 				break;
 			default:
 				break;
 		}
-		memset(&buf, 0, sizeof(buf));
 	}
+
+	free(buf);
 	fclose(fp);
+
 	return 0;
 }
 
-queue *get_world(void);
-queue *get_world(void)
+static queue *qmerge_add_set_atom(char *satom, queue *set)
+{
+	char *p;
+	const char *slot;
+
+	if ((p = strchr(satom, ':')) != NULL) {
+		*p = 0;
+		slot = p + 1;
+	} else
+		slot = "0";
+
+	return add_set(satom, slot, set);
+}
+
+static queue *qmerge_add_set_file(const char *file, queue *set)
 {
 	FILE *fp;
-	char buf[BUFSIZ];
-	queue *world = NULL;
-	char fname[_Q_PATH_MAX];
+	size_t buflen;
+	char *buf;
+	const char *fname;
 
-	if (*portroot && strcmp(portroot, "/") != 0)
-		snprintf(fname, sizeof(fname), "%s/var/lib/portage/world", portroot);
-	else
-		strncpy(fname,  "/var/lib/portage/world", sizeof(fname));
+	/* Find the file to read */
+	if (*portroot && strcmp(portroot, "/") != 0) {
+		size_t len, flen;
+		char *f;
+
+		len = strlen(portroot);
+		flen = strlen(file) + 1;
+		fname = f = alloca(len + flen);
+		memcpy(f, portroot, len);
+		memcpy(f + len, file, flen);
+	} else
+		fname = file;
 
 	if ((fp = fopen(fname, "r")) == NULL) {
-		warnp("fopen(\"%s\", \"r\"); = -1", fname);
+		warnp("unable to read set file %s", fname);
 		return NULL;
 	}
 
-	while (fgets(buf, sizeof(buf), fp) != NULL) {
-		char *p;
-		char *slot = (char *) "0";
-
+	/* Load each entry */
+	buf = NULL;
+	while (getline(&buf, &buflen, fp) != -1) {
 		rmspace(buf);
-
-		if ((p = strchr(buf, ':')) != NULL) {
-			*p = 0;
-			slot = p + 1;
-		}
-		world = add_set(buf, slot, world);
+		set = qmerge_add_set_atom(buf, set);
 	}
+	free(buf);
+
 	fclose(fp);
-	return world;
+
+	return set;
 }
 
-queue *qmerge_load_set(char *, queue *);
-queue *qmerge_load_set(char *buf, queue *set)
+static queue *qmerge_add_set(char *buf, queue *set)
 {
-	if (set != NULL)
-		return set;
 	if (strcmp(buf, "world") == 0)
-		return get_world();
+		return qmerge_add_set_file("/var/lib/portage/world", set);
 	if (strcmp(buf, "all") == 0)
 		return get_vdb_atoms(0);
-	return NULL;
+	/* XXX: Should load custom sets here */
+	return qmerge_add_set_atom(buf, set);
+}
+
+static int qmerge_run(queue *todo)
+{
+	if (uninstall)
+		return unmerge_packages(todo);
+	else
+		return parse_packages(todo);
 }
 
 int qmerge_main(int argc, char **argv)
 {
 	int i, ret;
-	const char Packages[] = "Packages";
-	int ARGC = argc;
-	char **ARGV = argv;
+	queue *todo;
 
 	if (argc < 2)
 		qmerge_usage(EXIT_FAILURE);
@@ -1761,78 +1776,43 @@
 		}
 	}
 
-	if (uninstall) {
-		if (interactive) {
-			int save_pretend = pretend;
-			int save_verbose = verbose;
-			int save_quiet = quiet;
-
-			pretend = 100;
-			verbose = 0;
-			quiet = 1;
-			ret = unmerge_packages(argc, argv);
-			if (ret || save_pretend)
-				return ret;
+	/* Expand any portage sets on the command line */
+	todo = NULL;
+	for (i = optind; i < argc; ++i)
+		todo = qmerge_add_set(argv[i], todo);
+
+	if (!uninstall)
+		qmerge_initialize();
+
+	/* Make sure the user wants to do it */
+	if (interactive) {
+		int save_pretend = pretend;
+		int save_verbose = verbose;
+		int save_quiet = quiet;
+
+		pretend = 100;
+		verbose = 0;
+		quiet = 1;
+		ret = qmerge_run(todo);
+		if (ret || save_pretend)
+			return ret;
 
+		if (uninstall) {
 			if (!prompt("OK to unmerge these packages"))
 				return 0;
-
-			pretend = save_pretend;
-			verbose = save_verbose;
-			quiet = save_quiet;
+		} else {
+			if (!prompt("OK to merge these packages"))
+				return 0;
 		}
 
-		return unmerge_packages(argc, argv);
+		pretend = save_pretend;
+		verbose = save_verbose;
+		quiet = save_quiet;
 	}
 
-	ARGC = argc;
-	ARGV = argv;
-
-	qmerge_initialize(Packages);
-
-	if (optind < argc) {
-		queue *world = NULL;
-		int ind = optind;
-		while (ind < argc) {
-			size_t size = 0;
-			i = ind;
-			ind++;
-
-			if ((world = qmerge_load_set(argv[i], world)) == NULL)
-				continue;
-
-			if (world != NULL) {
-				queue *ll;
-				char *ptr;
-
-				for (ll = world; ll != NULL; ll = ll->next)
-					size += (strlen(ll->name) + 1);
-				if (size < 1)
-					continue;
-
-				size += (strlen(argv[0]) + 1);
-				ptr = xmalloc(size);
-				sprintf(ptr, "%s ", argv[0]);
-
-				for (ll = world; ll != NULL; ll = ll->next) {
-					char *p = NULL;
-					xasprintf(&p, "%s ", ll->name);
-					strcat(ptr, p);
-					free(p);
-				}
-				ARGC = 0;
-				ARGV = NULL;
-				/* this will leak mem */
-				/* follow_rdepends = 0; */
-				makeargv(ptr, &ARGC, &ARGV);
-
-				free(ptr);
-				free_sets(world);
-				world = NULL;
-			}
-		}
-	}
-	return parse_packages(Packages, ARGC, ARGV);
+	ret = qmerge_run(todo);
+	free_sets(todo);
+	return ret;
 }
 
 #else






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-03-02  3:51 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2011-03-02  3:51 UTC (permalink / raw
  To: gentoo-commits

solar       11/03/02 03:51:01

  Modified:             qmerge.c
  Log:
  fix unlink behavior

Revision  Changes    Path
1.105                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.105&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.105&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.104&r2=1.105

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.104
retrieving revision 1.105
diff -u -r1.104 -r1.105
--- qmerge.c	24 Feb 2011 01:29:27 -0000	1.104
+++ qmerge.c	2 Mar 2011 03:51:01 -0000	1.105
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.104 2011/02/24 01:29:27 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.105 2011/03/02 03:51:01 solar Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.104 2011/02/24 01:29:27 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.105 2011/03/02 03:51:01 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -919,7 +919,7 @@
 	/* move the local vdb copy to the final place */
 	interactive_rename("vdb", buf, pkg);
 
-	snprintf(buf, sizeof(buf), BUSYBOX " %s.tar.bz2", pkg->PF);
+	snprintf(buf, sizeof(buf), "%s.tar.bz2", pkg->PF);
 	unlink_q(buf);
 	xchdir(port_tmpdir);
 	rm_rf(pkg->PF);






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-03-02  9:22 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-03-02  9:22 UTC (permalink / raw
  To: gentoo-commits

vapier      11/03/02 09:22:15

  Modified:             qmerge.c
  Log:
  scrub now unused code

Revision  Changes    Path
1.107                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.107&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.107&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.106&r2=1.107

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.106
retrieving revision 1.107
diff -u -r1.106 -r1.107
--- qmerge.c	2 Mar 2011 09:16:22 -0000	1.106
+++ qmerge.c	2 Mar 2011 09:22:14 -0000	1.107
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.106 2011/03/02 09:16:22 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.107 2011/03/02 09:22:14 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.106 2011/03/02 09:16:22 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.107 2011/03/02 09:22:14 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -101,29 +101,6 @@
 _q_static struct pkg_t *grab_binpkg_info(const char *);
 _q_static char *find_binpkg(const char *);
 
-_q_static int q_unlink_q(const char *path, const char *func, int line)
-{
-	int ret;
-	char *d;
-
-	if (pretend)
-		return 0;
-
-	ret = unlink(path);
-	if (ret)
-		return ret;
-
-	d = strrchr(path, '/');
-	if (d) {
-		*d = '\0';
-		rmdir_r(path);
-	}
-
-	return ret;
-}
-
-#define unlink_q(path) q_unlink_q(path, __FUNCTION__, __LINE__)
-
 _q_static void fetch(const char *destdir, const char *src)
 {
 	char buf[BUFSIZ];
@@ -1167,8 +1144,6 @@
 	freeargv(cpm_argc, cpm_argv);
 
 	if (!pretend) {
-		char *dir;
-
 		/* Then execute the pkg_postrm step */
 		pkg_run_func(vdb_path, phases, "pkg_postrm");
 






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-03-05 19:28 Ned Ludd (solar)
  0 siblings, 0 replies; 39+ messages in thread
From: Ned Ludd (solar) @ 2011-03-05 19:28 UTC (permalink / raw
  To: gentoo-commits

solar       11/03/05 19:28:21

  Modified:             qmerge.c
  Log:
  - names should match

Revision  Changes    Path
1.108                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.108&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.108&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.107&r2=1.108

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.107
retrieving revision 1.108
diff -u -r1.107 -r1.108
--- qmerge.c	2 Mar 2011 09:22:14 -0000	1.107
+++ qmerge.c	5 Mar 2011 19:28:21 -0000	1.108
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.107 2011/03/02 09:22:14 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.108 2011/03/05 19:28:21 solar Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.107 2011/03/02 09:22:14 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.108 2011/03/05 19:28:21 solar Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -290,7 +290,7 @@
 	rm_rf(fname);
 }
 
-void install_mask_pwd(int argc, char **argv, const struct stat st);
+void install_mask_pwd(int iargc, char **iargv, const struct stat st);
 void install_mask_pwd(int iargc, char **iargv, const struct stat st)
 {
 	char buf[1024];






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-03-17  2:02 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-03-17  2:02 UTC (permalink / raw
  To: gentoo-commits

vapier      11/03/17 02:02:39

  Modified:             qmerge.c
  Log:
  qmerge: delay PORTAGE_BINHOST checking to point where it is needed

Revision  Changes    Path
1.109                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.109&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.109&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.108&r2=1.109

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.108
retrieving revision 1.109
diff -u -r1.108 -r1.109
--- qmerge.c	5 Mar 2011 19:28:21 -0000	1.108
+++ qmerge.c	17 Mar 2011 02:02:39 -0000	1.109
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.108 2011/03/05 19:28:21 solar Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.109 2011/03/17 02:02:39 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.108 2011/03/05 19:28:21 solar Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.109 2011/03/17 02:02:39 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -105,6 +105,9 @@
 {
 	char buf[BUFSIZ];
 
+	if (!binhost[0])
+		errf("PORTAGE_BINHOST= does not appear to be valid");
+
 	fflush(stdout);
 	fflush(stderr);
 
@@ -164,9 +167,6 @@
 	if (pkgdir[0] != '/')
 		errf("PKGDIR='%s' does not appear to be valid", pkgdir);
 
-	if (!binhost[0])
-		errf("PORTAGE_BINHOST= does not appear to be valid");
-
 	if (!search_pkgs && !pretend) {
 		if (mkdir_p(pkgdir, 0755))
 			errp("could not setup PKGDIR: %s", pkgdir);






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-10-02 22:09 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-10-02 22:09 UTC (permalink / raw
  To: gentoo-commits

vapier      11/10/02 22:09:48

  Modified:             qmerge.c
  Log:
  fix warning with gcc-4.6+ about set-but-unused variable c

Revision  Changes    Path
1.110                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.110&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.110&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.109&r2=1.110

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.109
retrieving revision 1.110
diff -u -r1.109 -r1.110
--- qmerge.c	17 Mar 2011 02:02:39 -0000	1.109
+++ qmerge.c	2 Oct 2011 22:09:47 -0000	1.110
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.109 2011/03/17 02:02:39 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.110 2011/10/02 22:09:47 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -55,7 +55,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.109 2011/03/17 02:02:39 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.110 2011/10/02 22:09:47 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -716,8 +716,8 @@
 	char **ARGV;
 	int ARGC;
 	struct stat st;
-	char c;
 	char **iargv;
+	char c;
 	int iargc;
 
 	if (!install || !pkg || !atom)
@@ -730,9 +730,9 @@
 
 	c = qprint_tree_node(level, atom, pkg);
 
-	/* if (((c == 'R') || (c == 'D')) && update_only)
-		return;
-	*/
+	if (0)
+		if (((c == 'R') || (c == 'D')) && update_only)
+			return;
 
 	if (pkg->RDEPEND[0] && follow_rdepends) {
 		const char *rdepend;






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-12-12 20:47 Fabian Groffen (grobian)
  0 siblings, 0 replies; 39+ messages in thread
From: Fabian Groffen (grobian) @ 2011-12-12 20:47 UTC (permalink / raw
  To: gentoo-commits

grobian     11/12/12 20:47:00

  Modified:             qmerge.c
  Log:
  Fixed compilation on Darwin by solving GNUlib st_mtim problem
  
  Use GNUlib's wrappers to get st_mtim, define a workaround macro for when
  we don't use GNUlib.  (Tested on plain Gentoo Linux.)

Revision  Changes    Path
1.111                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.111&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.111&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.110&r2=1.111

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.110
retrieving revision 1.111
diff -u -r1.110 -r1.111
--- qmerge.c	2 Oct 2011 22:09:47 -0000	1.110
+++ qmerge.c	12 Dec 2011 20:47:00 -0000	1.111
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.110 2011/10/02 22:09:47 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.111 2011/12/12 20:47:00 grobian Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -11,6 +11,16 @@
 
 #include <fnmatch.h>
 #include <glob.h>
+#include <sys/stat.h>
+/* This is a GNUlib hack, because GNUlib doesn't provide st_mtim members
+ * of struct stat, but instead provides wrappers to retrieve the time
+ * fields (stat-time module). We just define a macro in case people are
+ * building without autoconf. */
+#ifdef _GL_SYS_STAT_H
+# include "stat-time.h"
+#else
+# define get_stat_mtime(X) ((X)->st_mtim)
+#endif
 
 #ifndef GLOB_BRACE
 # define GLOB_BRACE     (1 << 10)	/* Expand "{a,b}" to "a" "b".  */
@@ -55,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.110 2011/10/02 22:09:47 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.111 2011/12/12 20:47:00 grobian Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -612,8 +622,8 @@
 			}
 
 			/* Preserve the file times */
-			times[0] = st.st_mtim;
-			times[1] = st.st_mtim;
+			times[0] = get_stat_mtime(&st);
+			times[1] = get_stat_mtime(&st);
 			futimens(fd_dstf, times);
 
 			close(fd_srcf);
@@ -655,8 +665,8 @@
 			}
 
 			struct timespec times[2];
-			times[0] = st.st_mtim;
-			times[1] = st.st_mtim;
+			times[0] = get_stat_mtime(&st);
+			times[1] = get_stat_mtime(&st);
 			utimensat(subfd_dst, name, times, AT_SYMLINK_NOFOLLOW);
 		}
 






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-12-18 20:41 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-12-18 20:41 UTC (permalink / raw
  To: gentoo-commits

vapier      11/12/18 20:41:54

  Modified:             qmerge.c
  Log:
  drop unused fp argument in q_profile_walk callback

Revision  Changes    Path
1.113                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.113&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.113&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.112&r2=1.113

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.112
retrieving revision 1.113
diff -u -r1.112 -r1.113
--- qmerge.c	18 Dec 2011 20:23:34 -0000	1.112
+++ qmerge.c	18 Dec 2011 20:41:54 -0000	1.113
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.112 2011/12/18 20:23:34 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.113 2011/12/18 20:41:54 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.112 2011/12/18 20:23:34 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.113 2011/12/18 20:41:54 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1777,7 +1777,7 @@
 }
 
 _q_static void *
-qmerge_add_set_system(void *data, char *buf, FILE *fp)
+qmerge_add_set_system(void *data, char *buf)
 {
 	queue *set = data;
 	char *s;






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2011-12-19  4:58 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2011-12-19  4:58 UTC (permalink / raw
  To: gentoo-commits

vapier      11/12/19 04:58:09

  Modified:             qmerge.c
  Log:
  avoid xstrdup when qmerge fetching when possible

Revision  Changes    Path
1.115                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.115&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.115&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.114&r2=1.115

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.114
retrieving revision 1.115
diff -u -r1.114 -r1.115
--- qmerge.c	19 Dec 2011 04:23:18 -0000	1.114
+++ qmerge.c	19 Dec 2011 04:58:09 -0000	1.115
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.114 2011/12/19 04:23:18 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.115 2011/12/19 04:58:09 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.114 2011/12/19 04:23:18 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.115 2011/12/19 04:58:09 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -132,27 +132,29 @@
 		pid_t p;
 		int status;
 
-		const char *prog = (force_download || install) ? "wget" : pretend ? "echo" : "wget";
+		char prog[] = "wget";
+		char argv_c[] = "-c";
+		char argv_P[] = "-P";
+		char argv_q[] = "-q";
+		char *argv_dir = xstrdup(destdir);
 		char *argv[] = {
-			xstrdup(prog),
-			xstrdup("-c"),
-			xstrdup("-P"),
-			xstrdup(destdir),
+			prog,
+			argv_c,
+			argv_P,
+			argv_dir,
 			buf,
-			quiet ? xstrdup("-q") : NULL,
+			quiet ? argv_q : NULL,
 			NULL,
 		};
+		if (!(force_download || install) && pretend)
+			strcpy(prog, "echo");
 		snprintf(buf, sizeof(buf), "%s/%s", binhost, src);
 
 		p = vfork();
 		if (p == 0)
 			_exit(execvp(prog, argv));
 
-		free(argv[0]);
-		free(argv[1]);
-		free(argv[2]);
-		free(argv[3]);
-		free(argv[5]);
+		free(argv_dir);
 
 		waitpid(p, &status, 0);
 #if 0






^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-20  7:32 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-20  7:32 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/20 07:32:07

  Modified:             qmerge.c
  Log:
  qmerge: fix -U for the most part

Revision  Changes    Path
1.117                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.117&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.117&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.116&r2=1.117

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.116
retrieving revision 1.117
diff -u -r1.116 -r1.117
--- qmerge.c	13 Aug 2012 22:23:35 -0000	1.116
+++ qmerge.c	20 Apr 2013 07:32:07 -0000	1.117
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.116 2012/08/13 22:23:35 robbat2 Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.117 2013/04/20 07:32:07 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.116 2012/08/13 22:23:35 robbat2 Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.117 2013/04/20 07:32:07 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -210,14 +210,15 @@
 _q_static int qmerge_filter_cat(q_vdb_cat_ctx *cat_ctx, void *priv)
 {
 	struct qmerge_bv_state *state = priv;
-	return strcmp(cat_ctx->name, state->catname) == 0;
+	return !state->catname || strcmp(cat_ctx->name, state->catname) == 0;
 }
 
 _q_static int qmerge_best_version_cb(q_vdb_pkg_ctx *pkg_ctx, void *priv)
 {
 	struct qmerge_bv_state *state = priv;
 	if (qlist_match(pkg_ctx, state->buf, true))
-		strcpy(state->retbuf, state->buf);
+		snprintf(state->retbuf, sizeof(state->buf), "%s/%s",
+			pkg_ctx->cat_ctx->name, pkg_ctx->name);
 	return 0;
 }
 
@@ -230,8 +231,9 @@
 		.retbuf = retbuf,
 	};
 
-	snprintf(state.buf, sizeof(state.buf), "%s/%s", catname, pkgname);
 	retbuf[0] = '\0';
+	snprintf(state.buf, sizeof(state.buf), "%s%s%s",
+		catname ? : "", catname ? "/" : "", pkgname);
 	q_vdb_foreach_pkg(qmerge_best_version_cb, &state, qmerge_filter_cat);
 
 	return retbuf;





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-22  3:55 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-22  3:55 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/22 03:55:18

  Modified:             qmerge.c
  Log:
  qmerge: create tmpdirs before trying to use them

Revision  Changes    Path
1.119                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.119&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.119&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.118&r2=1.119

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.118
retrieving revision 1.119
diff -u -r1.118 -r1.119
--- qmerge.c	21 Apr 2013 04:28:10 -0000	1.118
+++ qmerge.c	22 Apr 2013 03:55:18 -0000	1.119
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.118 2013/04/21 04:28:10 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.119 2013/04/22 03:55:18 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.118 2013/04/21 04:28:10 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.119 2013/04/22 03:55:18 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -182,10 +182,11 @@
 	if (!search_pkgs && !pretend) {
 		if (mkdir_p(pkgdir, 0755))
 			errp("could not setup PKGDIR: %s", pkgdir);
-		mkdir_p(port_tmpdir, 0755);
 	}
 
+	mkdir_p(port_tmpdir, 0755);
 	xchdir(port_tmpdir);
+	mkdir_p("portage", 0755);
 	xchdir("portage");
 
 	if (force_download && force_download != 2)





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29  6:26 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29  6:26 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 06:26:57

  Modified:             qmerge.c
  Log:
  qmerge: check if the vdb exists before running best_version to avoid warnings when doing the first merge

Revision  Changes    Path
1.121                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.121&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.121&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.120&r2=1.121

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.120
retrieving revision 1.121
diff -u -r1.120 -r1.121
--- qmerge.c	29 Apr 2013 05:10:35 -0000	1.120
+++ qmerge.c	29 Apr 2013 06:26:57 -0000	1.121
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.120 2013/04/29 05:10:35 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.121 2013/04/29 06:26:57 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.120 2013/04/29 05:10:35 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.121 2013/04/29 06:26:57 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -225,6 +225,7 @@
 
 _q_static char *best_version(const char *catname, const char *pkgname)
 {
+	static int vdb_check = 1;
 	static char retbuf[4096];
 	struct qmerge_bv_state state = {
 		.catname = catname,
@@ -232,11 +233,28 @@
 		.retbuf = retbuf,
 	};
 
+	/* Make sure these dirs exist before we try walking them */
+	switch (vdb_check) {
+	case 1: {
+		int fd = open(portroot, O_RDONLY|O_CLOEXEC);
+		if (fd >= 0) {
+			/* skip leading slash */
+			vdb_check = faccessat(fd, portvdb + 1, X_OK, 0);
+			close(fd);
+		} else
+			vdb_check = -1;
+	}
+		if (vdb_check)
+	case -1:
+			goto done;
+	}
+
 	retbuf[0] = '\0';
 	snprintf(state.buf, sizeof(state.buf), "%s%s%s",
 		catname ? : "", catname ? "/" : "", pkgname);
 	q_vdb_foreach_pkg(qmerge_best_version_cb, &state, qmerge_filter_cat);
 
+ done:
 	return retbuf;
 }
 





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29  6:28 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29  6:28 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 06:28:22

  Modified:             qmerge.c
  Log:
  qmerge: fall back to loading the Packages file from the binpkg store when the temp one does not exist (in case we want to avoid fetching all the damn time)

Revision  Changes    Path
1.122                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.122&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.122&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.121&r2=1.122

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.121
retrieving revision 1.122
diff -u -r1.121 -r1.122
--- qmerge.c	29 Apr 2013 06:26:57 -0000	1.121
+++ qmerge.c	29 Apr 2013 06:28:21 -0000	1.122
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.121 2013/04/29 06:26:57 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.122 2013/04/29 06:28:21 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.121 2013/04/29 06:26:57 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.122 2013/04/29 06:28:21 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1467,6 +1467,26 @@
 	return 0;
 }
 
+_q_static FILE *
+open_binpkg_index(void)
+{
+	FILE *fp;
+	char buf[BUFSIZ];
+
+	snprintf(buf, sizeof(buf), "%s/portage/%s", port_tmpdir, Packages);
+	fp = fopen(buf, "r");
+	if (fp)
+		return fp;
+
+	snprintf(buf, sizeof(buf), "%s/%s", pkgdir, Packages);
+	fp = fopen(buf, "r");
+	if (fp)
+		return fp;
+
+	errp("Unable to open package file %s in %s/portage or %s",
+		Packages, port_tmpdir, pkgdir);
+}
+
 _q_static struct pkg_t *
 grab_binpkg_info(const char *name)
 {
@@ -1475,19 +1495,14 @@
 	char *p;
 	depend_atom *atom;
 
-	struct pkg_t *pkg = xmalloc(sizeof(struct pkg_t));
-	struct pkg_t *rpkg = xmalloc(sizeof(struct pkg_t));
+	struct pkg_t *pkg = xzalloc(sizeof(struct pkg_t));
+	struct pkg_t *rpkg = xzalloc(sizeof(struct pkg_t));
 
 	static char best_match[sizeof(Pkg.PF)+2+sizeof(Pkg.CATEGORY)];
 
 	best_match[0] = 0;
 
-	memset(pkg, 0, sizeof(struct pkg_t));
-	memset(rpkg, 0, sizeof(struct pkg_t));
-	snprintf(buf, sizeof(buf), "%s/portage/Packages", port_tmpdir);
-
-	if ((fp = fopen(buf, "r")) == NULL)
-		errp("Unable to open package file %s", buf);
+	fp = open_binpkg_index();
 
 	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		if (*buf == '\n') {
@@ -1588,10 +1603,7 @@
 	if (NULL == name)
 		return best_match;
 
-	snprintf(buf, sizeof(buf), "%s/portage/Packages", port_tmpdir);
-
-	if ((fp = fopen(buf, "r")) == NULL)
-		errp("Unable to open package file %s", buf);
+	fp = open_binpkg_index();
 
 	while (fgets(buf, sizeof(buf), fp) != NULL) {
 		if (*buf == '\n') {
@@ -1664,8 +1676,7 @@
 	char *buf, *p;
 	long lineno = 0;
 
-	if ((fp = fopen(Packages, "r")) == NULL)
-		errp("Unable to open package file %s", Packages);
+	fp = open_binpkg_index();
 
 	memset(&Pkg, 0, sizeof(Pkg));
 





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29  6:29 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29  6:29 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 06:29:55

  Modified:             qmerge.c
  Log:
  qmerge: clean up init logic slightly -- only run mkdir/chdir once, and avoicd access() when we know we wont be downloading anything

Revision  Changes    Path
1.123                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.123&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.123&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.122&r2=1.123

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.122
retrieving revision 1.123
diff -u -r1.122 -r1.123
--- qmerge.c	29 Apr 2013 06:28:21 -0000	1.122
+++ qmerge.c	29 Apr 2013 06:29:55 -0000	1.123
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.122 2013/04/29 06:28:21 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.123 2013/04/29 06:29:55 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.122 2013/04/29 06:28:21 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.123 2013/04/29 06:29:55 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -184,20 +184,21 @@
 			errp("could not setup PKGDIR: %s", pkgdir);
 	}
 
-	mkdir_p(port_tmpdir, 0755);
-	xchdir(port_tmpdir);
-	mkdir_p("portage", 0755);
-	xchdir("portage");
-
-	if (force_download && force_download != 2)
-		unlink(Packages);
-
-	if ((access(Packages, R_OK) != 0) && (force_download != 2)) {
-		char *tbuf = NULL;
-		xasprintf(&tbuf, "%s/portage/", port_tmpdir);
-		if (access(Packages, R_OK) != 0)
-			fetch(tbuf, Packages);
-		free(tbuf);
+	char *buf;
+	xasprintf(&buf, "%s/portage", port_tmpdir);
+	mkdir_p(buf, 0755);
+	xchdir(buf);
+
+	if (force_download != 2) {
+		if (force_download)
+			unlink(Packages);
+
+		if (access(Packages, R_OK) != 0) {
+			xasprintf(&buf, "%s/portage/", port_tmpdir);
+			if (access(Packages, R_OK) != 0)
+				fetch(buf, Packages);
+			free(buf);
+		}
 	}
 }
 





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29 16:18 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29 16:18 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 16:18:34

  Modified:             qmerge.c
  Log:
  qmerge: run pkg_setup too

Revision  Changes    Path
1.125                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.125&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.125&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.124&r2=1.125

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.124
retrieving revision 1.125
diff -u -r1.124 -r1.125
--- qmerge.c	29 Apr 2013 06:51:33 -0000	1.124
+++ qmerge.c	29 Apr 2013 16:18:34 -0000	1.125
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.124 2013/04/29 06:51:33 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.125 2013/04/29 16:18:34 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.124 2013/04/29 06:51:33 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.125 2013/04/29 16:18:34 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -881,6 +881,7 @@
 	fflush(stdout);
 
 	eat_file("vdb/DEFINED_PHASES", phases, sizeof(phases));
+	pkg_run_func("vdb", phases, "pkg_setup", D, T);
 	pkg_run_func("vdb", phases, "pkg_preinst", D, T);
 
 	/* XXX: kill this off */





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29 16:30 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29 16:30 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 16:30:22

  Modified:             qmerge.c
  Log:
  qmerge: run pkg_pretend, set MERGE_TYPE var, and add a few more helper funcs

Revision  Changes    Path
1.126                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.126&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.126&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.125&r2=1.126

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.125
retrieving revision 1.126
diff -u -r1.125 -r1.126
--- qmerge.c	29 Apr 2013 16:18:34 -0000	1.125
+++ qmerge.c	29 Apr 2013 16:30:22 -0000	1.126
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.125 2013/04/29 16:18:34 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.126 2013/04/29 16:30:22 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.125 2013/04/29 16:18:34 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.126 2013/04/29 16:30:22 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -432,13 +432,17 @@
 		"debug-print-section() { :; }\n"
 		/* Not quite right */
 		"has_version() { qlist -ICq -e '$1' >/dev/null; }\n"
+		/* best_version() */
 		"use() { useq \"$@\"; }\n"
-		"useq() { hasq $1 $USE; }\n"
+		"usex() { useq \"$1\" && echo \"${2-yes}$4\" || echo \"${3-no}$5\"; }\n"
+		"useq() { hasq \"$1\" $USE; }\n"
 		"has() { hasq \"$@\"; }\n"
 		"hasq() { local h=$1; shift; case \" $* \" in *\" $h \"*) return 0;; *) return 1;; esac; }\n"
+		"hasv() { hasq \"$@\" && echo \"$1\"; }\n"
 		"elog() { printf ' * %%b\\n' \"$*\"; }\n"
 		"einfo() { elog \"$@\"; }\n"
 		"ewarn() { elog \"$@\"; }\n"
+		"eqawarn() { elog \"QA: \"\"$@\"; }\n"
 		"eerror() { elog \"$@\"; }\n"
 		"die() { eerror \"$@\"; exit 1; }\n"
 		"ebegin() { printf ' * %%b ...' \"$*\"; }\n"
@@ -448,6 +452,7 @@
 		/* Load the main env */
 		". '%1$s/environment'\n"
 		/* Reload env vars that matter to us */
+		"MERGE_TYPE=binary\n"
 		"ROOT='%4$s'\n"
 		"EROOT=\"${EPREFIX%%/}/${ROOT#/}\"\n"
 		"D='%5$s'\n"
@@ -881,6 +886,7 @@
 	fflush(stdout);
 
 	eat_file("vdb/DEFINED_PHASES", phases, sizeof(phases));
+	pkg_run_func("vdb", phases, "pkg_pretend", D, T);
 	pkg_run_func("vdb", phases, "pkg_setup", D, T);
 	pkg_run_func("vdb", phases, "pkg_preinst", D, T);
 





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-29 23:03 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-29 23:03 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/29 23:03:31

  Modified:             qmerge.c
  Log:
  qmerge: create $ROOT when merging if it does not yet exist, and check the return value of merge_tree()

Revision  Changes    Path
1.127                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.127&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.127&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.126&r2=1.127

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.126
retrieving revision 1.127
diff -u -r1.126 -r1.127
--- qmerge.c	29 Apr 2013 16:30:22 -0000	1.126
+++ qmerge.c	29 Apr 2013 23:03:31 -0000	1.127
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.126 2013/04/29 16:30:22 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.127 2013/04/29 23:03:31 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.126 2013/04/29 16:30:22 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.127 2013/04/29 23:03:31 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -854,17 +854,18 @@
 		return;
 
 	/* Set up our temp dir to unpack this stuff */
-	xasprintf(&p, "%s/qmerge/%s", port_tmpdir, pkg->PF);
+	xasprintf(&p, "%s/qmerge/%s/%s", port_tmpdir, pkg->CATEGORY, pkg->PF);
 	mkdir_p(p, 0755);
 	xchdir(p);
+	xasprintf(&D, "%s/image", p);
+	xasprintf(&T, "%s/temp", p);
 	free(p);
 
 	/* Doesn't actually remove $PWD, just everything under it */
 	rm_rf(".");
 
-	xasprintf(&D, "%s/qmerge/%s/image", port_tmpdir, pkg->PF);
-	xasprintf(&T, "%s/qmerge/%s/temp", port_tmpdir, pkg->PF);
 	mkdir("temp", 0755);
+	mkdir_p(portroot, 0755);
 
 	/* XXX: maybe some day we should have this step operate on the
 	 *      tarball directly rather than unpacking it first. */
@@ -915,7 +916,8 @@
 	if ((contents = fopen("vdb/CONTENTS", "w")) == NULL)
 		errf("come on wtf?");
 	objs = NULL;
-	merge_tree("image", portroot, contents, &objs, iargc, iargv);
+	if (merge_tree("image", portroot, contents, &objs, iargc, iargv))
+		errp("failed to merge to %s", portroot);
 	fclose(contents);
 
 	freeargv(iargc, iargv);





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-04-30  1:50 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-04-30  1:50 UTC (permalink / raw
  To: gentoo-commits

vapier      13/04/30 01:50:20

  Modified:             qmerge.c
  Log:
  qmerge: add support for FEATURES=config-protect-if-modified when unmerging

Revision  Changes    Path
1.128                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.128&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.128&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.127&r2=1.128

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.127
retrieving revision 1.128
diff -u -r1.127 -r1.128
--- qmerge.c	29 Apr 2013 23:03:31 -0000	1.127
+++ qmerge.c	30 Apr 2013 01:50:20 -0000	1.128
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.127 2013/04/29 23:03:31 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.128 2013/04/30 01:50:20 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.127 2013/04/29 23:03:31 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.128 2013/04/30 01:50:20 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1078,6 +1078,8 @@
 	makeargv(config_protect, &cp_argc, &cp_argv);
 	makeargv(config_protect_mask, &cpm_argc, &cpm_argv);
 
+	bool unmerge_config_protected = !!strstr(features, "config-protect-if-modified");
+
 	while (getline(&buf, &buflen, fp) != -1) {
 		queue *q;
 		contents_entry *e;
@@ -1097,17 +1099,21 @@
 
 		/* Should we remove in order symlinks,objects,dirs ? */
 		switch (e->type) {
-			case CONTENTS_DIR:
-				if (!protected) {
-					/* since the dir contains files, we remove it later */
-					llist_char *list = xmalloc(sizeof(llist_char));
-					list->data = xstrdup(e->name);
-					list->next = dirs;
-					dirs = list;
-				}
+			case CONTENTS_DIR: {
+				/* since the dir contains files, we remove it later */
+				llist_char *list = xmalloc(sizeof(llist_char));
+				list->data = xstrdup(e->name);
+				list->next = dirs;
+				dirs = list;
 				continue;
+			}
 
 			case CONTENTS_OBJ:
+				if (protected && unmerge_config_protected) {
+					/* If the file wasn't modified, unmerge it */
+					unsigned char *hash = hash_file_at(portroot_fd, e->name + 1, HASH_MD5);
+					protected = strcmp(e->digest, (const char *)hash);
+				}
 				break;
 
 			case CONTENTS_SYM:





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-05-03 22:28 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-05-03 22:28 UTC (permalink / raw
  To: gentoo-commits

vapier      13/05/03 22:28:48

  Modified:             qmerge.c
  Log:
  qmerge: drop QMERGE check when unmerging as it should be stable now

Revision  Changes    Path
1.129                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.129&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.129&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.128&r2=1.129

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.128
retrieving revision 1.129
diff -u -r1.128 -r1.129
--- qmerge.c	30 Apr 2013 01:50:20 -0000	1.128
+++ qmerge.c	3 May 2013 22:28:48 -0000	1.129
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.128 2013/04/30 01:50:20 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.129 2013/05/03 22:28:48 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.128 2013/04/30 01:50:20 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.129 2013/05/03 22:28:48 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1923,9 +1923,8 @@
 	qmerge_strict = (strstr("strict", features) == 0) ? 1 : 0;
 
 	/* Short circut this. */
-	if ((install || uninstall) && !pretend) {
+	if (install && !pretend) {
 		if (follow_rdepends && getenv("QMERGE") == NULL) {
-			uninstall = 0;
 			install = 0;
 			warn("Using these options are likely to break your system at this point. export QMERGE=1; if you think you know what your doing.");
 		}





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2013-05-09  5:28 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2013-05-09  5:28 UTC (permalink / raw
  To: gentoo-commits

vapier      13/05/09 05:28:11

  Modified:             qmerge.c
  Log:
  qmerge: change output when removing unmodified config files to <<< rather than ***
  
  also abort if unlinking failed such as trying to remove a file but lack perms (e.g. non-root when ROOT=/)

Revision  Changes    Path
1.130                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.130&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.130&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.129&r2=1.130

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.129
retrieving revision 1.130
diff -u -r1.129 -r1.130
--- qmerge.c	3 May 2013 22:28:48 -0000	1.129
+++ qmerge.c	9 May 2013 05:28:11 -0000	1.130
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.129 2013/05/03 22:28:48 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.130 2013/05/09 05:28:11 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.129 2013/05/03 22:28:48 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.130 2013/05/09 05:28:11 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1092,7 +1092,6 @@
 			continue;
 
 		protected = config_protected(e->name, cp_argc, cp_argv, cpm_argc, cpm_argv);
-		snprintf(zing, sizeof(zing), "%s%s%s", protected ? YELLOW : GREEN, protected ? "***" : "<<<" , NORM);
 
 		/* This should never happen ... */
 		assert(e->name[0] == '/' && e->name[1] != '/');
@@ -1133,6 +1132,8 @@
 				continue;
 		}
 
+		snprintf(zing, sizeof(zing), "%s%s%s", protected ? YELLOW : GREEN, protected ? "***" : "<<<" , NORM);
+
 		if (protected) {
 			qprintf("%s %s\n", zing, e->name);
 			continue;
@@ -1156,7 +1157,8 @@
 		if (!keep || q) {
 			char *p;
 
-			unlinkat(portroot_fd, e->name + 1, 0);
+			if (unlinkat(portroot_fd, e->name + 1, 0))
+				errp("could not unlink: %s%s", portroot, e->name + 1);
 
 			p = strrchr(e->name, '/');
 			if (p) {





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-01-07 19:17 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-01-07 19:17 UTC (permalink / raw
  To: gentoo-commits

vapier      14/01/07 19:17:25

  Modified:             qmerge.c
  Log:
  qmerge: ignore unmerge errors due to missing files in case someone already did `rm` on it

Revision  Changes    Path
1.131                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.131&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.131&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.130&r2=1.131

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.130
retrieving revision 1.131
diff -u -r1.130 -r1.131
--- qmerge.c	9 May 2013 05:28:11 -0000	1.130
+++ qmerge.c	7 Jan 2014 19:17:25 -0000	1.131
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.130 2013/05/09 05:28:11 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.131 2014/01/07 19:17:25 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.130 2013/05/09 05:28:11 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.131 2014/01/07 19:17:25 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1157,8 +1157,11 @@
 		if (!keep || q) {
 			char *p;
 
-			if (unlinkat(portroot_fd, e->name + 1, 0))
-				errp("could not unlink: %s%s", portroot, e->name + 1);
+			if (unlinkat(portroot_fd, e->name + 1, 0)) {
+				/* If a file was already deleted, ignore the error */
+				if (errno != ENOENT)
+					errp("could not unlink: %s%s", portroot, e->name + 1);
+			}
 
 			p = strrchr(e->name, '/');
 			if (p) {





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-17  6:32 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-17  6:32 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/17 06:32:33

  Modified:             qmerge.c
  Log:
  qmerge: do not require PORTAGE_BINHOST all the time
  
  perfectly reasonable to only install local binpkgs

Revision  Changes    Path
1.133                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.133&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.133&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.132&r2=1.133

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.132
retrieving revision 1.133
diff -u -r1.132 -r1.133
--- qmerge.c	16 Feb 2014 21:14:24 -0000	1.132
+++ qmerge.c	17 Feb 2014 06:32:33 -0000	1.133
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.132 2014/02/16 21:14:24 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.133 2014/02/17 06:32:33 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.132 2014/02/16 21:14:24 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.133 2014/02/17 06:32:33 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -113,16 +113,15 @@
 
 _q_static void fetch(const char *destdir, const char *src)
 {
-	char buf[BUFSIZ];
-
 	if (!binhost[0])
-		errf("PORTAGE_BINHOST= does not appear to be valid");
+		return;
 
 	fflush(stdout);
 	fflush(stderr);
 
 #if 0
 	if (getenv("FETCHCOMMAND") != NULL) {
+		char buf[BUFSIZ];
 		snprintf(buf, sizeof(buf), "(export DISTDIR='%s' URI='%s/%s'; %s)",
 			destdir, binhost, src, getenv("FETCHCOMMAND"));
 		xsystem(buf);
@@ -131,6 +130,7 @@
 	{
 		pid_t p;
 		int status;
+		char *path;
 
 		char prog[] = "wget";
 		char argv_c[] = "-c";
@@ -142,18 +142,23 @@
 			argv_c,
 			argv_P,
 			argv_dir,
-			buf,
+			path,
 			quiet ? argv_q : NULL,
 			NULL,
 		};
 		if (!(force_download || install) && pretend)
 			strcpy(prog, "echo");
-		snprintf(buf, sizeof(buf), "%s/%s", binhost, src);
+		xasprintf(&path, "%s/%s", binhost, src);
 
 		p = vfork();
-		if (p == 0)
+		switch (p) {
+		case 0:
 			_exit(execvp(prog, argv));
+		case -1:
+			errp("vfork failed");
+		}
 
+		free(path);
 		free(argv_dir);
 
 		waitpid(p, &status, 0);





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-18  4:32 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-18  4:32 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/18 04:32:52

  Modified:             qmerge.c
  Log:
  qmerge: fix path use -- assign it to argv after we init it

Revision  Changes    Path
1.134                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.134&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.134&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.133&r2=1.134

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.133
retrieving revision 1.134
diff -u -r1.133 -r1.134
--- qmerge.c	17 Feb 2014 06:32:33 -0000	1.133
+++ qmerge.c	18 Feb 2014 04:32:52 -0000	1.134
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.133 2014/02/17 06:32:33 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.134 2014/02/18 04:32:52 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.133 2014/02/17 06:32:33 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.134 2014/02/18 04:32:52 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -132,6 +132,8 @@
 		int status;
 		char *path;
 
+		xasprintf(&path, "%s/%s", binhost, src);
+
 		char prog[] = "wget";
 		char argv_c[] = "-c";
 		char argv_P[] = "-P";
@@ -148,7 +150,6 @@
 		};
 		if (!(force_download || install) && pretend)
 			strcpy(prog, "echo");
-		xasprintf(&path, "%s/%s", binhost, src);
 
 		p = vfork();
 		switch (p) {





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-18  6:57 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-18  6:57 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/18 06:57:41

  Modified:             qmerge.c
  Log:
  qmerge: fix has_version definition -- qlist always exits 0, but writes updates to stdout

Revision  Changes    Path
1.135                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.135&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.135&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.134&r2=1.135

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.134
retrieving revision 1.135
diff -u -r1.134 -r1.135
--- qmerge.c	18 Feb 2014 04:32:52 -0000	1.134
+++ qmerge.c	18 Feb 2014 06:57:41 -0000	1.135
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.134 2014/02/18 04:32:52 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.135 2014/02/18 06:57:41 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.134 2014/02/18 04:32:52 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.135 2014/02/18 06:57:41 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -437,7 +437,7 @@
 		"debug-print-function() { :; }\n"
 		"debug-print-section() { :; }\n"
 		/* Not quite right */
-		"has_version() { qlist -ICq -e '$1' >/dev/null; }\n"
+		"has_version() { [ -n \"$(qlist -ICqe \"$1\")\" ]; }\n"
 		/* best_version() */
 		"use() { useq \"$@\"; }\n"
 		"usex() { useq \"$1\" && echo \"${2-yes}$4\" || echo \"${3-no}$5\"; }\n"





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-18  6:58 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-18  6:58 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/18 06:58:13

  Modified:             qmerge.c
  Log:
  qmerge: add emake/FILESDIR definitions
  
  for now, we disable FILESDIR on the assumption there is no PORTDIR anywhere

Revision  Changes    Path
1.136                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.136&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.136&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.135&r2=1.136

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.135
retrieving revision 1.136
diff -u -r1.135 -r1.136
--- qmerge.c	18 Feb 2014 06:57:41 -0000	1.135
+++ qmerge.c	18 Feb 2014 06:58:13 -0000	1.136
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.135 2014/02/18 06:57:41 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.136 2014/02/18 06:58:13 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.135 2014/02/18 06:57:41 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.136 2014/02/18 06:58:13 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -453,11 +453,13 @@
 		"die() { eerror \"$@\"; exit 1; }\n"
 		"ebegin() { printf ' * %%b ...' \"$*\"; }\n"
 		"eend() { local r=${1:-$?}; [ $# -gt 0 ] && shift; [ $r -eq 0 ] && echo ' [ ok ]' || echo \" $* \"'[ !! ]'; return $r; }\n"
+		"emake() { ${MAKE:-make} ${MAKEOPTS} \"$@\"; }\n"
 		/* Unpack the env if need be */
 		"[ -e '%1$s/environment' ] || { bzip2 -dc '%1$s/environment.bz2' > '%1$s/environment' || exit 1; }\n"
 		/* Load the main env */
 		". '%1$s/environment'\n"
 		/* Reload env vars that matter to us */
+		"FILESDIR=/.does/not/exist/anywhere\n"
 		"MERGE_TYPE=binary\n"
 		"ROOT='%4$s'\n"
 		"EROOT=\"${EPREFIX%%/}/${ROOT#/}\"\n"





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-18  6:58 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-18  6:58 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/18 06:58:45

  Modified:             qmerge.c
  Log:
  qmerge: auto fix local Packages files via `emaint binhost --fix`

Revision  Changes    Path
1.137                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.137&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.137&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.136&r2=1.137

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.136
retrieving revision 1.137
diff -u -r1.136 -r1.137
--- qmerge.c	18 Feb 2014 06:58:13 -0000	1.136
+++ qmerge.c	18 Feb 2014 06:58:45 -0000	1.137
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.136 2014/02/18 06:58:13 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.137 2014/02/18 06:58:45 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -65,7 +65,7 @@
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.136 2014/02/18 06:58:13 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.137 2014/02/18 06:58:45 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -1378,7 +1378,7 @@
 	}
 	if (access(buf, R_OK) == 0) {
 		if (!pkg->SHA1[0] && !pkg->MD5[0]) {
-			warn("No checksum data for %s", buf);
+			warn("No checksum data for %s (try `emaint binhost --fix`)", buf);
 			return;
 		} else {
 			if (pkg_verify_checksums(buf, pkg, atom, qmerge_strict, !quiet) == 0) {
@@ -1520,20 +1520,51 @@
 open_binpkg_index(void)
 {
 	FILE *fp;
-	char buf[BUFSIZ];
+	char *path;
 
-	snprintf(buf, sizeof(buf), "%s/portage/%s", port_tmpdir, Packages);
-	fp = fopen(buf, "r");
+	xasprintf(&path, "%s/portage/%s", port_tmpdir, Packages);
+	fp = fopen(path, "r");
 	if (fp)
-		return fp;
+		goto done;
+	free(path);
 
-	snprintf(buf, sizeof(buf), "%s/%s", pkgdir, Packages);
-	fp = fopen(buf, "r");
+	xasprintf(&path, "%s/%s", pkgdir, Packages);
+	fp = fopen(path, "r");
 	if (fp)
-		return fp;
+		goto done;
 
-	errp("Unable to open package file %s in %s/portage or %s",
+	/* This is normal when installing from local repo only. */
+	warnp("Unable to open package file %s in %s/portage or %s",
 		Packages, port_tmpdir, pkgdir);
+	warn("Attempting to manually regen via `emaint binhost`");
+
+	pid_t p;
+	int status;
+
+	char argv_emaint[] = "emaint";
+	char argv_binhost[] = "binhost";
+	char argv_fix[] = "--fix";
+	char *argv[] = {
+		argv_emaint,
+		argv_binhost,
+		argv_fix,
+		NULL,
+	};
+
+	p = vfork();
+	switch (p) {
+	case 0:
+		_exit(execvp(argv[0], argv));
+	case -1:
+		errp("vfork failed");
+	}
+	waitpid(p, &status, 0);
+
+	fp = fopen(path, "r");
+
+ done:
+	free(path);
+	return fp;
 }
 
 _q_static struct pkg_t *
@@ -1812,7 +1843,7 @@
 	free(buf);
 	fclose(fp);
 
-	return 0;
+	return EXIT_SUCCESS;
 }
 
 _q_static queue *





^ permalink raw reply	[flat|nested] 39+ messages in thread

* [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c
@ 2014-02-18  6:59 Mike Frysinger (vapier)
  0 siblings, 0 replies; 39+ messages in thread
From: Mike Frysinger (vapier) @ 2014-02-18  6:59 UTC (permalink / raw
  To: gentoo-commits

vapier      14/02/18 06:59:05

  Modified:             qmerge.c
  Log:
  qmerge: add --debug option for auto running shell through `set -x`

Revision  Changes    Path
1.138                portage-utils/qmerge.c

file : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.138&view=markup
plain: http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?rev=1.138&content-type=text/plain
diff : http://sources.gentoo.org/viewvc.cgi/gentoo-projects/portage-utils/qmerge.c?r1=1.137&r2=1.138

Index: qmerge.c
===================================================================
RCS file: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v
retrieving revision 1.137
retrieving revision 1.138
diff -u -r1.137 -r1.138
--- qmerge.c	18 Feb 2014 06:58:45 -0000	1.137
+++ qmerge.c	18 Feb 2014 06:59:05 -0000	1.138
@@ -1,7 +1,7 @@
 /*
  * Copyright 2005-2010 Gentoo Foundation
  * Distributed under the terms of the GNU General Public License v2
- * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.137 2014/02/18 06:58:45 vapier Exp $
+ * $Header: /var/cvsroot/gentoo-projects/portage-utils/qmerge.c,v 1.138 2014/02/18 06:59:05 vapier Exp $
  *
  * Copyright 2005-2010 Ned Ludd        - <solar@gentoo.org>
  * Copyright 2005-2010 Mike Frysinger  - <vapier@gentoo.org>
@@ -48,6 +48,7 @@
 	{"yes",     no_argument, NULL, 'y'},
 	{"nodeps",  no_argument, NULL, 'O'},
 	{"nomd5",   no_argument, NULL, '5'},
+	{"debug",   no_argument, NULL, 128},
 	COMMON_LONG_OPTS
 };
 
@@ -62,10 +63,11 @@
 	"Don't prompt before overwriting",
 	"Don't merge dependencies",
 	"Don't verify MD5 digest of files",
+	"Run shell funcs with `set -x`",
 	COMMON_OPTS_HELP
 };
 
-static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.137 2014/02/18 06:58:45 vapier Exp $";
+static const char qmerge_rcsid[] = "$Id: qmerge.c,v 1.138 2014/02/18 06:59:05 vapier Exp $";
 #define qmerge_usage(ret) usage(ret, QMERGE_FLAGS, qmerge_long_opts, qmerge_opts_help, lookup_applet_idx("qmerge"))
 
 char search_pkgs = 0;
@@ -77,6 +79,7 @@
 char nomd5 = 0;
 char qmerge_strict = 0;
 char update_only = 0;
+bool debug = false;
 const char Packages[] = "Packages";
 
 /*
@@ -467,10 +470,16 @@
 		"ED=\"${EPREFIX%%/}/${D#/}\"\n"
 		"T='%6$s'\n"
 		/* Finally run the func */
-		"%2$s\n"
+		"%7$s%2$s\n"
 		/* Ignore func return values (not exit values) */
 		":",
-		vdb_path, func, phase, portroot, D, T);
+		/*1*/ vdb_path,
+		/*2*/ func,
+		/*3*/ phase,
+		/*4*/ portroot,
+		/*5*/ D,
+		/*6*/ T,
+		/*7*/ debug ? "set -x;" : "");
 	xsystembash(script);
 	free(script);
 }
@@ -1961,6 +1970,7 @@
 			case 'y': interactive = 0; break;
 			case 'O': follow_rdepends = 0; break;
 			case '5': nomd5 = 1; break;
+			case 128: debug = true; break;
 			COMMON_GETOPTS_CASES(qmerge)
 		}
 	}





^ permalink raw reply	[flat|nested] 39+ messages in thread

end of thread, other threads:[~2014-02-18  6:59 UTC | newest]

Thread overview: 39+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-01-13 19:15 [gentoo-commits] gentoo-projects commit in portage-utils: qmerge.c Mike Frysinger (vapier)
  -- strict thread matches above, loose matches on Subject: below --
2014-02-18  6:59 Mike Frysinger (vapier)
2014-02-18  6:58 Mike Frysinger (vapier)
2014-02-18  6:58 Mike Frysinger (vapier)
2014-02-18  6:57 Mike Frysinger (vapier)
2014-02-18  4:32 Mike Frysinger (vapier)
2014-02-17  6:32 Mike Frysinger (vapier)
2014-01-07 19:17 Mike Frysinger (vapier)
2013-05-09  5:28 Mike Frysinger (vapier)
2013-05-03 22:28 Mike Frysinger (vapier)
2013-04-30  1:50 Mike Frysinger (vapier)
2013-04-29 23:03 Mike Frysinger (vapier)
2013-04-29 16:30 Mike Frysinger (vapier)
2013-04-29 16:18 Mike Frysinger (vapier)
2013-04-29  6:29 Mike Frysinger (vapier)
2013-04-29  6:28 Mike Frysinger (vapier)
2013-04-29  6:26 Mike Frysinger (vapier)
2013-04-22  3:55 Mike Frysinger (vapier)
2013-04-20  7:32 Mike Frysinger (vapier)
2011-12-19  4:58 Mike Frysinger (vapier)
2011-12-18 20:41 Mike Frysinger (vapier)
2011-12-12 20:47 Fabian Groffen (grobian)
2011-10-02 22:09 Mike Frysinger (vapier)
2011-03-17  2:02 Mike Frysinger (vapier)
2011-03-05 19:28 Ned Ludd (solar)
2011-03-02  9:22 Mike Frysinger (vapier)
2011-03-02  3:51 Ned Ludd (solar)
2011-02-24  1:29 Mike Frysinger (vapier)
2011-02-22  6:10 Mike Frysinger (vapier)
2011-02-21 22:02 Mike Frysinger (vapier)
2011-02-21  1:52 Mike Frysinger (vapier)
2010-06-08  4:52 Mike Frysinger (vapier)
2010-01-18  6:30 Ned Ludd (solar)
2010-01-13  6:14 Ned Ludd (solar)
2009-05-03 17:19 Ned Ludd (solar)
2009-04-17 14:44 Ned Ludd (solar)
2009-03-21  6:37 Ned Ludd (solar)
2008-05-10 20:21 Diego Petteno (flameeyes)
2007-10-24 16:50 Ned Ludd (solar)

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox