Merge branch 'master' into sqlalchemy
[sfa.git] / sfa / rspecs / elements / element.py
index 6f15d60..7f79e81 100644 (file)
@@ -11,51 +11,11 @@ class Element(dict):
             if key in fields:
                 self[key] = fields[key] 
 
-    @staticmethod
-    def get_elements(xml, xpath, element_class=None, fields=None):
-        """
-        Search the specifed xml node for elements that match the 
-        specified xpath query. 
-        Returns a list of objects instanced by the specified element_class.
-        """
-        if not element_class:
-            element_class = Element
-# xxx this obviously is wrong...
-#        if not fields and hasattr(element_class, fields):
-#           fields = element_class.fields
-        elems = xml.xpath(xpath)
-        objs = []
-        for elem in elems:
-            if not fields:
-                obj = element_class(elem.attrib, elem)
-            else:
-                obj = element_class({}, elem)
-                for field in fields:
-                    if field in elem.attrib:
-                        obj[field] = elem.attrib[field]    
-            objs.append(obj)
-# xxx seems unused
-        generic_elems = [element_class(elem.attrib, elem) for elem in elems]
-        return objs
 
-
-    @staticmethod
-    def add_elements(xml, name, objs, fields=None):
-        """
-        Adds a child node to the specified xml node based on
-        the specified name , element class and object.    
-        """
-        if not isinstance(objs, list):
-            objs = [objs]
-        elems = []
-        for obj in objs:
-            if not obj:
-                continue
-            if not fields:
-                fields = obj.keys()
-            elem = xml.add_element(name)
-            for field in fields:
-                if field in obj and obj[field]:
-                    elem.set(field, unicode(obj[field]))
-            elems.append(elem)
-        return elems
+    def __getattr__(self, name):
+        if hasattr(self.__dict__, name):
+            return getattr(self.__dict__, name)
+        elif hasattr(self.element, name):
+            return getattr(self.element, name)
+        else:
+            raise AttributeError, "class Element has no attribute %s" % name