diff options
author | Campbell Barton <ideasman42@gmail.com> | 2012-03-22 02:29:49 +0400 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2012-03-22 02:29:49 +0400 |
commit | b56d2f97662e0277076b7a7fd1f7a19380dc9f63 (patch) | |
tree | e2bb3fb3affd60a14229fd38098a3c804a8e3b03 /source/blender/python/intern/bpy.c | |
parent | 95f66f162ce695310872950232b6a00633646e1e (diff) |
fix [#30623] user-defined render presets bug
this report exposed multiple bugs in blender when using a non utf8 compatible home directory.
- bpy.utils.script_paths() would crash when homedir wasn't utf8 (reported bug)
- PyC_DefaultNameSpace() - would raise an error when running when __file__ was non utf8.
- preset filepath property was not set to accept non utf8.
- bpy.paths.display_name would raise an error on non utf8 paths, (used for preset draw)
Diffstat (limited to 'source/blender/python/intern/bpy.c')
-rw-r--r-- | source/blender/python/intern/bpy.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/source/blender/python/intern/bpy.c b/source/blender/python/intern/bpy.c index 0f5ca13586c..71cfa50743d 100644 --- a/source/blender/python/intern/bpy.c +++ b/source/blender/python/intern/bpy.c @@ -71,12 +71,17 @@ PyDoc_STRVAR(bpy_script_paths_doc, static PyObject *bpy_script_paths(PyObject *UNUSED(self)) { PyObject *ret = PyTuple_New(2); + PyObject *item; char *path; path = BLI_get_folder(BLENDER_SYSTEM_SCRIPTS, NULL); - PyTuple_SET_ITEM(ret, 0, PyUnicode_FromString(path?path:"")); + item = PyUnicode_DecodeFSDefault(path ? path : ""); + BLI_assert(item != NULL); + PyTuple_SET_ITEM(ret, 0, item); path = BLI_get_folder(BLENDER_USER_SCRIPTS, NULL); - PyTuple_SET_ITEM(ret, 1, PyUnicode_FromString(path?path:"")); + item = PyUnicode_DecodeFSDefault(path ? path : ""); + BLI_assert(item != NULL); + PyTuple_SET_ITEM(ret, 1, item); return ret; } @@ -200,7 +205,7 @@ static PyObject *bpy_resource_path(PyObject *UNUSED(self), PyObject *args, PyObj path = BLI_get_folder_version(folder_id, (major * 100) + minor, FALSE); - return PyUnicode_DecodeFSDefault(path); + return PyUnicode_DecodeFSDefault(path ? path : ""); } static PyMethodDef meth_bpy_script_paths = |