From 1aca840cf74ce6c1553a33eaaee06869be8734a1 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Fri, 4 Oct 2024 01:13:41 +0200 Subject: [PATCH 01/15] Replace the Load LOPs parm callbacks with expressions on the file parms to support Solaris Context Options (Draft) --- client/ayon_houdini/api/hda_utils.py | 76 +++++++++---------- .../otls/ayon_lop_import.hda/INDEX__SECTION | 2 +- .../DialogScript | 22 ++---- .../DialogScript | 20 +---- 4 files changed, 44 insertions(+), 76 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 617f121258..dc19e643dd 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -33,6 +33,14 @@ import hou +def get_session_cache() -> dict: + """Get a persistent `hou.session.ayon_cache` dict""" + cache = getattr(hou.session, "ayon_cache", None) + if cache is None: + hou.session.ayon_cache = cache = {} + return cache + + def is_valid_uuid(value) -> bool: """Return whether value is a valid UUID""" try: @@ -155,36 +163,21 @@ def _get_thumbnail(project_name: str, version_id: str, thumbnail_dir: str): return path -def set_representation(node, representation_id: str): - file_parm = node.parm("file") - if not representation_id: - # Clear filepath and thumbnail - with _unlocked_parm(file_parm): - file_parm.set("") - set_node_thumbnail(node, None) - return - - project_name = ( - node.evalParm("project_name") - or get_current_project_name() - ) - +def get_representation_path( + project_name: str, + representation_id: str, + use_ayon_entity_uri: bool +) -> str: # Ignore invalid representation ids silently # TODO remove - added for backwards compatibility with OpenPype scenes if not is_valid_uuid(representation_id): - return + return "" repre_entity = get_representation_by_id(project_name, representation_id) if not repre_entity: - return + return "" context = get_representation_context(project_name, repre_entity) - update_info(node, context) - - if node.parm("use_ayon_entity_uri"): - use_ayon_entity_uri = node.evalParm("use_ayon_entity_uri") - else: - use_ayon_entity_uri = False if use_ayon_entity_uri: path = get_ayon_entity_uri_from_representation_context(context) else: @@ -193,8 +186,22 @@ def set_representation(node, representation_id: str): # fails to resolve @sourcename var with backslashed # paths correctly. So we force forward slashes path = path.replace("\\", "/") - with _unlocked_parm(file_parm): - file_parm.set(path) + return path + + +def set_representation(node, representation_id: str): + # TODO: Unused currently; add support again for thumbnail updates + if not representation_id: + set_node_thumbnail(node, None) + return + + project_name = ( + node.evalParm("project_name") + or get_current_project_name() + ) + repre_entity = get_representation_by_id(project_name, representation_id) + context = get_representation_context(project_name, repre_entity) + update_info(node, context) if node.evalParm("show_thumbnail"): # Update thumbnail @@ -264,19 +271,9 @@ def on_representation_id_changed(node): set_representation(node, repre_id) -def on_representation_parms_changed(node, force=False): - """ - Usually used as callback to the project, folder, product, version and - representation parms which on change - would result in a different - representation id to be resolved. - - Args: - node (hou.Node): Node to update. - force (Optional[bool]): Whether to force the callback to retrigger - even if the representation id already matches. For example, when - needing to resolve the filepath in a different way. - """ - project_name = node.evalParm("project_name") or get_current_project_name() +def get_node_expected_representation_id(node) -> str: + project_name = node.evalParm( + "project_name") or get_current_project_name() representation_id = get_representation_id( project_name=project_name, folder_path=node.evalParm("folder_path"), @@ -289,10 +286,7 @@ def on_representation_parms_changed(node, force=False): representation_id = "" else: representation_id = str(representation_id) - - if force or node.evalParm("representation") != representation_id: - node.parm("representation").set(representation_id) - node.parm("representation").pressButton() # trigger callback + return representation_id def get_representation_id( diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION index f101cdfeb0..331f88cba9 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION @@ -10,5 +10,5 @@ Inputs: 0 to 1 Subnet: true Python: false Empty: false -Modified: Tue Jul 30 12:57:14 2024 +Modified: Fri Oct 4 00:58:20 2024 diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index f18c00d472..647d7ed8ed 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -34,8 +34,6 @@ default { "$AYON_PROJECT_NAME" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_folder_path;select_folder_path(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "folder_path" @@ -44,8 +42,6 @@ default { "$AYON_FOLDER_PATH" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_folder_path;select_folder_path(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "folder_name" @@ -60,7 +56,7 @@ default { "usdAsset" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_product_name;select_product_name(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().set_to_latest_version(kwargs['node'])\nhou.phm().on_representation_parms_changed(kwargs['node'])" } + parmtag { "script_callback" "hou.phm().set_to_latest_version(kwargs['node'])" } parmtag { "script_callback_language" "python" } } parm { @@ -80,16 +76,12 @@ [ "return result" ] language python } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "representation_name" label "Representation" type string default { "usd" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "load_refresh" @@ -99,7 +91,7 @@ default { "0" } help "Click to refresh and retry applying the product load parameters to load the correct file" parmtag { "button_icon" "" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } + parmtag { "script_callback" "" } parmtag { "script_callback_language" "python" } } parm { @@ -128,17 +120,15 @@ name "file" label "File" type string - default { "" } + default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_path\", {})\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nrepre_id = hou.evalParm(\"representation\")\nuse_entity_uri = hou.evalParm(\"use_ayon_entity_uri\")\nhash_value = project_name, repre_id, use_entity_uri\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\npath = hda_utils.get_representation_path(project_name, repre_id, use_entity_uri)\ncache[hash_value] = path\nreturn path\n" python ] } parmtag { "script_callback_language" "python" } } parm { name "use_ayon_entity_uri" label "Use AYON Entity URI" - help "When enabled, loads the filepath using the AYON Entity URI instead of the resolved filepath." type toggle default { "0" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'], force=True)" } - parmtag { "script_callback_language" "python" } + help "When enabled, loads the filepath using the AYON Entity URI instead of the resolved filepath." } parm { name "primpath1" @@ -336,9 +326,7 @@ name "representation" label "Representation ID" type string - default { "" } - parmtag { "script_callback" "hou.phm().on_representation_id_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } + default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_ids\", {})\n\n\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nfolder_path = hou.evalParm(\"folder_path\")\nproduct_name = hou.evalParm(\"product_name\")\nversion = hou.evalParm(\"version\")\nrepresentation_name = hou.evalParm(\"representation_name\")\n\nnode = hou.pwd()\nhash_value = \">\".join([project_name, folder_path, product_name, version, representation_name])\nprint(f\"Expression: {node.path()} {datetime.datetime.now()} {hash_value}\")\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\nrepre_id = hda_utils.get_node_expected_representation_id(node)\ncache[hash_value] = repre_id\n" python ] } } parm { name "version_name" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index 140a1f0cb9..eb72b48d9d 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -34,8 +34,6 @@ default { "$AYON_PROJECT_NAME" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_folder_path;select_folder_path(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "folder_path" @@ -44,8 +42,6 @@ default { "$AYON_FOLDER_PATH" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_folder_path;select_folder_path(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "product_name" @@ -54,7 +50,7 @@ default { "usdShot" } parmtag { "script_action" "from ayon_houdini.api.hda_utils import select_product_name;select_product_name(kwargs['node'])" } parmtag { "script_action_icon" "BUTTONS_reselect" } - parmtag { "script_callback" "hou.phm().set_to_latest_version(kwargs['node'])\nhou.phm().on_representation_parms_changed(kwargs['node'])" } + parmtag { "script_callback" "hou.phm().set_to_latest_version(kwargs['node'])" } parmtag { "script_callback_language" "python" } } parm { @@ -74,16 +70,12 @@ [ "return result" ] language python } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "representation_name" label "Representation" type string default { "usd" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "load_refresh" @@ -93,8 +85,6 @@ default { "0" } help "Click to refresh and retry applying the product load parameters to load the correct file" parmtag { "button_icon" "" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } parm { name "load_message" @@ -122,7 +112,7 @@ name "file" label "File" type string - default { "" } + default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_path\", {})\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nrepre_id = hou.evalParm(\"representation\")\nuse_entity_uri = hou.evalParm(\"use_ayon_entity_uri\")\nhash_value = project_name, repre_id, use_entity_uri\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\npath = hda_utils.get_representation_path(project_name, repre_id, use_entity_uri)\ncache[hash_value] = path\nreturn path\n" python ] } parmtag { "script_callback_language" "python" } } parm { @@ -131,8 +121,6 @@ help "When enabled, loads the filepath using the AYON Entity URI instead of the resolved filepath." type toggle default { "0" } - parmtag { "script_callback" "hou.phm().on_representation_parms_changed(kwargs['node'], force=True)" } - parmtag { "script_callback_language" "python" } } groupcollapsible { name "extra_options" @@ -263,9 +251,7 @@ name "representation" label "Representation ID" type string - default { "" } - parmtag { "script_callback" "hou.phm().on_representation_id_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } + default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_ids\", {})\n\n\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nfolder_path = hou.evalParm(\"folder_path\")\nproduct_name = hou.evalParm(\"product_name\")\nversion = hou.evalParm(\"version\")\nrepresentation_name = hou.evalParm(\"representation_name\")\n\nnode = hou.pwd()\nhash_value = \">\".join([project_name, folder_path, product_name, version, representation_name])\nprint(f\"Expression: {node.path()} {datetime.datetime.now()} {hash_value}\")\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\nrepre_id = hda_utils.get_node_expected_representation_id(node)\ncache[hash_value] = repre_id\n" python ] } } parm { name "version_name" From 61e31d5c5867359c9c31cf965bdabb9e25a4b517 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Fri, 4 Oct 2024 01:19:04 +0200 Subject: [PATCH 02/15] Revert redundant change --- .../startup/otls/ayon_lop_import.hda/INDEX__SECTION | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION index 331f88cba9..520c4e6c37 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION @@ -10,5 +10,4 @@ Inputs: 0 to 1 Subnet: true Python: false Empty: false -Modified: Fri Oct 4 00:58:20 2024 - +Modified: Tue Jul 30 12:57:14 2024 From 46335d3601c668f6d166763c88350d93d139f1ea Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Fri, 4 Oct 2024 01:21:20 +0200 Subject: [PATCH 03/15] Revert redundant change --- .../ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION | 1 + 1 file changed, 1 insertion(+) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION index 520c4e6c37..f101cdfeb0 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION @@ -11,3 +11,4 @@ Subnet: true Python: false Empty: false Modified: Tue Jul 30 12:57:14 2024 + From ce5063b99f53be76c750de4f97be3c39d6f8af3e Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Fri, 4 Oct 2024 02:06:14 +0200 Subject: [PATCH 04/15] Remove removed function --- .../ayon_8_8Lop_1lop__import_8_81.0/PythonModule | 1 - .../ayon_8_8Lop_1load__shot_8_81.0/PythonModule | 1 - 2 files changed, 2 deletions(-) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule index 0e91d023b2..901c00e19d 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule @@ -2,7 +2,6 @@ from ayon_houdini.api.hda_utils import ( on_thumbnail_show_changed, on_thumbnail_size_changed, on_representation_id_changed, - on_representation_parms_changed, setup_flag_changed_callback, get_available_versions, select_product_name, diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule index 0e91d023b2..901c00e19d 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule @@ -2,7 +2,6 @@ from ayon_houdini.api.hda_utils import ( on_thumbnail_show_changed, on_thumbnail_size_changed, on_representation_id_changed, - on_representation_parms_changed, setup_flag_changed_callback, get_available_versions, select_product_name, From bbee3344e214426c29420f6ee662614a3e6c9d20 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 10:43:05 +0200 Subject: [PATCH 05/15] Move expression functions into `hda_utils` for re-use and easier code reviews in `git` --- client/ayon_houdini/api/hda_utils.py | 53 +++++++++++++++++++ .../DialogScript | 4 +- .../DialogScript | 4 +- 3 files changed, 57 insertions(+), 4 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index dc19e643dd..15a0fbfe6b 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -708,3 +708,56 @@ def set_to_latest_version(node): versions = get_available_versions(node) if versions: node.parm("version").set(str(versions[0])) + + +# region Parm Expressions +# Callbacks used for expression on HDAs (e.g. Load Asset or Load Shot LOP) +# Note that these are called many times, sometimes even multiple times when +# the Parameters tab is open on the node. So some caching is performed to +# avoid expensive re-querying. +def expression_clear_cache(subkey=None) -> bool: + # Clear full cache if no subkey provided + if subkey is None: + if hasattr(hou.session, "ayon_cache"): + delattr(hou.session, "ayon_cache") + return True + return False + + # Clear only key in cache if provided + cache = getattr(hou.session, "ayon_cache", {}) + if subkey in cache: + cache.pop(subkey) + return True + return False + + +def expression_get_representation_id() -> str: + project_name = hou.evalParm("project_name") + folder_path = hou.evalParm("folder_path") + product_name = hou.evalParm("product_name") + version = hou.evalParm("version") + representation_name = hou.evalParm("representation_name") + + node = hou.pwd() + hash_value = (project_name, folder_path, product_name, version, + representation_name) + cache = get_session_cache().setdefault("representation_ids", {}) + if hash_value in cache: + return cache[hash_value] + + repre_id = get_node_expected_representation_id(node) + cache[hash_value] = repre_id + + +def expression_get_representation_path() -> str: + cache = get_session_cache().setdefault("representation_path", {}) + project_name = hou.evalParm("project_name") + repre_id = hou.evalParm("representation") + use_entity_uri = hou.evalParm("use_ayon_entity_uri") + hash_value = project_name, repre_id, use_entity_uri + if hash_value in cache: + return cache[hash_value] + + path = get_representation_path(project_name, repre_id, use_entity_uri) + cache[hash_value] = path + return path diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index 647d7ed8ed..392ddb09a6 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -120,7 +120,7 @@ name "file" label "File" type string - default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_path\", {})\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nrepre_id = hou.evalParm(\"representation\")\nuse_entity_uri = hou.evalParm(\"use_ayon_entity_uri\")\nhash_value = project_name, repre_id, use_entity_uri\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\npath = hda_utils.get_representation_path(project_name, repre_id, use_entity_uri)\ncache[hash_value] = path\nreturn path\n" python ] } + default { [ "from ayon_houdini.api import hda_utils\nreturn hda_utils.expression_get_representation_path()" python ] } parmtag { "script_callback_language" "python" } } parm { @@ -326,7 +326,7 @@ name "representation" label "Representation ID" type string - default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_ids\", {})\n\n\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nfolder_path = hou.evalParm(\"folder_path\")\nproduct_name = hou.evalParm(\"product_name\")\nversion = hou.evalParm(\"version\")\nrepresentation_name = hou.evalParm(\"representation_name\")\n\nnode = hou.pwd()\nhash_value = \">\".join([project_name, folder_path, product_name, version, representation_name])\nprint(f\"Expression: {node.path()} {datetime.datetime.now()} {hash_value}\")\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\nrepre_id = hda_utils.get_node_expected_representation_id(node)\ncache[hash_value] = repre_id\n" python ] } + default { [ "from ayon_houdini.api import hda_utils\nreturn hda_utils.expression_get_representation_id()" python ] } } parm { name "version_name" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index eb72b48d9d..b23a95dd43 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -112,7 +112,7 @@ name "file" label "File" type string - default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_path\", {})\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nrepre_id = hou.evalParm(\"representation\")\nuse_entity_uri = hou.evalParm(\"use_ayon_entity_uri\")\nhash_value = project_name, repre_id, use_entity_uri\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\npath = hda_utils.get_representation_path(project_name, repre_id, use_entity_uri)\ncache[hash_value] = path\nreturn path\n" python ] } + default { [ "from ayon_houdini.api import hda_utils\nreturn hda_utils.expression_get_representation_path()" python ] } parmtag { "script_callback_language" "python" } } parm { @@ -251,7 +251,7 @@ name "representation" label "Representation ID" type string - default { [ "# This triggers very often, for whatever reason. So we need to\n# optimize and cache to avoid heavy querying for each call.\nimport datetime\nimport hou.session\n\nfrom ayon_houdini.api import hda_utils\nimport importlib\nimportlib.reload(hda_utils)\n\ncache = hda_utils.get_session_cache().setdefault(\"representation_ids\", {})\n\n\n\n# Set up input dependencies (by calling these Houdini links\n# there attributes as input dependencies and will update the\n# expression if any of them changes)\nproject_name = hou.evalParm(\"project_name\")\nfolder_path = hou.evalParm(\"folder_path\")\nproduct_name = hou.evalParm(\"product_name\")\nversion = hou.evalParm(\"version\")\nrepresentation_name = hou.evalParm(\"representation_name\")\n\nnode = hou.pwd()\nhash_value = \">\".join([project_name, folder_path, product_name, version, representation_name])\nprint(f\"Expression: {node.path()} {datetime.datetime.now()} {hash_value}\")\nif hash_value in cache:\n return cache[hash_value]\n\n\nprint(\"Compute\")\nrepre_id = hda_utils.get_node_expected_representation_id(node)\ncache[hash_value] = repre_id\n" python ] } + default { [ "from ayon_houdini.api import hda_utils\nreturn hda_utils.expression_get_representation_id()" python ] } } parm { name "version_name" From 4167536db044edbf2253800fe28e4c226e429164 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 11:00:30 +0200 Subject: [PATCH 06/15] Add todo --- client/ayon_houdini/api/hda_utils.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 15a0fbfe6b..2801fb5652 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -312,6 +312,11 @@ def get_representation_id( Optional[str]: Representation id or None if not found. """ + # TODO: This is now used in an expression in LOPs and preferably should + # not trigger setting additional parameters. As such, we should maybe + # somehow offload the warning message to the "cook" or some other way + # of identifying whether the parms are all valid without requiring + # more queries of the database. if not all([ project_name, folder_path, product_name, version, representation_name From 4b43df5c904dcfd72a38ce58b07cae379b433256 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 15:20:58 +0200 Subject: [PATCH 07/15] Fix shown warning on the LOP node by force computing them when needed --- client/ayon_houdini/api/hda_utils.py | 66 +++----- .../Contents.dir/Contents.createtimes | 5 +- .../Contents.dir/Contents.houdini_versions | 7 +- .../Contents.dir/Contents.mime | 156 +++++++++++++++--- .../Contents.dir/Contents.modtimes | 9 +- .../DialogScript | 19 --- 6 files changed, 175 insertions(+), 87 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 2801fb5652..f4620d0868 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -274,19 +274,13 @@ def on_representation_id_changed(node): def get_node_expected_representation_id(node) -> str: project_name = node.evalParm( "project_name") or get_current_project_name() - representation_id = get_representation_id( - project_name=project_name, - folder_path=node.evalParm("folder_path"), - product_name=node.evalParm("product_name"), - version=node.evalParm("version"), - representation_name=node.evalParm("representation_name"), - load_message_parm=node.parm("load_message") + return get_representation_id( + project_name=project_name, + folder_path=node.evalParm("folder_path"), + product_name=node.evalParm("product_name"), + version=node.evalParm("version"), + representation_name=node.evalParm("representation_name"), ) - if representation_id is None: - representation_id = "" - else: - representation_id = str(representation_id) - return representation_id def get_representation_id( @@ -295,7 +289,6 @@ def get_representation_id( product_name, version, representation_name, - load_message_parm, ): """Get representation id. @@ -305,19 +298,14 @@ def get_representation_id( product_name (str): Product name version (str): Version name as string representation_name (str): Representation name - load_message_parm (hou.Parm): A string message parm to report - any error messages to. Returns: - Optional[str]: Representation id or None if not found. + str: Representation id or None if not found. - """ - # TODO: This is now used in an expression in LOPs and preferably should - # not trigger setting additional parameters. As such, we should maybe - # somehow offload the warning message to the "cook" or some other way - # of identifying whether the parms are all valid without requiring - # more queries of the database. + Raises: + ValueError: If the entity could not be resolved with input values. + """ if not all([ project_name, folder_path, product_name, version, representation_name ]): @@ -329,15 +317,14 @@ def get_representation_id( "representation": representation_name } missing = ", ".join(key for key, value in labels.items() if not value) - load_message_parm.set(f"Load info incomplete. Found empty: {missing}") - return + raise ValueError(f"Load info incomplete. Found empty: {missing}") try: version = int(version.strip()) except ValueError: - load_message_parm.set(f"Invalid version format: '{version}'\n" - "Make sure to set a valid version number.") - return + raise ValueError( + f"Invalid version format: '{version}'\n" + "Make sure to set a valid version number.") folder_entity = get_folder_by_path(project_name, folder_path=folder_path, @@ -346,10 +333,8 @@ def get_representation_id( # This may be due to the project not existing - so let's validate # that first if not get_project(project_name): - load_message_parm.set(f"Project not found: '{project_name}'") - return - load_message_parm.set(f"Folder not found: '{folder_path}'") - return + raise ValueError(f"Project not found: '{project_name}'") + raise ValueError(f"Folder not found: '{folder_path}'") product_entity = get_product_by_name( project_name, @@ -357,25 +342,23 @@ def get_representation_id( folder_id=folder_entity["id"], fields={"id"}) if not product_entity: - load_message_parm.set(f"Product not found: '{product_name}'") - return + raise ValueError(f"Product not found: '{product_name}'") + version_entity = get_version_by_name( project_name, version, product_id=product_entity["id"], fields={"id"}) if not version_entity: - load_message_parm.set(f"Version not found: '{version}'") - return + raise ValueError(f"Version not found: '{version}'") + representation_entity = get_representation_by_name( project_name, representation_name, version_id=version_entity["id"], fields={"id"}) if not representation_entity: - load_message_parm.set( - f"Representation not found: '{representation_name}'.") - return + raise ValueError(f"Representation not found: '{representation_name}'.") return representation_entity["id"] @@ -750,7 +733,12 @@ def expression_get_representation_id() -> str: if hash_value in cache: return cache[hash_value] - repre_id = get_node_expected_representation_id(node) + try: + repre_id = get_node_expected_representation_id(node) + except ValueError: + # Ignore invalid parameters + repre_id = "" + cache[hash_value] = repre_id diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes index 2d6bdf00aa..3047376d77 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes @@ -1,6 +1,7 @@ { + "hdaroot/switch_load_warnings.def":1728298521, "hdaroot/warn_no_representation_set.def":1708980551, - "hdaroot/reference.def":1698150558, "hdaroot/output0.def":1698215383, - "hdaroot.def":1717451587 + "hdaroot.def":1728285340, + "hdaroot/reference.def":1698150558 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions index fb7f024db3..5c591db892 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions @@ -1,9 +1,10 @@ { - "values":["20.0.703" + "values":["20.5.370" ], "indexes":{ - "hdaroot/warn_no_representation_set.userdata":0, + "hdaroot/output0.userdata":0, + "hdaroot/switch_load_warnings.userdata":0, "hdaroot/reference.userdata":0, - "hdaroot/output0.userdata":0 + "hdaroot/warn_no_representation_set.userdata":0 } } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime index ec12230a75..1f6aea588a 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime @@ -19,26 +19,28 @@ Content-Disposition: attachment; filename="hdaroot.def" Content-Type: text/plain comment "" -position -1.67827 1.26636 -connectornextid 0 +position -4.36447 -0.693346 +connectornextid 1 flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } inputsNamed3 { +0 cube1 0 1 "input1" } inputs { +0 cube1 0 1 } stat { create -1 modify -1 - author Mustafa_Taher@Major-Kalawy + author User@HP-Z820-03 access 0777 } -color UT_Color RGB 0.8 0.8 0.8 +color UT_Color RGB 0.8 0.8 0.8 delscript "" exprlanguage hscript end @@ -77,9 +79,9 @@ Content-Disposition: attachment; filename="hdaroot/output0.def" Content-Type: text/plain comment "" -position -1.13898e-08 2.03328 +position -0.346993 0.925092 connectornextid 1 -flags = lock off model off template off footprint off xray off bypass off display off render on highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } @@ -98,7 +100,7 @@ stat author Maqina-05@Maqina-05 access 0777 } -color UT_Color RGB 0.8 0.8 0.8 +color UT_Color RGB 0.8 0.8 0.8 delscript "" exprlanguage hscript end @@ -136,7 +138,7 @@ Content-Disposition: attachment; filename="hdaroot/reference.def" Content-Type: text/plain comment "" -position -0.00125004 4.19692 +position -0.348243 2.45537 connectornextid 2 flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 @@ -145,11 +147,11 @@ outputsNamed3 } inputsNamed3 { -1 warn_no_representation_set 1 1 "input1" +1 switch_load_warnings 1 1 "input1" } inputs { -0 warn_no_representation_set 0 1 +0 switch_load_warnings 0 1 } stat { @@ -158,7 +160,7 @@ stat author Maqina-05@Maqina-05 access 0777 } -color UT_Color RGB 0.8 0.8 0.8 +color UT_Color RGB 0.8 0.8 0.8 delscript "" exprlanguage hscript end @@ -302,9 +304,9 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.de Content-Type: text/plain comment "" -position -1.13898e-08 5.20999 +position 1.06093 5.41052 connectornextid 2 -flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { 1 "output1" @@ -324,7 +326,7 @@ stat author User@HP-Z820-03 access 0777 } -color UT_Color RGB 0.8 0.8 0.8 +color UT_Color RGB 0.8 0.8 0.8 delscript "" exprlanguage hscript end @@ -334,12 +336,31 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.ch Content-Type: text/plain { - channel enable1 { + channel errormsg1 { lefttype = extend righttype = extend + defaultString = "\"from ayon_houdini.api import hda_utils + +# Parent node +node = hou.pwd().parent() +try: + hda_utils.get_node_expected_representation_id(node) +except ValueError as exc: + return str(exc) + +return \\\"Unable to get representation\\\"\"" flags = 0 - start = 39.800000000000004 - segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } + start = 40 + segment { length = 0 expr = "from ayon_houdini.api import hda_utils + +# Parent node +node = hou.pwd().parent() +try: + hda_utils.get_node_expected_representation_id(node) +except ValueError as exc: + return str(exc) + +return \"Unable to get representation.\"" language = python } } } @@ -350,9 +371,9 @@ Content-Type: text/plain { version 0.8 numerror [ 0 locks=0 ] ( 1 ) -errormsg1 [ 0 locks=0 ] ( `chs(\"../load_message\")` ) +errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) severity1 [ 0 locks=0 ] ( "warn" ) -enable1 [ 0 locks=0 ] ( [ enable1 0 ] ) +enable1 [ 0 locks=0 ] ( 1 ) } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY @@ -366,14 +387,109 @@ Content-Type: text/plain } } +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.init" +Content-Type: text/plain + +type = switch +matchesdef = 1 + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.def" +Content-Type: text/plain + +comment "" +position -0.154899 4.11657 +connectornextid 3 +flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off +outputsNamed3 +{ +1 "output1" +} +inputsNamed3 +{ +2 (0) "" 1 "input1" +0 warn_no_representation_set 1 1 "input2" +} +inputs +{ +0 (0) 0 1 +1 warn_no_representation_set 0 1 +} +stat +{ + create -1 + modify -1 + author User@HP-Z820-03 + access 0777 +} +color UT_Color RGB 0.8 1 0.7 +delscript "" +exprlanguage hscript +end + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.editableinputdata" +Content-Type: text/plain + +[ + { + }, + { + } +] + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.chn" +Content-Type: text/plain + +{ + channel input { + lefttype = extend + righttype = extend + flags = 0 + start = 40 + segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } + } + } + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.parm" +Content-Type: text/plain + +{ +version 0.8 +chooseinputbyname [ 0 locks=0 ] ( "off" ) +input [ 0 locks=0 ] ( [ input 0 ] ) +selectinputname [ 0 locks=0 ] ( "" ) +selectinputvalue [ 0 locks=0 ] ( "" ) +config_separator [ 0 locks=0 ] ( ) +badinput [ 0 locks=0 ] ( ignore ) +fallback [ 0 locks=0 ] ( 0 ) +selectfallbackname [ 0 locks=0 ] ( "" ) +inputname [ 0 locks=0 ] ( "`opinput(\".\", @input)`" ) +} + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.userdata" +Content-Type: text/plain + +{ + "___Version___":{ + "type":"string", + "value":"___EXTERNAL___" + } +} + --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot.order" Content-Type: text/plain -3 +4 output0 reference warn_no_representation_set +switch_load_warnings --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot.net" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes index dbbe22dd33..bfe25fab51 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes @@ -1,6 +1,7 @@ { - "hdaroot/warn_no_representation_set.def":1711565807, - "hdaroot/reference.def":1711565598, - "hdaroot/output0.def":1708980807, - "hdaroot.def":1717451686 + "hdaroot/switch_load_warnings.def":1728299309, + "hdaroot/warn_no_representation_set.def":1728299277, + "hdaroot/output0.def":1728299301, + "hdaroot.def":1728299413, + "hdaroot/reference.def":1728299301 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index 392ddb09a6..e475f8e1f1 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -83,25 +83,6 @@ type string default { "usd" } } - parm { - name "load_refresh" - label "Refresh" - type button - joinnext - default { "0" } - help "Click to refresh and retry applying the product load parameters to load the correct file" - parmtag { "button_icon" "" } - parmtag { "script_callback" "" } - parmtag { "script_callback_language" "python" } - } - parm { - name "load_message" - label "Message" - type label - default { "" } - hidewhen "{ load_message == \"\" }" - parmtag { "sidefx::look" "block" } - } parm { name "sepparm" label "Separator" From d1587bbfbf795d13ccf52819d8235b5d7ae481fa Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 15:26:33 +0200 Subject: [PATCH 08/15] Fix shown warning on the LOP node by force computing them when needed (now for Load Shot LOP) --- .../Contents.dir/Contents.createtimes | 3 +- .../Contents.dir/Contents.houdini_versions | 7 +- .../Contents.dir/Contents.mime | 257 +++++++++++++----- .../Contents.dir/Contents.modtimes | 9 +- .../DialogScript | 19 +- 5 files changed, 197 insertions(+), 98 deletions(-) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes index 3b50c1d798..6b4cc961c5 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes @@ -1,6 +1,7 @@ { + "hdaroot/switch_load_warnings.def":1728298521, "hdaroot/sublayer.def":1720045839, "hdaroot/warn_no_representation_set.def":1708980551, "hdaroot/output0.def":1698215383, - "hdaroot.def":1720046536 + "hdaroot.def":1728307343 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions index c685293feb..b7dda90c76 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions @@ -1,9 +1,10 @@ { - "values":["20.0.724" + "values":["20.5.370" ], "indexes":{ + "hdaroot/output0.userdata":0, + "hdaroot/switch_load_warnings.userdata":0, "hdaroot/sublayer.userdata":0, - "hdaroot/warn_no_representation_set.userdata":0, - "hdaroot/output0.userdata":0 + "hdaroot/warn_no_representation_set.userdata":0 } } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime index d890e71afa..8ecf304212 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime @@ -19,12 +19,11 @@ Content-Disposition: attachment; filename="hdaroot.def" Content-Type: text/plain comment "" -position -3.46569 1.07549 -connectornextid 1 -flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off +position -0.987179 -0.326068 +connectornextid 0 +flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { -0 "output1" } inputsNamed3 { @@ -82,9 +81,9 @@ Content-Disposition: attachment; filename="hdaroot/output0.def" Content-Type: text/plain comment "" -position -1.13898e-08 2.03328 +position -1.18363 1.36997 connectornextid 1 -flags = lock off model off template off footprint off xray off bypass off display off render on highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } @@ -129,6 +128,122 @@ Content-Type: text/plain } } +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/sublayer.init" +Content-Type: text/plain + +type = sublayer +matchesdef = 1 + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/sublayer.def" +Content-Type: text/plain + +comment "" +position -1.18488 2.62985 +connectornextid 2 +flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off +outputsNamed3 +{ +1 "output1" +} +inputsNamed3 +{ +0 switch_load_warnings 1 1 "input1" +} +inputs +{ +0 switch_load_warnings 0 1 +} +stat +{ + create -1 + modify -1 + author User@HP-Z820-03 + access 0777 +} +color UT_Color RGB 0.8 0.8 0.8 +delscript "" +exprlanguage hscript +end + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/sublayer.chn" +Content-Type: text/plain + +{ + channel reload { + lefttype = extend + righttype = extend + flags = 0 + start = 40 + segment { length = 0 expr = ch(\"../reload\") } + } + channel mute1 { + lefttype = extend + righttype = extend + flags = 0 + start = 40 + segment { length = 0 expr = ch(\"../mute1\") } + } + channel timeoffset1 { + lefttype = extend + righttype = extend + flags = 0 + start = 40 + segment { length = 0 expr = ch(\"../timeoffset1\") } + } + channel timescale1 { + lefttype = extend + righttype = extend + default = 1 + flags = 0 + start = 40 + segment { length = 0 value = 1 1 expr = ch(\"../timescale1\") } + } + } + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/sublayer.parm" +Content-Type: text/plain + +{ +version 0.8 +parentlayer_group [ 0 locks=0 ] ( 0 ) +loadpayloads [ 0 locks=0 ] ( "on" ) +setstagemetadata [ 0 locks=0 ] ( auto ) +editrootlayer [ 0 locks=0 ] ( "on" ) +findsublayers [ 0 locks=0 ] ( "" ) +removefoundsublayers [ 0 locks=0 ] ( "on" ) +composition_group [ 0 locks=0 ] ( 0 ) +sublayertype [ 0 locks=0 ] ( filesandinputs ) +handlemissingfiles [ 0 locks=0 ] ( error ) +positiontype [ 0 locks=0 ] ( strongest ) +positionindex [ 0 locks=0 ] ( 0 ) +files_separator [ 0 locks=0 ] ( ) +num_files [ 0 locks=0 ] ( 1 ) +reload [ 0 locks=0 ] ( [ reload 0 ] ) +inputs_separator [ 0 locks=0 ] ( ) +enable [ 0 locks=0 ] ( "on" ) +sublayerfile_group1 [ 0 locks=0 ] ( 1 ) +enable1 [ 0 locks=0 ] ( "on" ) +filepath1 [ 0 locks=0 ] ( `chs(\"../file\")` ) +mute1 [ 0 locks=0 ] ( [ mute1 0 ] ) +timeoffset1 [ 0 locks=0 ] ( [ timeoffset1 0 ] ) +timescale1 [ 0 locks=0 ] ( [ timescale1 1 ] ) +} + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/sublayer.userdata" +Content-Type: text/plain + +{ + "___Version___":{ + "type":"string", + "value":"___EXTERNAL___" + } +} + --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.init" Content-Type: text/plain @@ -141,9 +256,9 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.de Content-Type: text/plain comment "" -position -1.13898e-08 5.20999 +position 0.0322012 4.82456 connectornextid 2 -flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { 1 "output1" @@ -173,12 +288,31 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.ch Content-Type: text/plain { - channel enable1 { + channel errormsg1 { lefttype = extend righttype = extend + defaultString = "\"from ayon_houdini.api import hda_utils + +# Parent node +node = hou.pwd().parent() +try: + hda_utils.get_node_expected_representation_id(node) +except ValueError as exc: + return str(exc) + +return \\\"Unable to get representation\\\"\"" flags = 0 - start = 39.800000000000004 - segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } + start = 40 + segment { length = 0 expr = "from ayon_houdini.api import hda_utils + +# Parent node +node = hou.pwd().parent() +try: + hda_utils.get_node_expected_representation_id(node) +except ValueError as exc: + return str(exc) + +return \"Unable to get representation.\"" language = python } } } @@ -189,9 +323,9 @@ Content-Type: text/plain { version 0.8 numerror [ 0 locks=0 ] ( 1 ) -errormsg1 [ 0 locks=0 ] ( `chs(\"../load_message\")` ) +errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) severity1 [ 0 locks=0 ] ( "warn" ) -enable1 [ 0 locks=0 ] ( [ enable1 0 ] ) +enable1 [ 0 locks=0 ] ( 1 ) } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY @@ -206,19 +340,19 @@ Content-Type: text/plain } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/sublayer.init" +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.init" Content-Type: text/plain -type = sublayer +type = switch matchesdef = 1 --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/sublayer.def" +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.def" Content-Type: text/plain comment "" -position -0.00125004 4.03316 -connectornextid 2 +position -1.18363 3.53061 +connectornextid 3 flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { @@ -226,11 +360,13 @@ outputsNamed3 } inputsNamed3 { -0 warn_no_representation_set 1 1 "input1" +2 (0) "" 1 "input1" +0 warn_no_representation_set 1 1 "input2" } inputs { -0 warn_no_representation_set 0 1 +0 (0) 0 1 +1 warn_no_representation_set 0 1 } stat { @@ -239,79 +375,55 @@ stat author User@HP-Z820-03 access 0777 } -color UT_Color RGB 0.8 0.8 0.8 +color UT_Color RGB 0.8 1 0.7 delscript "" exprlanguage hscript end --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/sublayer.chn" +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.editableinputdata" +Content-Type: text/plain + +[ + { + }, + { + } +] + +--HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.chn" Content-Type: text/plain { - channel reload { - lefttype = extend - righttype = extend - flags = 0 - start = 40 - segment { length = 0 expr = ch(\"../reload\") } - } - channel mute1 { - lefttype = extend - righttype = extend - flags = 0 - start = 40 - segment { length = 0 expr = ch(\"../mute1\") } - } - channel timeoffset1 { + channel input { lefttype = extend righttype = extend flags = 0 start = 40 - segment { length = 0 expr = ch(\"../timeoffset1\") } - } - channel timescale1 { - lefttype = extend - righttype = extend - default = 1 - flags = 0 - start = 40 - segment { length = 0 value = 1 1 expr = ch(\"../timescale1\") } + segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } } } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/sublayer.parm" +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.parm" Content-Type: text/plain { version 0.8 -parentlayer_group [ 0 locks=0 ] ( 0 ) -loadpayloads [ 0 locks=0 ] ( "on" ) -setstagemetadata [ 0 locks=0 ] ( auto ) -editrootlayer [ 0 locks=0 ] ( "on" ) -findsublayers [ 0 locks=0 ] ( "" ) -removefoundsublayers [ 0 locks=0 ] ( "on" ) -composition_group [ 0 locks=0 ] ( 0 ) -sublayertype [ 0 locks=0 ] ( filesandinputs ) -handlemissingfiles [ 0 locks=0 ] ( error ) -positiontype [ 0 locks=0 ] ( strongest ) -positionindex [ 0 locks=0 ] ( 0 ) -files_separator [ 0 locks=0 ] ( ) -num_files [ 0 locks=0 ] ( 1 ) -reload [ 0 locks=0 ] ( [ reload 0 ] ) -inputs_separator [ 0 locks=0 ] ( ) -enable [ 0 locks=0 ] ( "on" ) -sublayerfile_group1 [ 0 locks=0 ] ( 1 ) -enable1 [ 0 locks=0 ] ( "on" ) -filepath1 [ 0 locks=0 ] ( `chs(\"../file\")` ) -mute1 [ 0 locks=0 ] ( [ mute1 0 ] ) -timeoffset1 [ 0 locks=0 ] ( [ timeoffset1 0 ] ) -timescale1 [ 0 locks=0 ] ( [ timescale1 1 ] ) +chooseinputbyname [ 0 locks=0 ] ( "off" ) +input [ 0 locks=0 ] ( [ input 0 ] ) +selectinputname [ 0 locks=0 ] ( "" ) +selectinputvalue [ 0 locks=0 ] ( "" ) +config_separator [ 0 locks=0 ] ( ) +badinput [ 0 locks=0 ] ( ignore ) +fallback [ 0 locks=0 ] ( 0 ) +selectfallbackname [ 0 locks=0 ] ( "" ) +inputname [ 0 locks=0 ] ( "`opinput(\".\", @input)`" ) } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/sublayer.userdata" +Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.userdata" Content-Type: text/plain { @@ -325,10 +437,11 @@ Content-Type: text/plain Content-Disposition: attachment; filename="hdaroot.order" Content-Type: text/plain -3 +4 output0 -warn_no_representation_set sublayer +warn_no_representation_set +switch_load_warnings --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot.net" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes index 5ac7842a55..75c57beaa5 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes @@ -1,6 +1,7 @@ { - "hdaroot/sublayer.def":1720045978, - "hdaroot/warn_no_representation_set.def":1720045871, - "hdaroot/output0.def":1720045871, - "hdaroot.def":1720046571 + "hdaroot/switch_load_warnings.def":1728307536, + "hdaroot/sublayer.def":1728307536, + "hdaroot/warn_no_representation_set.def":1728307536, + "hdaroot/output0.def":1728307536, + "hdaroot.def":1728307791 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index b23a95dd43..ea59aff1b3 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -77,23 +77,6 @@ type string default { "usd" } } - parm { - name "load_refresh" - label "Refresh" - type button - joinnext - default { "0" } - help "Click to refresh and retry applying the product load parameters to load the correct file" - parmtag { "button_icon" "" } - } - parm { - name "load_message" - label "Message" - type label - default { "" } - hidewhen "{ load_message == \"\" }" - parmtag { "sidefx::look" "block" } - } parm { name "sepparm" label "Separator" @@ -118,9 +101,9 @@ parm { name "use_ayon_entity_uri" label "Use AYON Entity URI" - help "When enabled, loads the filepath using the AYON Entity URI instead of the resolved filepath." type toggle default { "0" } + help "When enabled, loads the filepath using the AYON Entity URI instead of the resolved filepath." } groupcollapsible { name "extra_options" From b8fae23c46c91d76c2f2ab582ff28f0425463226 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 15:27:56 +0200 Subject: [PATCH 09/15] Remove unused context manager --- client/ayon_houdini/api/hda_utils.py | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index f4620d0868..305789c1d9 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -1,7 +1,6 @@ """Helper functions for load HDA""" import os -import contextlib import uuid from typing import List @@ -50,16 +49,6 @@ def is_valid_uuid(value) -> bool: return True -@contextlib.contextmanager -def _unlocked_parm(parm): - """Unlock parm during context; will always lock after""" - try: - parm.lock(False) - yield - finally: - parm.lock(True) - - def get_available_versions(node): """Return the versions list for node. From 58ee40ed2013146dbe97a28f3464c01cf6df23ca Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Mon, 7 Oct 2024 17:39:08 +0200 Subject: [PATCH 10/15] Cleanup --- client/ayon_houdini/api/hda_utils.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 305789c1d9..0018233736 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -96,7 +96,7 @@ def get_available_versions(node): return version_names -def update_info(node, context): +def set_node_representation_from_context(node, context): """Update project, folder, product, version, representation name parms. Arguments: @@ -125,11 +125,6 @@ def update_info(node, context): } parms = {key: value for key, value in parms.items() if node.evalParm(key) != value} - parms["load_message"] = "" # clear any warnings/errors - - # Note that these never trigger any parm callbacks since we do not - # trigger the `parm.pressButton` and programmatically setting values - # in Houdini does not trigger callbacks automatically node.setParms(parms) @@ -179,6 +174,11 @@ def get_representation_path( def set_representation(node, representation_id: str): + # For now this only updates the thumbnail, but it may update more over time + _update_thumbnail(node, representation_id) + + +def _update_thumbnail(node, representation_id): # TODO: Unused currently; add support again for thumbnail updates if not representation_id: set_node_thumbnail(node, None) @@ -189,9 +189,6 @@ def set_representation(node, representation_id: str): or get_current_project_name() ) repre_entity = get_representation_by_id(project_name, representation_id) - context = get_representation_context(project_name, repre_entity) - update_info(node, context) - if node.evalParm("show_thumbnail"): # Update thumbnail # TODO: Cache thumbnail path as well @@ -743,3 +740,6 @@ def expression_get_representation_path() -> str: path = get_representation_path(project_name, repre_id, use_entity_uri) cache[hash_value] = path return path + +# endregion + From 15282367c66b8eb86b9776f56a4e49b6a3e631ff Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Tue, 22 Oct 2024 01:18:36 +0200 Subject: [PATCH 11/15] Fix warnings persisting on nodes + cleanup --- client/ayon_houdini/api/hda_utils.py | 88 +++++------- .../otls/ayon_lop_import.hda/INDEX__SECTION | 2 +- .../Contents.dir/Contents.createtimes | 3 +- .../Contents.dir/Contents.houdini_versions | 1 - .../Contents.dir/Contents.mime | 130 +++-------------- .../Contents.dir/Contents.modtimes | 9 +- .../DialogScript | 2 - .../MessageNodes | 2 +- .../ayon_8_8Lop_1lop__import_8_81.0/OnLoaded | 2 +- .../PythonModule | 10 +- .../ayon_lop_load_shot.hda/INDEX__SECTION | 2 +- .../Contents.dir/Contents.createtimes | 3 +- .../Contents.dir/Contents.houdini_versions | 1 - .../Contents.dir/Contents.mime | 132 ++++-------------- .../Contents.dir/Contents.modtimes | 9 +- .../DialogScript | 2 - .../ayon_8_8Lop_1load__shot_8_81.0/OnLoaded | 2 +- .../PythonModule | 10 +- 18 files changed, 99 insertions(+), 311 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 0018233736..3e9cfb90c5 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -1,9 +1,12 @@ -"""Helper functions for load HDA""" +"""Heper functions for load HDA""" import os import uuid from typing import List +import hou +from qtpy import QtCore, QtWidgets, QtGui + import ayon_api from ayon_api import ( get_project, @@ -14,23 +17,19 @@ get_version_by_name, get_representation_by_name ) -from ayon_core.pipeline.load import ( - get_representation_context, - get_representation_path_from_context -) from ayon_core.pipeline.context_tools import ( get_current_project_name, get_current_folder_path ) -from ayon_core.tools.utils import SimpleFoldersWidget +from ayon_core.pipeline.load import ( + get_representation_context, + get_representation_path_from_context +) from ayon_core.style import load_stylesheet - +from ayon_core.tools.utils import SimpleFoldersWidget from ayon_houdini.api import lib from .usd import get_ayon_entity_uri_from_representation_context -from qtpy import QtCore, QtWidgets, QtGui -import hou - def get_session_cache() -> dict: """Get a persistent `hou.session.ayon_cache` dict""" @@ -128,25 +127,6 @@ def set_node_representation_from_context(node, context): node.setParms(parms) -def _get_thumbnail(project_name: str, version_id: str, thumbnail_dir: str): - folder = hou.text.expandString(thumbnail_dir) - path = os.path.join(folder, "{}_thumbnail.jpg".format(version_id)) - expanded_path = hou.text.expandString(path) - if os.path.isfile(expanded_path): - return path - - # Try and create a thumbnail cache file - data = ayon_api.get_thumbnail(project_name, - entity_type="version", - entity_id=version_id) - if data: - thumbnail_dir_expanded = hou.text.expandString(thumbnail_dir) - os.makedirs(thumbnail_dir_expanded, exist_ok=True) - with open(expanded_path, "wb") as f: - f.write(data.content) - return path - - def get_representation_path( project_name: str, representation_id: str, @@ -173,13 +153,31 @@ def get_representation_path( return path -def set_representation(node, representation_id: str): - # For now this only updates the thumbnail, but it may update more over time - _update_thumbnail(node, representation_id) +def _get_thumbnail(project_name: str, version_id: str, thumbnail_dir: str): + folder = hou.text.expandString(thumbnail_dir) + path = os.path.join(folder, "{}_thumbnail.jpg".format(version_id)) + expanded_path = hou.text.expandString(path) + if os.path.isfile(expanded_path): + return path + + # Try and create a thumbnail cache file + data = ayon_api.get_thumbnail(project_name, + entity_type="version", + entity_id=version_id) + if data: + thumbnail_dir_expanded = hou.text.expandString(thumbnail_dir) + os.makedirs(thumbnail_dir_expanded, exist_ok=True) + with open(expanded_path, "wb") as f: + f.write(data.content) + return path + +def update_thumbnail(node): + if not node.evalParm("show_thumbnail"): + lib.remove_all_thumbnails(node) + return -def _update_thumbnail(node, representation_id): - # TODO: Unused currently; add support again for thumbnail updates + representation_id = node.evalParm("representation") if not representation_id: set_node_thumbnail(node, None) return @@ -231,11 +229,7 @@ def compute_thumbnail_rect(node): def on_thumbnail_show_changed(node): """Callback on thumbnail show parm changed""" - if node.evalParm("show_thumbnail"): - # For now, update all - on_representation_id_changed(node) - else: - lib.remove_all_thumbnails(node) + update_thumbnail(node) def on_thumbnail_size_changed(node): @@ -247,16 +241,6 @@ def on_thumbnail_size_changed(node): lib.set_node_thumbnail(node, thumbnail) -def on_representation_id_changed(node): - """Callback on representation id changed - - Args: - node (hou.Node): Node to update. - """ - repre_id = node.evalParm("representation") - set_representation(node, repre_id) - - def get_node_expected_representation_id(node) -> str: project_name = node.evalParm( "project_name") or get_current_project_name() @@ -730,9 +714,9 @@ def expression_get_representation_id() -> str: def expression_get_representation_path() -> str: cache = get_session_cache().setdefault("representation_path", {}) - project_name = hou.evalParm("project_name") - repre_id = hou.evalParm("representation") - use_entity_uri = hou.evalParm("use_ayon_entity_uri") + project_name: str = hou.evalParm("project_name") + repre_id: str = hou.evalParm("representation") + use_entity_uri = bool(hou.evalParm("use_ayon_entity_uri")) hash_value = project_name, repre_id, use_entity_uri if hash_value in cache: return cache[hash_value] diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION index f101cdfeb0..bc13be663e 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/INDEX__SECTION @@ -10,5 +10,5 @@ Inputs: 0 to 1 Subnet: true Python: false Empty: false -Modified: Tue Jul 30 12:57:14 2024 +Modified: Tue Oct 22 01:07:36 2024 diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes index 3047376d77..2077693610 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.createtimes @@ -1,7 +1,6 @@ { - "hdaroot/switch_load_warnings.def":1728298521, "hdaroot/warn_no_representation_set.def":1708980551, "hdaroot/output0.def":1698215383, - "hdaroot.def":1728285340, + "hdaroot.def":1729551657, "hdaroot/reference.def":1698150558 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions index 5c591db892..8e223913b8 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.houdini_versions @@ -3,7 +3,6 @@ ], "indexes":{ "hdaroot/output0.userdata":0, - "hdaroot/switch_load_warnings.userdata":0, "hdaroot/reference.userdata":0, "hdaroot/warn_no_representation_set.userdata":0 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime index 1f6aea588a..1b6f91d97a 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.mime @@ -19,19 +19,17 @@ Content-Disposition: attachment; filename="hdaroot.def" Content-Type: text/plain comment "" -position -4.36447 -0.693346 -connectornextid 1 +position -3.95588 0.372876 +connectornextid 0 flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } inputsNamed3 { -0 cube1 0 1 "input1" } inputs { -0 cube1 0 1 } stat { @@ -81,7 +79,7 @@ Content-Type: text/plain comment "" position -0.346993 0.925092 connectornextid 1 -flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display off render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } @@ -147,11 +145,11 @@ outputsNamed3 } inputsNamed3 { -1 switch_load_warnings 1 1 "input1" +1 warn_no_representation_set 1 1 "input1" } inputs { -0 switch_load_warnings 0 1 +0 warn_no_representation_set 0 1 } stat { @@ -304,9 +302,9 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.de Content-Type: text/plain comment "" -position 1.06093 5.41052 +position -0.346993 4.50044 connectornextid 2 -flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { 1 "output1" @@ -355,123 +353,40 @@ return \\\"Unable to get representation\\\"\"" # Parent node node = hou.pwd().parent() +if node.evalParm(\"representation\"): + return \"\" + try: hda_utils.get_node_expected_representation_id(node) except ValueError as exc: return str(exc) - -return \"Unable to get representation.\"" language = python } +else: + return \"\"" language = python } } - } - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.parm" -Content-Type: text/plain - -{ -version 0.8 -numerror [ 0 locks=0 ] ( 1 ) -errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) -severity1 [ 0 locks=0 ] ( "warn" ) -enable1 [ 0 locks=0 ] ( 1 ) -} - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.userdata" -Content-Type: text/plain - -{ - "___Version___":{ - "type":"string", - "value":"___EXTERNAL___" - } -} - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.init" -Content-Type: text/plain - -type = switch -matchesdef = 1 - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.def" -Content-Type: text/plain - -comment "" -position -0.154899 4.11657 -connectornextid 3 -flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off -outputsNamed3 -{ -1 "output1" -} -inputsNamed3 -{ -2 (0) "" 1 "input1" -0 warn_no_representation_set 1 1 "input2" -} -inputs -{ -0 (0) 0 1 -1 warn_no_representation_set 0 1 -} -stat -{ - create -1 - modify -1 - author User@HP-Z820-03 - access 0777 -} -color UT_Color RGB 0.8 1 0.7 -delscript "" -exprlanguage hscript -end - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.editableinputdata" -Content-Type: text/plain - -[ - { - }, - { - } -] - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.chn" -Content-Type: text/plain - -{ - channel input { + channel enable1 { lefttype = extend righttype = extend + default = 1 flags = 0 start = 40 - segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } + segment { length = 0 value = 1 1 expr = "strlen(chs(\"../representation\")) == 0" } } } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.parm" +Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.parm" Content-Type: text/plain { version 0.8 -chooseinputbyname [ 0 locks=0 ] ( "off" ) -input [ 0 locks=0 ] ( [ input 0 ] ) -selectinputname [ 0 locks=0 ] ( "" ) -selectinputvalue [ 0 locks=0 ] ( "" ) -config_separator [ 0 locks=0 ] ( ) -badinput [ 0 locks=0 ] ( ignore ) -fallback [ 0 locks=0 ] ( 0 ) -selectfallbackname [ 0 locks=0 ] ( "" ) -inputname [ 0 locks=0 ] ( "`opinput(\".\", @input)`" ) +numerror [ 0 locks=0 ] ( 1 ) +errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) +severity1 [ 0 locks=0 ] ( "warn" ) +enable1 [ 0 locks=0 ] ( [ enable1 0 ] ) } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.userdata" +Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.userdata" Content-Type: text/plain { @@ -485,11 +400,10 @@ Content-Type: text/plain Content-Disposition: attachment; filename="hdaroot.order" Content-Type: text/plain -4 +3 output0 reference warn_no_representation_set -switch_load_warnings --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot.net" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes index bfe25fab51..a1ed4d0189 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/Contents.dir/Contents.modtimes @@ -1,7 +1,6 @@ { - "hdaroot/switch_load_warnings.def":1728299309, - "hdaroot/warn_no_representation_set.def":1728299277, - "hdaroot/output0.def":1728299301, - "hdaroot.def":1728299413, - "hdaroot/reference.def":1728299301 + "hdaroot/warn_no_representation_set.def":1729552033, + "hdaroot/output0.def":1729551715, + "hdaroot.def":1729552052, + "hdaroot/reference.def":1729552032 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index e475f8e1f1..bb8ffe2a73 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -269,8 +269,6 @@ label "Show Pipeline Parms" type toggle default { "0" } - parmtag { "script_callback" "hou.phm().on_thumbnail_show_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/MessageNodes b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/MessageNodes index ff389a716b..6941746e05 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/MessageNodes +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/MessageNodes @@ -1 +1 @@ -warn_no_representation_set reference +warn_no_representation_set reference \ No newline at end of file diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/OnLoaded b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/OnLoaded index 42e3c6e640..4c77009400 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/OnLoaded +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/OnLoaded @@ -7,7 +7,7 @@ hda_module.setup_flag_changed_callback(node) def on_duplicate(): """Duplicate thumbnail on node duplicate""" if node.evalParm("show_thumbnail") and node.evalParm("representation"): - hda_module.on_representation_id_changed(node) + hda_module.update_thumbnail(node) if not hou.hipFile.isLoadingHipFile(): diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule index 901c00e19d..8b13789179 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule @@ -1,9 +1 @@ -from ayon_houdini.api.hda_utils import ( - on_thumbnail_show_changed, - on_thumbnail_size_changed, - on_representation_id_changed, - setup_flag_changed_callback, - get_available_versions, - select_product_name, - set_to_latest_version -) + diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/INDEX__SECTION b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/INDEX__SECTION index 73ccafc80b..b4d6467b34 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/INDEX__SECTION +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/INDEX__SECTION @@ -10,5 +10,5 @@ Inputs: 0 to 1 Subnet: true Python: false Empty: false -Modified: Thu Jul 4 00:43:25 2024 +Modified: Tue Oct 22 01:11:23 2024 diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes index 6b4cc961c5..a046bdeced 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.createtimes @@ -1,7 +1,6 @@ { - "hdaroot/switch_load_warnings.def":1728298521, "hdaroot/sublayer.def":1720045839, "hdaroot/warn_no_representation_set.def":1708980551, "hdaroot/output0.def":1698215383, - "hdaroot.def":1728307343 + "hdaroot.def":1729552120 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions index b7dda90c76..3b6b0e7d79 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.houdini_versions @@ -3,7 +3,6 @@ ], "indexes":{ "hdaroot/output0.userdata":0, - "hdaroot/switch_load_warnings.userdata":0, "hdaroot/sublayer.userdata":0, "hdaroot/warn_no_representation_set.userdata":0 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime index 8ecf304212..1675bbd4e0 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.mime @@ -19,9 +19,9 @@ Content-Disposition: attachment; filename="hdaroot.def" Content-Type: text/plain comment "" -position -0.987179 -0.326068 +position -4.13562 1.50033 connectornextid 0 -flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } @@ -67,7 +67,7 @@ Content-Disposition: attachment; filename="hdaroot.inp" Content-Type: text/plain 1 -0 -1.3044269152357999 6.2635205889365251 2 0 __NO_OWNER_NETWORK_BOX__ "FROMOUTPUT" +0 -1.18363 4.7584699999999991 2 0 __NO_OWNER_NETWORK_BOX__ "FROMOUTPUT" --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot/output0.init" @@ -83,7 +83,7 @@ Content-Type: text/plain comment "" position -1.18363 1.36997 connectornextid 1 -flags = lock off model off template off footprint off xray off bypass off display on render on highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display off render on highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { } @@ -140,7 +140,7 @@ Content-Disposition: attachment; filename="hdaroot/sublayer.def" Content-Type: text/plain comment "" -position -1.18488 2.62985 +position -1.18363 2.49947 connectornextid 2 flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 @@ -149,11 +149,11 @@ outputsNamed3 } inputsNamed3 { -0 switch_load_warnings 1 1 "input1" +0 warn_no_representation_set 1 1 "input1" } inputs { -0 switch_load_warnings 0 1 +0 warn_no_representation_set 0 1 } stat { @@ -256,9 +256,9 @@ Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.de Content-Type: text/plain comment "" -position 0.0322012 4.82456 +position -1.18363 3.62897 connectornextid 2 -flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off +flags = lock off model off template off footprint off xray off bypass off display on render off highlight off unload off savedata off compress on colordefault on exposed on debug off outputsNamed3 { 1 "output1" @@ -307,123 +307,40 @@ return \\\"Unable to get representation\\\"\"" # Parent node node = hou.pwd().parent() +if node.evalParm(\"representation\"): + return \"\" + try: hda_utils.get_node_expected_representation_id(node) except ValueError as exc: return str(exc) - -return \"Unable to get representation.\"" language = python } +else: + return \"\"" language = python } } - } - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.parm" -Content-Type: text/plain - -{ -version 0.8 -numerror [ 0 locks=0 ] ( 1 ) -errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) -severity1 [ 0 locks=0 ] ( "warn" ) -enable1 [ 0 locks=0 ] ( 1 ) -} - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.userdata" -Content-Type: text/plain - -{ - "___Version___":{ - "type":"string", - "value":"___EXTERNAL___" - } -} - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.init" -Content-Type: text/plain - -type = switch -matchesdef = 1 - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.def" -Content-Type: text/plain - -comment "" -position -1.18363 3.53061 -connectornextid 3 -flags = lock off model off template off footprint off xray off bypass off display off render off highlight off unload off savedata off compress on colordefault on exposed on debug off -outputsNamed3 -{ -1 "output1" -} -inputsNamed3 -{ -2 (0) "" 1 "input1" -0 warn_no_representation_set 1 1 "input2" -} -inputs -{ -0 (0) 0 1 -1 warn_no_representation_set 0 1 -} -stat -{ - create -1 - modify -1 - author User@HP-Z820-03 - access 0777 -} -color UT_Color RGB 0.8 1 0.7 -delscript "" -exprlanguage hscript -end - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.editableinputdata" -Content-Type: text/plain - -[ - { - }, - { - } -] - ---HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.chn" -Content-Type: text/plain - -{ - channel input { + channel enable1 { lefttype = extend righttype = extend + default = 1 flags = 0 start = 40 - segment { length = 0 expr = "if(ch(\"../representation\"), 0, 1)" } + segment { length = 0 value = 1 1 expr = "strlen(chs(\"../representation\")) == 0" } } } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.parm" +Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.parm" Content-Type: text/plain { version 0.8 -chooseinputbyname [ 0 locks=0 ] ( "off" ) -input [ 0 locks=0 ] ( [ input 0 ] ) -selectinputname [ 0 locks=0 ] ( "" ) -selectinputvalue [ 0 locks=0 ] ( "" ) -config_separator [ 0 locks=0 ] ( ) -badinput [ 0 locks=0 ] ( ignore ) -fallback [ 0 locks=0 ] ( 0 ) -selectfallbackname [ 0 locks=0 ] ( "" ) -inputname [ 0 locks=0 ] ( "`opinput(\".\", @input)`" ) +numerror [ 0 locks=0 ] ( 1 ) +errormsg1 [ 0 locks=0 ] ( [ errormsg1 "" ] ) +severity1 [ 0 locks=0 ] ( "warn" ) +enable1 [ 0 locks=0 ] ( [ enable1 0 ] ) } --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY -Content-Disposition: attachment; filename="hdaroot/switch_load_warnings.userdata" +Content-Disposition: attachment; filename="hdaroot/warn_no_representation_set.userdata" Content-Type: text/plain { @@ -437,11 +354,10 @@ Content-Type: text/plain Content-Disposition: attachment; filename="hdaroot.order" Content-Type: text/plain -4 +3 output0 sublayer warn_no_representation_set -switch_load_warnings --HOUDINIMIMEBOUNDARY0xD3ADD339-0x00000F49-0x56B122C9-0x00000001HOUDINIMIMEBOUNDARY Content-Disposition: attachment; filename="hdaroot.net" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes index 75c57beaa5..4fc9380cfa 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/Contents.dir/Contents.modtimes @@ -1,7 +1,6 @@ { - "hdaroot/switch_load_warnings.def":1728307536, - "hdaroot/sublayer.def":1728307536, - "hdaroot/warn_no_representation_set.def":1728307536, - "hdaroot/output0.def":1728307536, - "hdaroot.def":1728307791 + "hdaroot/sublayer.def":1729552247, + "hdaroot/warn_no_representation_set.def":1729552277, + "hdaroot/output0.def":1729552203, + "hdaroot.def":1729552272 } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index ea59aff1b3..3c3522ac98 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -196,8 +196,6 @@ label "Show Pipeline Parms" type toggle default { "0" } - parmtag { "script_callback" "hou.phm().on_thumbnail_show_changed(kwargs['node'])" } - parmtag { "script_callback_language" "python" } } } diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/OnLoaded b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/OnLoaded index 42e3c6e640..4c77009400 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/OnLoaded +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/OnLoaded @@ -7,7 +7,7 @@ hda_module.setup_flag_changed_callback(node) def on_duplicate(): """Duplicate thumbnail on node duplicate""" if node.evalParm("show_thumbnail") and node.evalParm("representation"): - hda_module.on_representation_id_changed(node) + hda_module.update_thumbnail(node) if not hou.hipFile.isLoadingHipFile(): diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule index 901c00e19d..8b13789179 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule @@ -1,9 +1 @@ -from ayon_houdini.api.hda_utils import ( - on_thumbnail_show_changed, - on_thumbnail_size_changed, - on_representation_id_changed, - setup_flag_changed_callback, - get_available_versions, - select_product_name, - set_to_latest_version -) + From e7a6418da3de09cf8bcbf4163af1b36014098a4b Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Tue, 22 Oct 2024 01:24:25 +0200 Subject: [PATCH 12/15] Fix PythonModules --- .../ayon_8_8Lop_1lop__import_8_81.0/PythonModule | 10 +++++++++- .../ayon_8_8Lop_1load__shot_8_81.0/PythonModule | 10 +++++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule index 8b13789179..225fadf962 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule @@ -1 +1,9 @@ - +from ayon_houdini.api.hda_utils import ( + on_thumbnail_show_changed, + on_thumbnail_size_changed, + update_thumbnail, + setup_flag_changed_callback, + get_available_versions, + select_product_name, + set_to_latest_version +) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule index 8b13789179..225fadf962 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule @@ -1 +1,9 @@ - +from ayon_houdini.api.hda_utils import ( + on_thumbnail_show_changed, + on_thumbnail_size_changed, + update_thumbnail, + setup_flag_changed_callback, + get_available_versions, + select_product_name, + set_to_latest_version +) From 244c7d0c9585d6c284baf7c25abf2209466267ec Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Wed, 30 Oct 2024 00:38:45 +0100 Subject: [PATCH 13/15] Add explicit update thumbnail and clear cache button --- client/ayon_houdini/api/hda_utils.py | 6 ++++++ .../DialogScript | 18 ++++++++++++++++++ .../PythonModule | 3 ++- .../DialogScript | 18 ++++++++++++++++++ .../PythonModule | 3 ++- 5 files changed, 46 insertions(+), 2 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 3e9cfb90c5..9f8bb647ba 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -39,6 +39,12 @@ def get_session_cache() -> dict: return cache +def clear_session_cache(): + """Clear the current session `hou.session.ayon_cache` dict""" + if hasattr(hou.session, "ayon_cache"): + del hou.session.ayon_cache + + def is_valid_uuid(value) -> bool: """Return whether value is a valid UUID""" try: diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index bb8ffe2a73..e869dd5880 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -83,6 +83,15 @@ type string default { "usd" } } + parm { + name "clear_cache" + label "Clear Cache" + type button + default { "0" } + help "The load logic uses expressions that cache into the current session to avoid continuously requeryin the database. This clear that cache to enforce a full refresh of the expressions." + parmtag { "script_callback" "hou.phm().clear_cache()" } + parmtag { "script_callback_language" "python" } + } parm { name "sepparm" label "Separator" @@ -264,6 +273,15 @@ parmtag { "script_callback" "hou.phm().on_thumbnail_size_changed(kwargs['node'])" } parmtag { "script_callback_language" "python" } } + parm { + name "update_thumbnail" + label "Update Thumbnail" + type button + default { "0" } + hidewhen "{ show_thumbnail == 0 }" + parmtag { "script_callback" "hou.phm().update_thumbnail(kwargs['node'])" } + parmtag { "script_callback_language" "python" } + } parm { name "show_pipeline_parms" label "Show Pipeline Parms" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule index 225fadf962..86a308a3ec 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule @@ -5,5 +5,6 @@ from ayon_houdini.api.hda_utils import ( setup_flag_changed_callback, get_available_versions, select_product_name, - set_to_latest_version + set_to_latest_version, + clear_cache ) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index 3c3522ac98..4f02533af3 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -77,6 +77,15 @@ type string default { "usd" } } + parm { + name "clear_cache" + label "Clear Cache" + type button + default { "0" } + help "The load logic uses expressions that cache into the current session to avoid continuously requeryin the database. This clear that cache to enforce a full refresh of the expressions." + parmtag { "script_callback" "hou.phm().clear_cache()" } + parmtag { "script_callback_language" "python" } + } parm { name "sepparm" label "Separator" @@ -191,6 +200,15 @@ parmtag { "script_callback" "hou.phm().on_thumbnail_size_changed(kwargs['node'])" } parmtag { "script_callback_language" "python" } } + parm { + name "update_thumbnail" + label "Update Thumbnail" + type button + default { "0" } + hidewhen "{ show_thumbnail == 0 }" + parmtag { "script_callback" "hou.phm().update_thumbnail(kwargs['node'])" } + parmtag { "script_callback_language" "python" } + } parm { name "show_pipeline_parms" label "Show Pipeline Parms" diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule index 225fadf962..86a308a3ec 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule @@ -5,5 +5,6 @@ from ayon_houdini.api.hda_utils import ( setup_flag_changed_callback, get_available_versions, select_product_name, - set_to_latest_version + set_to_latest_version, + clear_cache ) From e7447919fc5f0dc9353c97c492856abe33d05cf0 Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Wed, 30 Oct 2024 00:44:45 +0100 Subject: [PATCH 14/15] Fix clear cache call --- client/ayon_houdini/api/hda_utils.py | 6 ------ .../ayon_8_8Lop_1lop__import_8_81.0/DialogScript | 2 +- .../ayon_8_8Lop_1lop__import_8_81.0/PythonModule | 2 +- .../ayon_8_8Lop_1load__shot_8_81.0/DialogScript | 2 +- .../ayon_8_8Lop_1load__shot_8_81.0/PythonModule | 2 +- 5 files changed, 4 insertions(+), 10 deletions(-) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 9f8bb647ba..3e9cfb90c5 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -39,12 +39,6 @@ def get_session_cache() -> dict: return cache -def clear_session_cache(): - """Clear the current session `hou.session.ayon_cache` dict""" - if hasattr(hou.session, "ayon_cache"): - del hou.session.ayon_cache - - def is_valid_uuid(value) -> bool: """Return whether value is a valid UUID""" try: diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript index e869dd5880..2a02ccd54c 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/DialogScript @@ -89,7 +89,7 @@ type button default { "0" } help "The load logic uses expressions that cache into the current session to avoid continuously requeryin the database. This clear that cache to enforce a full refresh of the expressions." - parmtag { "script_callback" "hou.phm().clear_cache()" } + parmtag { "script_callback" "hou.phm().expression_clear_cache()" } parmtag { "script_callback_language" "python" } } parm { diff --git a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule index 86a308a3ec..9f2de26925 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_import.hda/ayon_8_8Lop_1lop__import_8_81.0/PythonModule @@ -6,5 +6,5 @@ from ayon_houdini.api.hda_utils import ( get_available_versions, select_product_name, set_to_latest_version, - clear_cache + expression_clear_cache ) diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript index 4f02533af3..7c41bdcd25 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/DialogScript @@ -83,7 +83,7 @@ type button default { "0" } help "The load logic uses expressions that cache into the current session to avoid continuously requeryin the database. This clear that cache to enforce a full refresh of the expressions." - parmtag { "script_callback" "hou.phm().clear_cache()" } + parmtag { "script_callback" "hou.phm().expression_clear_cache()" } parmtag { "script_callback_language" "python" } } parm { diff --git a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule index 86a308a3ec..9f2de26925 100644 --- a/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule +++ b/client/ayon_houdini/startup/otls/ayon_lop_load_shot.hda/ayon_8_8Lop_1load__shot_8_81.0/PythonModule @@ -6,5 +6,5 @@ from ayon_houdini.api.hda_utils import ( get_available_versions, select_product_name, set_to_latest_version, - clear_cache + expression_clear_cache ) From 8d85e2638c48089e8fb11e9166f043dbcc5710ce Mon Sep 17 00:00:00 2001 From: Roy Nieterau Date: Wed, 30 Oct 2024 17:27:19 +0100 Subject: [PATCH 15/15] Actually return the repre id if it was not cached yet --- client/ayon_houdini/api/hda_utils.py | 1 + 1 file changed, 1 insertion(+) diff --git a/client/ayon_houdini/api/hda_utils.py b/client/ayon_houdini/api/hda_utils.py index 3e9cfb90c5..059d25b9d3 100644 --- a/client/ayon_houdini/api/hda_utils.py +++ b/client/ayon_houdini/api/hda_utils.py @@ -710,6 +710,7 @@ def expression_get_representation_id() -> str: repre_id = "" cache[hash_value] = repre_id + return repre_id def expression_get_representation_path() -> str: