From 51d5bf6af357c9e0665db44375373ce8990caa6d Mon Sep 17 00:00:00 2001 From: Oleg Broytman Date: Tue, 26 Nov 2013 06:43:26 +0400 Subject: [PATCH] XML VFS version 1.1.0: show comment(s) before the root element --- xml | 28 ++++++++++++++++++++++++++-- xml-ANNOUNCE | 3 +++ 2 files changed, 29 insertions(+), 2 deletions(-) diff --git a/xml b/xml index 9a6db3e..e8049dd 100755 --- a/xml +++ b/xml @@ -40,7 +40,7 @@ The VFS was inspired by a FUSE xmlfs: https://github.com/halhen/xmlfs """ -__version__ = "1.0.1" +__version__ = "1.1.0" __author__ = "Oleg Broytman " __copyright__ = "Copyright (C) 2013 PhiloSoft Design" __license__ = "GPL" @@ -126,6 +126,9 @@ class XmlVfs(object): self.parse() def list(self): + root_comments = self.get_root_comments() + if root_comments: + print "-r--r--r-- 1 user group %d Jan 1 00:00 text" % (len(root_comments)) self._list(self.getroot()) def _list(self, node, path=''): @@ -208,6 +211,9 @@ class MiniDOMXmlVfs(XmlVfs): def getroot(self): return self.document + def get_root_comments(self): + return self.collect_text(self.document) + def getchildren(self, node): return node.childNodes @@ -283,6 +289,14 @@ if use_elementtree: def getroot(self): return self.document.getroot() + def get_root_comments(self): + text_accumulator = [] + for element in self.getroot(): + if not self.istag(element): + text = u"" % element.text + text_accumulator.append(text) + return '\n'.join(text_accumulator).encode(default_encoding, "replace") + def getlocalname(self, name): if name.startswith('{'): name = name.split('}', 1)[1] # Remove XML namespace @@ -299,6 +313,13 @@ if use_lxml: def getroot(self): return [self.document.getroot()] + def get_root_comments(self): + text_accumulator = [] + for element in self.document.getroot().itersiblings(tag=etree.Comment, preceding=True): + text = u"" % element.text + text_accumulator.append(text) + return '\n'.join(text_accumulator).encode(default_encoding, "replace") + def getlocalname(self, name): return etree.QName(name).localname @@ -379,7 +400,10 @@ def mcxml_copyout(): xml_error('There are no namespaces') elif path_comp == 'text': - text = xmlvfs.collect_text(node) + if '/' in xml_filename: + text = xmlvfs.collect_text(node) + else: + text = xmlvfs.get_root_comments() else: xml_error('Unknown file') diff --git a/xml-ANNOUNCE b/xml-ANNOUNCE index db4dadb..9156e2f 100644 --- a/xml-ANNOUNCE +++ b/xml-ANNOUNCE @@ -5,6 +5,9 @@ WHAT IS IT View an XML file in Midnight Commander as a filesystem. +WHAT'S NEW in version 1.1.0 (2013-11-26) + Show comment(s) before the root element. + WHAT'S NEW in version 1.0.1 (2013-11-24) Fixed a few minor bugs. -- 2.39.5