From e760c7f30e7f43af7ed1c0ab55625362ea923951 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vil=C3=A9m=20Duha?= <vilda.novak@gmail.com> Date: Wed, 4 Sep 2019 15:34:09 +0200 Subject: [PATCH] BlenderKit: fix upload of objects with ' or " in their name. it now doesn't allow these character in object/datablock names when uploading. --- blenderkit/__init__.py | 14 ++------------ blenderkit/autothumb.py | 2 +- blenderkit/upload.py | 4 ++++ blenderkit/utils.py | 19 +++++++++++++++++++ 4 files changed, 26 insertions(+), 13 deletions(-) diff --git a/blenderkit/__init__.py b/blenderkit/__init__.py index 516f470c2..d7689a3c0 100644 --- a/blenderkit/__init__.py +++ b/blenderkit/__init__.py @@ -371,18 +371,8 @@ class BlenderKitCommonSearchProps(object): def name_update(self, context): ''' checks for name change, because it decides if whole asset has to be re-uploaded. Name is stored in the blend file and that's the reason.''' - props = utils.get_upload_props() - if props.name_old != props.name: - props.name_changed = True - props.name_old = props.name - nname = props.name.strip() - nname = nname.replace('_', ' ') - if nname.isupper(): - nname = nname.lower() - nname = nname[0].upper() + nname[1:] - props.name = nname - asset = utils.get_active_asset() - asset.name = nname + utils.name_update() + def update_tags(self, context): diff --git a/blenderkit/autothumb.py b/blenderkit/autothumb.py index f9e7c85f8..4be82f292 100644 --- a/blenderkit/autothumb.py +++ b/blenderkit/autothumb.py @@ -110,7 +110,7 @@ def start_thumbnailer(self, context): basename = os.path.join(basename, "temp") if not ext: ext = ".blend" - asset_name = mainmodel.blenderkit.name + asset_name = mainmodel.name tempdir = tempfile.mkdtemp() file_dir = os.path.dirname(bpy.data.filepath) diff --git a/blenderkit/upload.py b/blenderkit/upload.py index 75f203df4..955713b51 100644 --- a/blenderkit/upload.py +++ b/blenderkit/upload.py @@ -533,6 +533,10 @@ def auto_fix(asset_type=''): def start_upload(self, context, asset_type, reupload, upload_set): '''start upload process, by processing data''' + + # fix the name first + utils.name_update() + props = utils.get_upload_props() storage_quota_ok = check_storage_quota(props) if not storage_quota_ok: diff --git a/blenderkit/utils.py b/blenderkit/utils.py index 20dcaec8c..688346c00 100644 --- a/blenderkit/utils.py +++ b/blenderkit/utils.py @@ -465,3 +465,22 @@ def automap(target_object=None, target_slot=None, tex_size=1, bg_exception=False if just_scale: scale_uvs(tob, scale=Vector((1/tex_size, 1/tex_size))) bpy.context.view_layer.objects.active = actob + +def name_update(): + props = get_upload_props() + if props.name_old != props.name: + props.name_changed = True + props.name_old = props.name + nname = props.name.strip() + nname = nname.replace('_', ' ') + + if nname.isupper(): + nname = nname.lower() + nname = nname[0].upper() + nname[1:] + props.name = nname + # here we need to fix the name for blender data = ' or " give problems in path evaluation down the road. + fname = props.name + fname = fname.replace('\'', '') + fname = fname.replace('\"', '') + asset = get_active_asset() + asset.name = fname \ No newline at end of file -- GitLab