aboutsummaryrefslogtreecommitdiff
path: root/engines/dreamweb/runtime.h
diff options
context:
space:
mode:
authorWillem Jan Palenstijn2011-12-07 10:23:21 -0800
committerWillem Jan Palenstijn2011-12-07 10:23:21 -0800
commit9e617d0dfddf91e5802c783fae5be679afe22b05 (patch)
tree5e9eb811689cb5e21b7ec41b0b14674d422da092 /engines/dreamweb/runtime.h
parentc1b7d25bb7cd8f718d79b47c6b4a12caed904dde (diff)
parent28ba2071e44b15ecb4c20ee682a9e2bbafe67ab9 (diff)
downloadscummvm-rg350-9e617d0dfddf91e5802c783fae5be679afe22b05.tar.gz
scummvm-rg350-9e617d0dfddf91e5802c783fae5be679afe22b05.tar.bz2
scummvm-rg350-9e617d0dfddf91e5802c783fae5be679afe22b05.zip
Merge pull request #127 from fingolfin/dreamweb-cleanup
Dreamweb: Remove more dead stuff, advance DreamBase <-> DreamGenContext split
Diffstat (limited to 'engines/dreamweb/runtime.h')
-rw-r--r--engines/dreamweb/runtime.h26
1 files changed, 17 insertions, 9 deletions
diff --git a/engines/dreamweb/runtime.h b/engines/dreamweb/runtime.h
index 48f7c88a20..a37fb56967 100644
--- a/engines/dreamweb/runtime.h
+++ b/engines/dreamweb/runtime.h
@@ -151,15 +151,19 @@ public:
: _value(value), _segment(segment) {
}
+ inline operator uint16() const {
+ return _value;
+ }
+
+ SegmentPtr getSegmentPtr() const {
+ return _segment;
+ }
+
inline uint8 &byte(unsigned index) {
assert(_segment != 0);
return _segment->byte(index);
}
- inline operator uint16() const {
- return _value;
- }
-
inline WordRef word(unsigned index) {
//debug(1, "getting word ref for %04x:%d", _value, index);
assert(_segment != 0);
@@ -194,6 +198,10 @@ public:
: _context(ctx), SegmentRef(value, segment) {
}
+ MutableSegmentRef(Context *ctx, SegmentRef seg)
+ : _context(ctx), SegmentRef(seg) {
+ }
+
inline MutableSegmentRef& operator=(const uint16 id);
};
@@ -255,12 +263,12 @@ public:
MutableSegmentRef es;
Flags flags;
- Context(SegmentPtr realData): al(ax), ah(ax), bl(bx), bh(bx), cl(cx), ch(cx), dl(dx), dh(dx),
- cs(kDefaultDataSegment, realData),
- ds(this, kDefaultDataSegment, realData),
- es(this, kDefaultDataSegment, realData) {
+ Context(SegmentRef data): al(ax), ah(ax), bl(bx), bh(bx), cl(cx), ch(cx), dl(dx), dh(dx),
+ cs(data),
+ ds(this, data),
+ es(this, data) {
- _segments[kDefaultDataSegment] = realData;
+ _segments[kDefaultDataSegment] = data.getSegmentPtr();
}
SegmentRef getSegment(uint16 value) {