forked from shotgunsoftware/rv-integration-package
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathshotgun_fields_example_C.mu
202 lines (181 loc) · 7.77 KB
/
shotgun_fields_example_C.mu
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
require runtime;
module: shotgun_fields_config_C
{
require shotgun_stringMap;
StringMap := shotgun_stringMap.StringMap;
function: serverMap (string; )
{
//
// If you decide to store your servers and script keys here
// instead of in an environment variable, edit the below to
// return a string of pairs of server urls and corresponding
// script keys separated by spaces, like this:
//
// return "https://tweak.shotgunstudio.com 4b1676497a208c845b12f5c6734daf9d6e7c6274 http://blah.shotgunstudio.com 4b1676497a208c845b12f5c6734daf9d6e7c6274"
//
// You can have as many server/key pairs as you want, and the
// first will be considered the default.
//
return nil;
}
function: fieldDescriptors((string, string, string, string, string, bool)[]; )
{
//
// In all the below, do NOT change the values in the "name"
// column. These are the keys, by which RV will index these
// arrays of information.
//
(string, string, string, string, string, bool)[] descriptors = {
//
// Entity fields. These may be any number of hops away from
// the Version. Note the shot/asset fields. The "link"field
// may point to either a Shot or an Asset. Both are supported
// by specifying the Link field and then that the Shot and Asset
// fields are computed from the Link field. The computation is
// internal and not part of the "compute" function defined
// below.
//
// name prettyName fieldName fieldType entityType compute
("link", "Link", "entity", "entity", "Version", false),
("shot", "Shot", "link", "entity", "Version", true),
("asset", "Asset", "link", "entity", "Version", true),
("sequence", "Sequence", "sg_sequence", "entity", "Shot", false),
("project", "Project", "project", "entity", "Version", false),
//("task", "Task", "sg_task", "entity", "Version", false),
("user", "Artist", "user", "entity", "Version", false),
//
// Media types. For each media type whose path is stored
// per version, you must specify path, pixel aspect, and slate boolian.
// Corresponding "swap to" menu items and prefs will be
// generated accordingly.
//
// name prettyName fieldName fieldType entityType compute
("mt_Source", "Source Path", "sg_source_path", "text", "Version", false),
("mt_Source_aspect", "none", "none", "float", "Version", true),
("mt_Source_hasSlate", "none", "none", "checkbox", "Version", true),
("mt_QT", "QT Path", "sg_qt_path", "text", "Version", false),
("mt_QT_aspect", "none", "none", "float", "Version", true),
("mt_QT_hasSlate", "none", "sg_has_slate", "checkbox", "Version", false),
//
// Editorial information. Can be stored on any entity, or computed
// from other information.
//
// name prettyName fieldName fieldType entityType compute
("frameMin", "Min Frame", "head_in", "number", "Shot", false),
("frameMax", "Max Frame", "tail_out", "number", "Shot", false),
("frameIn", "In Frame", "cut_in", "number", "Shot", false),
("frameOut", "Out Frame", "cut_out", "number", "Shot", false),
// ("frameRange", "Frame Range", "sg_frame_range", "text", "Version", false),
//
// Unlike the above, the "cutOrder" must be a field on the
// Shot entity. It can be any name or type, but the
// "actualCutOrder" function defined below must be able to
// generate an int from this field.
//
("cutOrder", "Cut Order", "sg_cut_order", "number", "Shot", false),
//
// Essential.
//
// name prettyName fieldName fieldType entityType compute
("id", "ID", "id", "number", "Version", false),
//
// Arbitrary fields for the info widget can go here. Can be
// fields on any entity "reachable" from the Version enitity.
// But any entity that appears in the entityType field below
// must appear as a fieldType entry above.
//
// name prettyName fieldName fieldType entityType compute
("name", "Name", "code", "text", "Version", false),
("description", "Description", "description", "text", "Version", false),
("created", "Created", "created_at", "date_time", "Version", false),
("status", "Status", "sg_status_list", "status_list", "Version", false),
("shotStatus", "Shot Status", "sg_status_list", "status_list", "Shot", false),
("assetStatus", "Asset Status", "sg_status_list", "status_list", "Asset", false),
("department", "Role", "sg_role", "text","Version",false)
};
return descriptors;
};
function: actualCutOrder (int; string cutOrderValue)
{
return int(cutOrderValue);
}
function: displayOrder (string[]; )
{
string[] fo = string [] {
"name",
"description",
"status",
"user",
"created",
"id",
"department",
"shot",
"shotStatus",
"sequence",
//"seqPriority",
"asset",
"assetStatus",
"project",
"mt_QT",
"mt_Source"
};
}
function: fieldsCompute (void; StringMap data, bool incremental)
{
//
// When 'incremental' is true, we only want to compute fields
// that "lead" to other fields (like entity fields). In
// general, we only need to compute field values after all
// entities are queried, ie when 'incremental' is false.
//
if (incremental) return;
//
// Here you can compute any fields that are not stored on
// entities, but which can be computed from fields which _are_
// stored on entities. Or field data can be modified to fit
// the needs of RV.
//
//
// Here we just say that the pixel aspect ratio as always 1.0
//
data.add("mt_Source_aspect", "1.0");
data.add("mt_QT_aspect", "1.0");
//
// XXX We claim here that source never has slate.
//
data.add("mt_Source_hasSlate", "false");
if (runtime.build_os() == "LINUX")
{
let source = data.find("mt_Source");
if (source neq nil)
{
source = regex.replace ("%04d", source, "#");
source = regex.replace ("%v", source, "r");
data.add("mt_Source", source);
}
}
/*
if (runtime.build_os() == "WINDOWS")
{
let frames = data.find("mt_Frames"),
altframes = data.find("mt_AltFrames"),
movie = data.find("mt_Movie");
if (frames neq nil && !regex.match("^[a-zA-Z]:", frames))
{
frames = "c:" + frames;
data.add("mt_Frames", frames);
}
if (altframes neq nil && !regex.match("^[a-zA-Z]:", altframes))
{
altframes = "c:" + altframes;
data.add("mt_AltFrames", altframes);
}
if (movie neq nil && !regex.match("^[a-zA-Z]:", movie))
{
movie = "c:" + movie;
data.add("mt_Movie", movie);
}
}
*/
}
}