File: tool_output.py

package info (click to toggle)
gnat-gps 18-5
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 45,716 kB
  • sloc: ada: 362,679; python: 31,031; xml: 9,597; makefile: 1,030; ansic: 917; sh: 264; java: 17
file content (78 lines) | stat: -rw-r--r-- 2,512 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
"""This plugin provides base class for custom output parser.

Parsers are organized in chain. Output of one parser is passed as input
to next one. Chain of parser could be attached to a build target.

An example:

import GPS, tool_output

class PopupParser(tool_output.OutputParser):
    def on_stdout(self,text,command):
        #  This call accepts all output during target build.
        #  text    - piece of output of target's build.
        #  command - GPS.Command caused build to execute.
        GPS.MDI.dialog (text)
        if self.child != None:
            self.child.on_stdout (text,command)

    def on_exit(self,status,command):
        #  This is called after build competed.
        #  Then each output parser is destroyed.
        #  status  - integer status of execution.
        #  command - GPS.Command caused build to execute.

        GPS.MDI.dialog ("Build complete!")
        if self.child != None:
            self.child.on_exit (status,command)

To add custom parser to a target insert next line to target description:

<output-parsers>[default] popupparser</output-parsers>
</target>
"""

#############################################################################
# No user customization below this line
#############################################################################

import six

class OutputParserMetaClass(type):
    registered = dict()   # list of registered parsers

    def __new__(cls, name, bases, attrs):
        new_class = type.__new__(cls, name, bases, attrs)
        OutputParserMetaClass.registered[new_class.get_name()] = new_class
        return new_class

    def get_name(self):
        """Return the name of the parser, either from a "name" class
            attribute, or from the class name
        """
        return getattr(self, 'name', self.__name__).lower()


@six.add_metaclass (OutputParserMetaClass)
class OutputParser(object):
    def __init__(self, child):
        self.child = child

    def on_stdout(self, text, command):
        if self.child is not None:
            self.child.on_stdout(text, command)

    def on_stderr(self, text, command):
        if self.child is not None:
            self.child.on_stderr(text, command)

    def on_exit(self, status, command):
        if self.child is not None:
            self.child.on_exit(status, command)


def create_parser(name, child=None):
    if name in OutputParserMetaClass.registered:
        return OutputParserMetaClass.registered[name](child)
    else:
        return None