ScummVM API documentation
exit.h
1 /* ScummVM - Graphic Adventure Engine
2  *
3  * ScummVM is the legal property of its developers, whose names
4  * are too numerous to list here. Please refer to the COPYRIGHT
5  * file distributed with this source distribution.
6  *
7  * Additional copyright for this file:
8  * Copyright (C) 1995-1997 Presto Studios, Inc.
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <http://www.gnu.org/licenses/>.
22  *
23  */
24 
25 #ifndef PEGASUS_NEIGHBORHOOD_EXIT_H
26 #define PEGASUS_NEIGHBORHOOD_EXIT_H
27 
28 #include "common/array.h"
29 #include "common/endian.h"
30 
31 #include "pegasus/constants.h"
32 
33 namespace Common {
34  class SeekableReadStream;
35 }
36 
37 namespace Pegasus {
38 
39 class ExitTable {
40 public:
41  ExitTable() {}
42  ~ExitTable() {}
43 
44  static uint32 getResTag() { return MKTAG('E', 'x', 'i', 't'); }
45 
46  void loadFromStream(Common::SeekableReadStream *stream);
47  void clear();
48 
49  struct Entry {
50  Entry() { clear(); }
51  bool isEmpty() { return movieStart == 0xffffffff; }
52  void clear() {
53  room = kNoRoomID;
54  direction = kNoDirection;
55  altCode = kNoAlternateID;
56  movieStart = 0xffffffff;
57  movieEnd = 0xffffffff;
58  exitEnd = 0xffffffff;
59  originalEnd = 0xffffffff;
60  exitLoop = 0xffffffff;
61  exitRoom = kNoRoomID;
62  exitDirection = kNoDirection;
63  }
64 
65  RoomID room;
66  DirectionConstant direction;
67  AlternateID altCode;
68  TimeValue movieStart;
69  TimeValue movieEnd;
70  // exitEnd is the end of the optimized run of walks.
71  TimeValue exitEnd;
72  TimeValue originalEnd;
73  // exitLoop is the loop start time of the optimized run of walks if the run
74  // loops back on itself (so far, only in TSA).
75  TimeValue exitLoop;
76  RoomID exitRoom;
77  DirectionConstant exitDirection;
78  };
79 
80  Entry findEntry(RoomID room, DirectionConstant direction, AlternateID altCode);
81 
82  typedef Common::Array<Entry>::iterator iterator;
83  iterator begin() { return _entries.begin(); }
84  iterator end() { return _entries.end(); }
85 
86 private:
87  Common::Array<Entry> _entries;
88 };
89 
90 } // End of namespace Pegasus
91 
92 #endif
T * iterator
Definition: array.h:54
Definition: stream.h:745
Definition: exit.h:49
Definition: algorithm.h:29
#define MKTAG(a0, a1, a2, a3)
Definition: endian.h:188
Definition: exit.h:39
Definition: ai_action.h:33