summaryrefslogtreecommitdiff
path: root/app-portage/portage-utils/files
diff options
context:
space:
mode:
authorV3n3RiX <venerix@redcorelinux.org>2019-05-18 00:10:51 +0100
committerV3n3RiX <venerix@redcorelinux.org>2019-05-18 00:10:51 +0100
commiteccb70a7f91b2d22582587f26d1a28bb31408b45 (patch)
tree3223e1fd54201bcf4ebecac6fbe87361cbe643e2 /app-portage/portage-utils/files
parenta2810985afabcc31d3eace5e61d8ea25b852ba17 (diff)
gentoo resync : 18.05.2019
Diffstat (limited to 'app-portage/portage-utils/files')
-rw-r--r--app-portage/portage-utils/files/portage-utils-0.74-qdepends-Q-regex.patch96
1 files changed, 96 insertions, 0 deletions
diff --git a/app-portage/portage-utils/files/portage-utils-0.74-qdepends-Q-regex.patch b/app-portage/portage-utils/files/portage-utils-0.74-qdepends-Q-regex.patch
new file mode 100644
index 000000000000..6d10161d704e
--- /dev/null
+++ b/app-portage/portage-utils/files/portage-utils-0.74-qdepends-Q-regex.patch
@@ -0,0 +1,96 @@
+qdepends: restore regex matching capabilities for reverse dependencies
+
+The use of atom matching unintendedly removed the ability to use
+regexes, which broke app-admin/gentoo-perl-helpers. This patch removes
+the atom matching, and reverts to using regex matching always to restore
+behaviour.
+
+Bug: https://bugs.gentoo.org/683430
+
+--- a/qdepends.c
++++ b/qdepends.c
+@@ -483,11 +483,9 @@
+ int ret;
+ regex_t preg;
+ regmatch_t match;
+- depend_atom *aq;
+ depend_atom *as;
+ depend_atom *ac;
+ char firstmatch = 0;
+- char *sslot;
+
+ if (!q_vdb_pkg_eat(pkg_ctx, state->depend_file, &depend, &depend_len))
+ return 0;
+@@ -526,34 +524,17 @@
+ return 1;
+ }
+
+- aq = atom_explode(state->query);
+- if (!aq) {
+- /* "fall" back to old behaviour of just performing an extended
+- * regular expression match */
+- if (wregcomp(&preg, state->query, REG_EXTENDED) != 0) {
+- dep_burn_tree(dep_tree);
+- return 1;
+- }
++ /* fallback for old behaviour of just performing an extended
++ * regular expression match */
++ if (wregcomp(&preg, state->query, REG_EXTENDED) != 0) {
++ dep_burn_tree(dep_tree);
++ return 1;
+ }
+
+ match.rm_eo = 0;
+ firstmatch = 1;
+ do { /* find all matches */
+- if (!aq) {
+- ret = regexec(&preg, ptr + match.rm_eo, 1, &match, 0);
+- } else {
+- char *loc;
+- ret = -1;
+- snprintf(qbuf, sizeof(qbuf), "%s%s%s",
+- aq->CATEGORY ? aq->CATEGORY : "",
+- aq->CATEGORY ? "/" : "",
+- aq->PN);
+- if ((loc = strstr(ptr + match.rm_eo, qbuf)) != NULL) {
+- ret = 0;
+- match.rm_so = loc - ptr;
+- match.rm_eo = match.rm_so + strlen(qbuf);
+- }
+- }
++ ret = regexec(&preg, ptr + match.rm_eo, 1, &match, 0);
+ if (ret != 0)
+ break;
+
+@@ -571,18 +552,6 @@
+ ptr + match.rm_so);
+ ac = atom_explode(qbuf);
+
+- /* drop SLOT when not present in aq so we can match atoms
+- * regardless */
+- sslot = ac->SLOT;
+- if (aq->SLOT == NULL && ac->SLOT != NULL)
+- ac->SLOT = NULL;
+- ret = atom_compare(ac, aq);
+- ac->SLOT = sslot;
+- if (ret != EQUAL) {
+- atom_implode(ac);
+- break;
+- }
+-
+ if (firstmatch == 1) {
+ firstmatch = 0;
+ printf("%s%s/%s%s%s%c", BOLD, catname, BLUE,
+@@ -615,11 +584,7 @@
+ if (verbose && firstmatch == 0)
+ printf("\n");
+
+- if (!aq) {
+- regfree(&preg);
+- } else {
+- atom_implode(aq);
+- }
++ regfree(&preg);
+ atom_implode(as);
+ dep_burn_tree(dep_tree);
+