about summary refs log tree commit diff stats
path: root/proto
diff options
context:
space:
mode:
Diffstat (limited to 'proto')
-rw-r--r--proto/data.proto24
-rw-r--r--proto/human.proto30
2 files changed, 50 insertions, 4 deletions
diff --git a/proto/data.proto b/proto/data.proto index bc3f669..e9cc7d7 100644 --- a/proto/data.proto +++ b/proto/data.proto
@@ -52,6 +52,13 @@ enum DoorGroupType {
52 SHUFFLE_GROUP = 4; 52 SHUFFLE_GROUP = 4;
53} 53}
54 54
55enum MapType {
56 NORMAL_MAP = 0;
57 ICARUS = 1;
58 GIFT_MAP = 2;
59 DEMO = 3;
60}
61
55enum AxisDirection { 62enum AxisDirection {
56 AXIS_DIRECTION_UNKNOWN = 0; 63 AXIS_DIRECTION_UNKNOWN = 0;
57 64
@@ -93,6 +100,12 @@ message Vec3d {
93 optional double z = 3; 100 optional double z = 3;
94} 101}
95 102
103message VersionNumber {
104 optional uint64 major = 1;
105 optional uint64 minor = 2;
106 optional uint64 patch = 3;
107}
108
96message ProxyIdentifier { 109message ProxyIdentifier {
97 optional uint64 panel = 1; 110 optional uint64 panel = 1;
98 optional string answer = 2; 111 optional string answer = 2;
@@ -117,6 +130,7 @@ message Connection {
117 optional bool roof_access = 7; 130 optional bool roof_access = 7;
118 optional bool purple_ending = 8; 131 optional bool purple_ending = 8;
119 optional bool cyan_ending = 9; 132 optional bool cyan_ending = 9;
133 optional bool vanilla_only = 10;
120} 134}
121 135
122message Door { 136message Door {
@@ -136,11 +150,13 @@ message Door {
136 repeated KeyholderAnswer keyholders = 13; 150 repeated KeyholderAnswer keyholders = 13;
137 repeated uint64 rooms = 14; 151 repeated uint64 rooms = 14;
138 repeated uint64 doors = 15; 152 repeated uint64 doors = 15;
139 repeated uint64 endings = 16; 153 optional bool white_ending = 16;
140 optional bool double_letters = 18; 154 optional bool double_letters = 18;
141 repeated string senders = 19; 155 repeated string senders = 19;
142 156
143 optional DoorType type = 8; 157 optional DoorType type = 8;
158 optional bool latch = 20;
159 optional bool legacy_location = 21;
144 160
145 optional string location_name = 17; 161 optional string location_name = 17;
146} 162}
@@ -183,9 +199,11 @@ message PaintingData {
183 199
184message Port { 200message Port {
185 optional uint64 id = 1; 201 optional uint64 id = 1;
202 optional uint64 ap_id = 11;
186 optional uint64 room_id = 2; 203 optional uint64 room_id = 2;
187 optional string name = 3; 204 optional string name = 3;
188 205
206 optional string display_name = 10;
189 optional string path = 4; 207 optional string path = 4;
190 optional Vec3d destination = 5; 208 optional Vec3d destination = 5;
191 optional double rotation = 8; 209 optional double rotation = 8;
@@ -256,6 +274,8 @@ message Map {
256 optional uint64 id = 1; 274 optional uint64 id = 1;
257 optional string name = 2; 275 optional string name = 2;
258 optional string display_name = 3; 276 optional string display_name = 3;
277 optional uint64 worldport_entrance = 4;
278 optional MapType type = 5;
259} 279}
260 280
261message Progressive { 281message Progressive {
@@ -274,7 +294,7 @@ message DoorGroup {
274} 294}
275 295
276message AllObjects { 296message AllObjects {
277 optional uint64 version = 15; 297 optional VersionNumber version = 15;
278 298
279 repeated Map maps = 7; 299 repeated Map maps = 7;
280 repeated Room rooms = 1; 300 repeated Room rooms = 1;
diff --git a/proto/human.proto b/proto/human.proto index 748cf33..c586599 100644 --- a/proto/human.proto +++ b/proto/human.proto
@@ -78,6 +78,9 @@ message HumanConnection {
78 // This means that the connection should additionally require all cyan letters 78 // This means that the connection should additionally require all cyan letters
79 // when the Strict Cyan Ending option is on. 79 // when the Strict Cyan Ending option is on.
80 optional bool cyan_ending = 10; 80 optional bool cyan_ending = 10;
81
82 // This means that the connection only exists when doors are not shuffled.
83 optional bool vanilla_only = 11;
81} 84}
82 85
83message HumanConnections { 86message HumanConnections {
@@ -101,7 +104,7 @@ message HumanDoor {
101 repeated KeyholderIdentifier keyholders = 10; 104 repeated KeyholderIdentifier keyholders = 10;
102 repeated RoomIdentifier rooms = 11; 105 repeated RoomIdentifier rooms = 11;
103 repeated DoorIdentifier doors = 12; 106 repeated DoorIdentifier doors = 12;
104 repeated string endings = 13; 107 optional bool white_ending = 13;
105 optional bool double_letters = 15; 108 optional bool double_letters = 15;
106 109
107 // Sender nodes to be added to the list of requirements for triggering the 110 // Sender nodes to be added to the list of requirements for triggering the
@@ -111,6 +114,16 @@ message HumanDoor {
111 optional DoorType type = 4; 114 optional DoorType type = 4;
112 optional string location_room = 5; 115 optional string location_room = 5;
113 optional string location_name = 14; 116 optional string location_name = 14;
117
118 // Non-item doors that are latched will stay open once opened, even if the
119 // opening trigger is deactivated. This applies to EVENT/LOCATION_ONLY doors,
120 // as well as item-locked doors when not shuffling doors.
121 optional bool latch = 17;
122
123 // If true, the client will treat this door like a location, even though no
124 // location is created for it in the generator. This helps provide backwards
125 // compatability with older worlds.
126 optional bool legacy_location = 18;
114} 127}
115 128
116message HumanDoors { 129message HumanDoors {
@@ -150,6 +163,7 @@ message HumanPainting {
150 163
151message HumanPort { 164message HumanPort {
152 optional string name = 1; 165 optional string name = 1;
166 optional string display_name = 8;
153 optional string path = 2; 167 optional string path = 2;
154 168
155 optional bool no_shuffle = 7; 169 optional bool no_shuffle = 7;
@@ -212,7 +226,18 @@ message HumanRoom {
212 226
213message HumanMap { 227message HumanMap {
214 optional string display_name = 1; 228 optional string display_name = 1;
229 optional MapType type = 4;
230
231 optional PortIdentifier worldport_entrance = 3;
232
233 // These two fields are used by the validator and nothing else. excluded_nodes
234 // are objects in the tscn that are intentionally not mentioned in the txtpb.
235 // custom_nodes are the reverse of that; objects that are mentioned in the
236 // txtpb but not present in the tscn. These are generally created dynamically
237 // by the game mod, but may also be used for places where the validator is
238 // just wrong about the contents of the map file.
215 repeated string excluded_nodes = 2; 239 repeated string excluded_nodes = 2;
240 repeated string custom_nodes = 5;
216} 241}
217 242
218message HumanProgressive { 243message HumanProgressive {
@@ -236,7 +261,7 @@ message HumanDoorGroups {
236 261
237message HumanGlobalMetadata { 262message HumanGlobalMetadata {
238 repeated string special_names = 1; 263 repeated string special_names = 1;
239 optional uint64 version = 2; 264 optional VersionNumber version = 2;
240} 265}
241 266
242message IdMappings { 267message IdMappings {
@@ -244,6 +269,7 @@ message IdMappings {
244 map<string, uint64> panels = 1; 269 map<string, uint64> panels = 1;
245 map<string, uint64> masteries = 2; 270 map<string, uint64> masteries = 2;
246 map<string, uint64> keyholders = 3; 271 map<string, uint64> keyholders = 3;
272 map<string, uint64> ports = 4;
247 } 273 }
248 274
249 message MapIds { 275 message MapIds {