diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2019-08-20 18:01:57 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2019-08-20 18:01:57 +0000 | 
| commit | 88c643b6fec27eec436c8d138fee6346e92337d6 (patch) | |
| tree | 82cd13b2f3cde1c9e5f79689ba4e6ba67694843f /utils/misc/grep-svn-log.py | |
| parent | 94994d372d014ce4c8758b9605d63fae651bd8aa (diff) | |
Notes
Diffstat (limited to 'utils/misc/grep-svn-log.py')
| -rwxr-xr-x | utils/misc/grep-svn-log.py | 96 | 
1 files changed, 0 insertions, 96 deletions
| diff --git a/utils/misc/grep-svn-log.py b/utils/misc/grep-svn-log.py deleted file mode 100755 index 86cc3ef1742f..000000000000 --- a/utils/misc/grep-svn-log.py +++ /dev/null @@ -1,96 +0,0 @@ -#!/usr/bin/env python - -""" -Greps and returns the first svn log entry containing a line matching the regular -expression pattern passed as the only arg. - -Example: - -svn log -v | grep-svn-log.py '^   D.+why_are_you_missing.h$' -""" - -import fileinput -import re -import sys -import StringIO - -# Separator string for "svn log -v" output. -separator = '-' * 72 - -usage = """Usage: grep-svn-log.py line-pattern -Example: -    svn log -v | grep-svn-log.py '^   D.+why_are_you_missing.h'""" - - -class Log(StringIO.StringIO): -    """Simple facade to keep track of the log content.""" - -    def __init__(self): -        self.reset() - -    def add_line(self, a_line): -        """Add a line to the content, if there is a previous line, commit it.""" -        global separator -        if self.prev_line is not None: -            print >> self, self.prev_line -        self.prev_line = a_line -        self.separator_added = (a_line == separator) - -    def del_line(self): -        """Forget about the previous line, do not commit it.""" -        self.prev_line = None - -    def reset(self): -        """Forget about the previous lines entered.""" -        StringIO.StringIO.__init__(self) -        self.prev_line = None - -    def finish(self): -        """Call this when you're finished with populating content.""" -        if self.prev_line is not None: -            print >> self, self.prev_line -        self.prev_line = None - - -def grep(regexp): -    # The log content to be written out once a match is found. -    log = Log() - -    LOOKING_FOR_MATCH = 0 -    FOUND_LINE_MATCH = 1 -    state = LOOKING_FOR_MATCH - -    while True: -        line = sys.stdin.readline() -        if not line: -            return -        line = line.splitlines()[0] -        if state == FOUND_LINE_MATCH: -            # At this state, we keep on accumulating lines until the separator -            # is encountered.  At which point, we can return the log content. -            if line == separator: -                log.finish() -                print log.getvalue() -                return -            log.add_line(line) - -        elif state == LOOKING_FOR_MATCH: -            if line == separator: -                log.reset() -            log.add_line(line) -            # Update next state if necessary. -            if regexp.search(line): -                state = FOUND_LINE_MATCH - - -def main(): -    if len(sys.argv) != 2: -        print usage -        sys.exit(0) - -    regexp = re.compile(sys.argv[1]) -    grep(regexp) -    sys.stdin.close() - -if __name__ == '__main__': -    main() | 
