-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathinfo.yml
217 lines (187 loc) · 10.6 KB
/
info.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
# Copyright (c) 2013 Shotgun Software Inc.
#
# CONFIDENTIAL AND PROPRIETARY
#
# This work is provided "AS IS" and subject to the Shotgun Pipeline Toolkit
# Source Code License included in this distribution package. See LICENSE.
# By accessing, using, copying or modifying this work you indicate your
# agreement to the Shotgun Pipeline Toolkit Source Code License. All rights
# not expressly granted therein are reserved by Shotgun Software Inc.
# Metadata defining the behaviour and requirements for this app
# expected fields in the configuration file for this app
configuration:
use_software_entity:
type: bool
description: Whether to use Flow Production Tracking Software Entities to register
launch commands for available DCCs.
default_value: false
software_entity_extra_fields:
type: list
allows_empty: True
values:
type: str
default_value: []
description: "A list of Software entity field code names that should be fetched and
and passed to the hooks as part of the Software entity dictionary.
The main fields are already fetched and provided by default, but this
allows custom fields to be specified without needing to perform a second
look up in Flow Production Tracking."
scan_all_projects:
type: bool
description: When true, and when use_software_entity is true, launchers
will be registered for all projects instead of only the
current environment's project.
default_value: false
menu_name:
type: str
description: Name to appear on the Flow Production Tracking menu.
default_value: ""
icon:
type: str
description: "The path to the icon to appear for the application. If the
value starts with '{target_engine}' then the remainder of the
path will be relative to the root of the engine's install. If
the value starts with '{config_path}' then the remainder of the
path will be relative to the root of the configuration. The
path should use forward slashes which will be replaced with
the correct operating system separator when used."
default_value: "{target_engine}/icon_256.png"
# Path information for multiple platforms
windows_path:
type: str
description: The path to the application executable on Windows.
default_value: ""
windows_args:
type: str
description: The arguments to be passed to application on Windows, as a string.
default_value: ""
linux_path:
type: str
description: The path to the application executable on Linux.
default_value: ""
linux_args:
type: str
description: The arguments to be passed to application on Linux, as a string.
default_value: ""
mac_path:
type: str
description: The path to the application executable on Mac OS X.
default_value: ""
mac_args:
type: str
description: The arguments to be passed to application on Mac OS X, as a string.
default_value: ""
engine:
type: str
description: "The name of the Flow Production Tracking engine to start. This is typically
the application name prefixed with tk, e.g. tk-maya, tk-nuke, tk-photoshop
etc. If you set this to an empty string, no toolkit engine will be started,
meaning that you can launch applications that do not have toolkit engines
set up."
default_value: ""
group:
type: str
description: "The name for a group this command should be considered a member of."
default_value: ""
group_default:
type: bool
description: "Boolean value indicating whether this command should represent the group as
a whole. Setting this value to True indicates that this is the command to run and
display in applications that show a single button for each named group."
default_value: False
defer_keyword:
type: str
default_value: ""
description: "Advanced parameter. This allows for advanced customization around deferred folder creation.
Deferred folder creation allows for the creation of partial subfolder structures depending
on a specific keyword (see main documentation for details). Before an app is launched, folders
are automatically created and by default (e.g. if you leave this setting as null),
the launch app will pass the name of the engine as the deferred folder creation keyword.
This makes it easy to set up deferred rules in your folder creation config for tk-maya,
tk-nuke etc. However, if you for example wanted to set up specific deferred folder structures
for Nuke and Nuke X (both running the nuke engine), you need a finer granularity. This setting
can then be used to override the default behaviour of just passing the engine name. Instead, you
can pass any string into the deferred folder creation (for example 'nuke' and 'nuke_x' in the case
above). This parameter is also useful if you want to use deferred folder creation in
conjunction with launching of apps which do not have a toolkit engine defined - for these
app launch instances, the engine setting is left blank, and therefore no engine name is passed
into the deferred folder creation. In such cases you can utilize this parameter to control
the deferred folder creation.
You can specify multiple keywords using a comma as a delimiter (eg. 'nuke, nuke_x').
This will trigger folder creation for folders in your schema that have any
of these values in their deferred folder creation setting."
versions:
type: list
allows_empty: True
values:
type: str
default_value: []
description: "A list of strings that will be used to substitute for the {version} token
in the values for the other settings for the instance of this app. For
example, a value of ['2012', '2013', '2014'] for this setting and a value of
'Launch Maya {version}' for menu_name would result in the following command
menu names being registered: Launch Maya 2012, Launch Maya 2013, Launch
Maya 2014. The first version in the list will be considered the 'default'
version if the engine running the app supports the concept. You can use pieces
of the version if you wrap the parts in parenthesis like ['(7.0)v3', '(8.0)v1'].
These pieces of the version string are available in the other settings via the
{v0}, {v1}, {v2}, ... replacement tokens."
skip_engine_instances:
type: list
allows_empty: True
values:
type: str
default_value: []
description: "A list of string names of engine instances to skip registering Software
launcher commands for. For example, a value of ['tk-nukestudio'] for this
setting would stop any Software entity launcher commands being registered
with the engine that reference the 'tk-nukestudio' engine instance in that
environment. This can be used to allow for an engine instance to be configured
for a given environment without a launcher existing for it. This is useful
in the case of Nuke Studio, where we want to allow for context changes into
certain environments, but we only want the application to be launchable from
a project environment. This setting only has an impact on Software entity
launchers."
extra:
type: dict
description: "Flow Production Tracking engine specific extra values. These are defined per
Flow Production Tracking engine. Please look in the app documentation for more
details."
default_value: {}
hook_app_launch:
type: hook
default_value: app_launch
description: "Called to launch the application. This hook contains the code that does
the actual execution of the launch command and parameters. If you have
a custom launcher system in your studio, it can be handy to override
Tank's default launch behaviour."
hook_before_app_launch:
type: hook
default_value: before_app_launch
description: "This hook is called just before the hook_app_launch is used and can be
useful if you don't want to modify the way applications are being launched
(which is advanced usage and can be done by overriding the app_launch hook),
but merely want to modify the environment before app launch. You may want
to add additional pipeline paths, APIs or other things to the setup, or
specify additional scripts etc to run."
hook_before_register_command:
type: hook
default_value: before_register_command
description: "This hook is called just before launcher command registration occurs.
it can be used to alter the engine instance name associated with the
launcher should that be required. This hook's methods are only called
when Software entity launchers are being used."
# the Shotgun fields that this app needs in order to operate correctly
requires_shotgun_fields:
# More verbose description of this item
display_name: "Launch Application"
description: "Launch Applications and initialize the Flow Production Tracking."
# Required minimum versions for this item to run
requires_shotgun_version:
requires_core_version: "v0.19.1"
requires_engine_version:
# the engines that this app can operate in:
supported_engines:
frameworks:
- {"name": "tk-framework-shotgunutils", "version": "v5.x.x", "minimum_version": "v5.1.0"}
- {"name": "tk-framework-qtwidgets", "version": "v2.x.x", "minimum_version": "v2.9.0"}