-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add relative paths to nodes as variables #2629
base: develop
Are you sure you want to change the base?
Conversation
53206f9
to
34e1495
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## develop #2629 +/- ##
===========================================
+ Coverage 69.93% 70.47% +0.53%
===========================================
Files 121 123 +2
Lines 7088 7231 +143
===========================================
+ Hits 4957 5096 +139
- Misses 2131 2135 +4 ☔ View full report in Codecov by Sentry. |
8c37fd0
to
3042f94
Compare
This property stores the location of the source code for a given node and is not exposed to the QML side.
`dynamicEnvVars` is a dictionary currently mapping a name to a folder to use as the root when writing relative paths. Keys correspond to the variable names that are to be replaced with their values during the evaluation of attributes. Although it currently only contains folder paths, any type of variable may be written in this dictionary to resolve attribute values with.
When the value of an attribute is evaluated, we should look for any substitution that can be made from the `dynamicEnvVars` dictionary. The values to substitute from are thus not part of the command line and can just be identified with "${varname}", as we do for environment variables.
For all nodes, use the new syntax for relative paths.
…ER}` This prevents having an absolute path for the script, which led to errors when opening, for example, a project in another environment.
3042f94
to
11d9b40
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, I should have seen that in the first review...
@@ -13,7 +13,7 @@ | |||
class Node(object): | |||
""" | |||
""" | |||
internalFolder = '{cache}/{nodeType}/{uid}/' | |||
internalFolder = '{cache}/{nodeType}/{uid}' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we still need it?
meshroom/core/node.py
Outdated
# Dynamic environment variables: defines variables that will be replaced with set values when used in attributes | ||
self.dynamicEnvVars = dict() | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On second thought, instead of adding a new concept, these 2 variables should probably just be part of the cmdVars and used as ‘{nodeCacheFolder}’ and ‘{nodeSourceCodeFolder}’. So, we don't mix the dynamic variables and the env variables (that are static by definition).
Description
This PR adds new variables that can be used in the description of nodes to write relative paths. For each
Node
object, there are currently two variables that are available by default:${NODE_CACHE_FOLDER}
, which points towards the cache folder for this node (and is effectively the same asdesc.Node.internalFolder
);${NODE_SOURCECODE_FOLDER}
, which points towards the folder containing the node's description.These variables are stored in a dictionary named
rootFolder
which is part of theNode
class.rootFolder
can be edited to add or remove variables, with the key of each entry being the name of variable and its value the path it corresponds to. Those variables will be resolved at the same time as environment variables during the evaluation of the attribute's value.All the nodes are modified to use
${NODE_CACHE_FOLDER}
instead ofdesc.Node.internalFolder
, andScenePreview
is updated to use${NODE_SOURCECODE_FOLDER}
when providing the path to the Blender script.Unit tests are added.
Features
rootFolder
dictionary to theBaseNode
classrootFolder
Implementation remarks
Node
objects have a new propertysourceCodeFolder
which contains the path to their directory, and which is used to resolve${NODE_SOURCECODE_FOLDER}
.