__all__ = ['Composer', 'ComposerError'] from error import MarkedYAMLError from events import * from nodes import * class ComposerError(MarkedYAMLError): pass class Composer(object): def __init__(self): self.anchors = {} def check_node(self): # Drop the STREAM-START event. if self.check_event(StreamStartEvent): self.get_event() # If there are more documents available? return not self.check_event(StreamEndEvent) def get_node(self): # Get the root node of the next document. if not self.check_event(StreamEndEvent): return self.compose_document() def get_single_node(self): # Drop the STREAM-START event. self.get_event() # Compose a document if the stream is not empty. document = None if not self.check_event(StreamEndEvent): document = self.compose_document() # Ensure that the stream contains no more documents. if not self.check_event(StreamEndEvent): event = self.get_event() raise ComposerError("expected a single document in the stream", document.start_mark, "but found another document", event.start_mark) # Drop the STREAM-END event. self.get_event() return document def compose_document(self): # Drop the DOCUMENT-START event. self.get_event() # Compose the root node. node = self.compose_node(None, None) # Drop the DOCUMENT-END event. self.get_event() self.anchors = {} return node def compose_node(self, parent, index): if self.check_event(AliasEvent): event = self.get_event() anchor = event.anchor if anchor not in self.anchors: raise ComposerError(None, None, "found undefined alias %r" % anchor.encode('utf-8'), event.start_mark) return self.anchors[anchor] event = self.peek_event() anchor = event.anchor if anchor is not None: if anchor in self.anchors: raise ComposerError("found duplicate anchor %r; first occurence" % anchor.encode('utf-8'), self.anchors[anchor].start_mark, "second occurence", event.start_mark) self.descend_resolver(parent, index) if self.check_event(ScalarEvent): node = self.compose_scalar_node(anchor) elif self.check_event(SequenceStartEvent): node = self.compose_sequence_node(anchor) elif self.check_event(MappingStartEvent): node = self.compose_mapping_node(anchor) self.ascend_resolver() return node def compose_scalar_node(self, anchor): event = self.get_event() tag = event.tag if tag is None or tag == u'!': tag = self.resolve(ScalarNode, event.value, event.implicit) node = ScalarNode(tag, event.value, event.start_mark, event.end_mark, style=event.style) if anchor is not None: self.anchors[anchor] = node return node def compose_sequence_node(self, anchor): start_event = self.get_event() tag = start_event.tag if tag is None or tag == u'!': tag = self.resolve(SequenceNode, None, start_event.implicit) node = SequenceNode(tag, [], start_event.start_mark, None, flow_style=start_event.flow_style) if anchor is not None: self.anchors[anchor] = node index = 0 while not self.check_event(SequenceEndEvent): node.value.append(self.compose_node(node, index)) index += 1 end_event = self.get_event() node.end_mark = end_event.end_mark return node def compose_mapping_node(self, anchor): start_event = self.get_event() tag = start_event.tag if tag is None or tag == u'!': tag = self.resolve(MappingNode, None, start_event.implicit) node = MappingNode(tag, [], start_event.start_mark, None, flow_style=start_event.flow_style) if anchor is not None: self.anchors[anchor] = node while not self.check_event(MappingEndEvent): #key_event = self.peek_event() item_key = self.compose_node(node, None) #if item_key in node.value: # raise ComposerError("while composing a mapping", start_event.start_mark, # "found duplicate key", key_event.start_mark) item_value = self.compose_node(node, item_key) #node.value[item_key] = item_value node.value.append((item_key, item_value)) end_event = self.get_event() node.end_mark = end_event.end_mark return node
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__init__.py | File | 9.55 KB | 0644 |
|
__init__.pyc | File | 11.09 KB | 0644 |
|
composer.py | File | 4.81 KB | 0644 |
|
composer.pyc | File | 4.4 KB | 0644 |
|
constructor.py | File | 24.56 KB | 0644 |
|
constructor.pyc | File | 21.3 KB | 0644 |
|
cyaml.py | File | 3.21 KB | 0644 |
|
cyaml.pyc | File | 3.7 KB | 0644 |
|
dumper.py | File | 2.66 KB | 0644 |
|
dumper.pyc | File | 2.49 KB | 0644 |
|
emitter.py | File | 42.41 KB | 0644 |
|
emitter.pyc | File | 31.21 KB | 0644 |
|
error.py | File | 2.5 KB | 0644 |
|
error.pyc | File | 2.88 KB | 0644 |
|
events.py | File | 2.39 KB | 0644 |
|
events.pyc | File | 4.78 KB | 0644 |
|
loader.py | File | 1.11 KB | 0644 |
|
loader.pyc | File | 1.83 KB | 0644 |
|
nodes.py | File | 1.41 KB | 0644 |
|
nodes.pyc | File | 2.12 KB | 0644 |
|
parser.py | File | 24.94 KB | 0644 |
|
parser.pyc | File | 14.3 KB | 0644 |
|
reader.py | File | 6.77 KB | 0644 |
|
reader.pyc | File | 5.57 KB | 0644 |
|
representer.py | File | 17.3 KB | 0644 |
|
representer.pyc | File | 14.28 KB | 0644 |
|
resolver.py | File | 8.91 KB | 0644 |
|
resolver.pyc | File | 6.52 KB | 0644 |
|
scanner.py | File | 51.22 KB | 0644 |
|
scanner.pyc | File | 32.09 KB | 0644 |
|
serializer.py | File | 4.07 KB | 0644 |
|
serializer.pyc | File | 4.21 KB | 0644 |
|
tokens.py | File | 2.51 KB | 0644 |
|
tokens.pyc | File | 6.28 KB | 0644 |
|