[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [31276] branches/soc-2010-moguri-2/release /scripts: These files didn't get added with the merge for some reason.

Mitchell Stokes mogurijin at gmail.com
Thu Aug 12 08:43:40 CEST 2010


Revision: 31276
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=31276
Author:   moguri
Date:     2010-08-12 08:43:39 +0200 (Thu, 12 Aug 2010)

Log Message:
-----------
These files didn't get added with the merge for some reason. Hopefully this isn't a sign of trouble to come...

Added Paths:
-----------
    branches/soc-2010-moguri-2/release/scripts/modules/bpy/path.py
    branches/soc-2010-moguri-2/release/scripts/modules/bpy_xml_ui.py
    branches/soc-2010-moguri-2/release/scripts/ui/properties_render_test.xml

Added: branches/soc-2010-moguri-2/release/scripts/modules/bpy/path.py
===================================================================
--- branches/soc-2010-moguri-2/release/scripts/modules/bpy/path.py	                        (rev 0)
+++ branches/soc-2010-moguri-2/release/scripts/modules/bpy/path.py	2010-08-12 06:43:39 UTC (rev 31276)
@@ -0,0 +1,174 @@
+# ##### BEGIN GPL LICENSE BLOCK #####
+#
+#  This program is free software; you can redistribute it and/or
+#  modify it under the terms of the GNU General Public License
+#  as published by the Free Software Foundation; either version 2
+#  of the License, or (at your option) any later version.
+#
+#  This program is distributed in the hope that it will be useful,
+#  but WITHOUT ANY WARRANTY; without even the implied warranty of
+#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#  GNU General Public License for more details.
+#
+#  You should have received a copy of the GNU General Public License
+#  along with this program; if not, write to the Free Software Foundation,
+#  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# ##### END GPL LICENSE BLOCK #####
+
+# <pep8 compliant>
+
+"""
+This module has a similar scope to os.path, containing utility
+functions for dealing with paths in Blender.
+"""
+
+import bpy as _bpy
+import os as _os
+
+def expand(path):
+    """
+    Returns the absolute path relative to the current blend file using the "//" prefix.
+    """
+    if path.startswith("//"):
+        return _os.path.join(_os.path.dirname(_bpy.data.filepath), path[2:])
+
+    return path
+
+
+def relpath(path, start=None):
+    """
+    Returns the path relative to the current blend file using the "//" prefix.
+
+    :arg start: Relative to this path, when not set the current filename is used.
+    :type start: string
+    """
+    if not path.startswith("//"):
+        if start is None:
+            start = _os.path.dirname(_bpy.data.filepath)
+        return "//" + _os.path.relpath(path, start)
+
+    return path
+
+
+def clean_name(name, replace="_"):
+    """
+    Returns a name with characters replaced that may cause problems under various circumstances, such as writing to a file.
+    All characters besides A-Z/a-z, 0-9 are replaced with "_"
+    or the replace argument if defined.
+    """
+
+    unclean_chars = \
+                 "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\
+                  \x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\
+                  \x1e\x1f\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\
+                  \x2e\x2f\x3a\x3b\x3c\x3d\x3e\x3f\x40\x5b\x5c\x5d\x5e\x60\x7b\
+                  \x7c\x7d\x7e\x7f\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\
+                  \x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\
+                  \x9a\x9b\x9c\x9d\x9e\x9f\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\
+                  \xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\
+                  \xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\
+                  \xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\
+                  \xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\
+                  \xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\
+                  \xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe"
+
+    for ch in unclean_chars:
+        name = name.replace(ch, replace)
+    return name
+
+
+def display_name(name):
+    """
+    Creates a display string from name to be used menus and the user interface.
+    Capitalize the first letter in all lowercase names, mixed case names are kept as is.
+    Intended for use with filenames and module names.
+    """
+
+    name_base = _os.path.splitext(name)[0]
+
+    # string replacements
+    name_base = name_base.replace("_colon_", ":")
+
+    name_base = name_base.replace("_", " ")
+
+    if name_base.islower():
+        return name_base.capitalize()
+    else:
+        return name_base
+
+
+def resolve_ncase(path):
+	"""
+	Resolve a case insensitive path on a case sensitive system,
+	returning a string with the path if found else return the original path.
+	"""
+
+	import os
+
+	def _ncase_path_found(path):
+		if path=='' or os.path.exists(path):
+			return path, True
+
+		filename = os.path.basename(path) # filename may be a directory or a file
+		dirpath = os.path.dirname(path)
+
+		suffix = ""
+		if not filename: # dir ends with a slash?
+			if len(dirpath) < len(path):
+				suffix = path[:len(path)-len(dirpath)]
+
+			filename = os.path.basename(dirpath)
+			dirpath = os.path.dirname(dirpath)
+
+		if not os.path.exists(dirpath):
+			dirpath, found = _ncase_path_found(dirpath)
+
+			if not found:
+				return path, False
+
+		# at this point, the directory exists but not the file
+
+		# we are expecting 'dirpath' to be a directory, but it could be a file
+		if os.path.isdir(dirpath):
+			files = os.listdir(dirpath)
+		else:
+			return path, False
+
+		filename_low = filename.lower()
+		f_iter_nocase = None
+
+		for f_iter in files:
+			if f_iter.lower() == filename_low:
+				f_iter_nocase = f_iter
+				break
+
+		if f_iter_nocase:
+			return os.path.join(dirpath, f_iter_nocase) + suffix, True
+		else:
+			# cant find the right one, just return the path as is.
+			return path, False
+
+	ncase_path, found = _ncase_path_found(path)
+	return ncase_path if found else path
+
+
+def ensure_ext(filepath, ext, case_sensitive=False):
+    """
+    Return the path with the extension added its its not alredy set.
+
+    :arg ext: The extension to check for.
+    :type ext: string
+    :arg case_sensitive: Check for matching case when comparing extensions.
+    :type case_sensitive: bool
+    """
+    import os
+    fn_base, fn_ext = os.path.splitext(filepath)
+    if fn_base and fn_ext:
+        if (case_sensitive and ext == fn_ext) or (ext.lower() == fn_ext.lower()):
+            return filepath
+        else:
+            return fn_base + ext
+
+    else:
+        return filepath + ext

Added: branches/soc-2010-moguri-2/release/scripts/modules/bpy_xml_ui.py
===================================================================
--- branches/soc-2010-moguri-2/release/scripts/modules/bpy_xml_ui.py	                        (rev 0)
+++ branches/soc-2010-moguri-2/release/scripts/modules/bpy_xml_ui.py	2010-08-12 06:43:39 UTC (rev 31276)
@@ -0,0 +1,151 @@
+# ##### BEGIN GPL LICENSE BLOCK #####
+#
+#  This program is free software; you can redistribute it and/or
+#  modify it under the terms of the GNU General Public License
+#  as published by the Free Software Foundation; either version 2
+#  of the License, or (at your option) any later version.
+#
+#  This program is distributed in the hope that it will be useful,
+#  but WITHOUT ANY WARRANTY; without even the implied warranty of
+#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#  GNU General Public License for more details.
+#
+#  You should have received a copy of the GNU General Public License
+#  along with this program; if not, write to the Free Software Foundation,
+#  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# ##### END GPL LICENSE BLOCK #####
+
+# <pep8 compliant>
+
+"""
+This module translates XML into blender/ui function calls.
+"""
+
+import xml.dom.minidom
+import bpy as _bpy
+
+def parse_rna(prop, value):
+    if prop.type == 'FLOAT':
+        value = float(value)
+    elif prop.type == 'INT':
+        value = int(value)
+    elif prop.type == 'BOOLEAN':
+        if value not in ("true", "false"):
+            raise Exception("invalid bool value: %s", value)
+        value = bool(value == "true")
+    elif prop.type in ('STRING', 'ENUM'):
+        pass
+    elif prop.type == 'POINTER':
+        value = eval("_bpy." + value)
+    else:
+        raise Exception("type not supported %s.%s" % (prop.identifier, prop.type))
+    return value
+    
+def parse_args(base, xml_node):
+    args = {}
+    rna_params = base.bl_rna.functions[xml_node.tagName].parameters
+    for key, value in xml_node.attributes.items():
+        args[key] = parse_rna(rna_params[key], value)
+    return args
+
+def ui_xml(base, xml_node):
+    name = xml_node.tagName
+    prop = base.bl_rna.properties.get(name)
+    if name in base.bl_rna.properties:
+        attr = xml_node.attributes.get("expr")
+        if attr:
+            value = attr.value
+            value = eval(value, {"context": _bpy.context})
+            setattr(base, name, value)
+        else:
+            attr = xml_node.attributes['value']
+            value = attr.value
+            value = parse_rna(prop, value)
+            setattr(base, name, value)
+    else:
+        func_new = getattr(base, name)
+        kw_args = parse_args(base, xml_node)
+        base_new = func_new(**kw_args) # call blender func
+        if xml_node.hasChildNodes():
+            ui_xml_list(base_new, xml_node.childNodes)
+
+def ui_xml_list(base, xml_nodes):
+    import bpy
+    for node in xml_nodes:
+        if node.nodeType not in (node.TEXT_NODE, node.COMMENT_NODE):
+            ui_xml(base, node)
+            bpy.N = node
+
+def test(layout):
+    uixml = xml.dom.minidom.parseString(open("/mnt/test/blender-svn/blender/release/scripts/ui/test.xml", 'r').read())
+    panel = uixml.getElementsByTagName('panel')[0]
+    ui_xml_list(layout, panel.childNodes)
+
+def load_xml(filepath):
+    classes = []
+    fn = open(filepath, 'r')
+    data = fn.read()
+    uixml = xml.dom.minidom.parseString(data).getElementsByTagName("ui")[0]
+    fn.close()
+    
+    def draw_xml(self, context):
+        node = self._xml_node.getElementsByTagName("draw")[0]
+        ui_xml_list(self.layout, node.childNodes)
+        
+    def draw_header_xml(self, context):
+        node = self._xml_node.getElementsByTagName("draw_header")[0]
+        ui_xml_list(self.layout, node.childNodes)
+    
+    for node in uixml.childNodes:
+        if node.nodeType not in (node.TEXT_NODE, node.COMMENT_NODE):
+            name = node.tagName
+            class_name = node.attributes["identifier"].value
+
+            if name == "panel":
+                class_dict = {
+                    "bl_label": node.attributes["label"].value,
+                    "bl_region_type": node.attributes["region_type"].value,
+                    "bl_space_type": node.attributes["space_type"].value,
+                    "bl_context": node.attributes["context"].value,

@@ Diff output truncated at 10240 characters. @@




More information about the Bf-blender-cvs mailing list