Frage

Jedes Mal, wenn ich eine Teilmenge eines Pflasters nehmen wollen, bin ich gezwungen, ein Skript zu schreiben, um nur die Indizes zu extrahieren, die ich will.

z. Ich habe einen Patch, der auf Unterverzeichnisse gilt 'Yay' und 'foo'.

Gibt es eine Möglichkeit, einen neuen Patch zu erstellen oder nur eine Teilmenge eines Patch anwenden? das heißt einen neuen Patch aus dem vorhandenen Patch erstellen, die nur alle Indizes nimmt, die unter Unterverzeichnis ‚yay‘ sind. Oder alle Indizes, die nicht unter Unterverzeichnis ‚foo‘

sind

Wenn ich ein Patch wie (entschuldigen Sie die unten pseudo-Patch):

Index : foo/bar
 yada
 yada
- asdf
+ jkl
 yada
 yada
Index : foo/bah
 blah
 blah
- 28
+ 29
 blah
 blah
 blah
Index : yay/team
 go
 huskies
- happy happy
+ joy joy
 cougars
 suck

Wie kann ich nur das ‚yay‘ Unterverzeichnis extrahieren oder anwenden wie:

Index : yay/team
 go
 huskies
- happy happy
+ joy joy
 cougars
 suck

Ich weiß, wenn ich Skript eine Lösung bis ich neu zu erfinden das Rad würde ...

War es hilfreich?

Lösung

Werfen Sie einen Blick auf die filterdiff Dienstprogramm, das Teil der patchutils ist.

Zum Beispiel, wenn Sie den folgenden Patch haben:

$ cat example.patch
diff -Naur orig/a/bar new/a/bar
--- orig/a/bar  2009-12-02 12:41:38.353745751 -0800
+++ new/a/bar   2009-12-02 12:42:17.845745951 -0800
@@ -1,3 +1,3 @@
 4
-5
+e
 6
diff -Naur orig/a/foo new/a/foo
--- orig/a/foo  2009-12-02 12:41:32.845745768 -0800
+++ new/a/foo   2009-12-02 12:42:25.697995617 -0800
@@ -1,3 +1,3 @@
 1
 2
-3
+c
diff -Naur orig/b/baz new/b/baz
--- orig/b/baz  2009-12-02 12:41:42.993745756 -0800
+++ new/b/baz   2009-12-02 12:42:37.585745735 -0800
@@ -1,3 +1,3 @@
-7
+z
 8
 9

Dann können Sie den folgenden Befehl ausführen, den Patch für nur Dinge im a Verzeichnis wie folgt zu extrahieren:

$ cat example.patch | filterdiff -i 'new/a/*'
--- orig/a/bar  2009-12-02 12:41:38.353745751 -0800
+++ new/a/bar   2009-12-02 12:42:17.845745951 -0800
@@ -1,3 +1,3 @@
 4
-5
+e
 6
--- orig/a/foo  2009-12-02 12:41:32.845745768 -0800
+++ new/a/foo   2009-12-02 12:42:25.697995617 -0800
@@ -1,3 +1,3 @@
 1
 2
-3
+c

Andere Tipps

Hier ist meine schnelle und schmutzige Perl-Lösung.

perl -ne '@a = split /^Index :/m, join "", <>; END { for(@a) {print "Index :", $_ if (m, yay/team,)}}' < foo.patch

Als Reaktion auf sigjuice Antrag in den Kommentaren, ich bin Entsendung meiner Skript Lösung. Es ist nicht zu 100% kugelsicher, und ich werde wahrscheinlich filterdiff stattdessen verwenden.

base_usage_str=r'''
    python %prog index_regex patch_file

description:
    Extracts all indices from a patch-file matching 'index_regex'

    e.g.
        python %prog '^evc_lib' p.patch > evc_lib_p.patch

        Will extract all indices which begin with evc_lib.

        -or-

        python %prog '^(?!evc_lib)' p.patch > not_evc_lib_p.patch

        Will extract all indices which do *not* begin with evc_lib.

authors:
    Ross Rogers, 2009.04.02
'''

import re,os,sys
from optparse import OptionParser

def main():

    parser = OptionParser(usage=base_usage_str)

    (options, args) = parser.parse_args(args=sys.argv[1:])

    if len(args) != 2:
        parser.print_help()
        if len(args) == 0:
            sys.exit(0)
        else:
            sys.exit(1)

    (index_regex,patch_file) = args
    sys.stderr.write('Extracting patches for indices found by regex:%s\n'%index_regex)
    #print 'user_regex',index_regex
    user_index_match_regex = re.compile(index_regex)

    # Index: verification/ring_td_cte/tests/mmio_wr_td_target.e
    # --- sw/cfg/foo.xml      2009-04-30 17:59:11 -07:00
    # +++ sw/cfg/foo.xml      2009-05-11 09:26:58 -07:00

    index_cre = re.compile(r'''(?:(?<=^)|(?<=\n))(--- (?:.*\n){2,}?(?![ @\+\-]))''')

    patch_file = open(patch_file,'r')
    all_patch_sets = index_cre.findall(patch_file.read())
    patch_file.close()

    for file_edit in all_patch_sets:
        # extract index subset
        index_path = re.compile('\+\+\+ (?P<index>[\w_\-/\.]+)').search(file_edit).group('index').strip()
        if user_index_match_regex.search(index_path):
            sys.stderr.write("Index regex matched index: "+index_path+"\n")
            print file_edit,


if __name__ == '__main__':
    main()
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top