diff options
| -rw-r--r-- | scumm/intern.h | 1 | ||||
| -rw-r--r-- | scumm/script_v2.cpp | 13 | 
2 files changed, 11 insertions, 3 deletions
| diff --git a/scumm/intern.h b/scumm/intern.h index 96da9ddb4c..f9218b663f 100644 --- a/scumm/intern.h +++ b/scumm/intern.h @@ -205,6 +205,7 @@ protected:  	void getResultPosIndirect();  	virtual void getResultPos();  	virtual int readVar(uint var); +	virtual void writeVar(uint var, int value);  	virtual void ifStateCommon(byte type);  	virtual void ifNotStateCommon(byte type); diff --git a/scumm/script_v2.cpp b/scumm/script_v2.cpp index 33b5d296ac..4f81f7eb98 100644 --- a/scumm/script_v2.cpp +++ b/scumm/script_v2.cpp @@ -436,10 +436,16 @@ int Scumm_v2::readVar(uint var) {  		var = _scummVars[var];  	checkRange(_numVariables - 1, 0, var, "Variable %d out of range(r)"); -	debug(6, "readvar(%d) = %d", var, _scummVars[var]); +	debug(1, "readvar(%d) = %d", var, _scummVars[var]);  	return _scummVars[var];  } +void Scumm_v2::writeVar(uint var, int value) { +	checkRange(_numVariables - 1, 0, var, "Variable %d out of range(r)"); +	debug(1, "writeVar(%d) = %d", var, value); +	_scummVars[var] = value; +} +  void Scumm_v2::getResultPosIndirect() {  	_resultVarNumber = _scummVars[fetchScriptByte()];  } @@ -529,7 +535,7 @@ void Scumm_v2::o2_getObjUnknown() {  }  void Scumm_v2::o2_setBitVar() { -	byte var = fetchScriptWord(); +	int var = fetchScriptWord();  	byte a = getVarOrDirectByte(0x80);  	int bit_var = var + a; @@ -540,11 +546,12 @@ void Scumm_v2::o2_setBitVar() {  		_scummVars[bit_var] |= (1 << bit_offset);  	else  		_scummVars[bit_var] &= ~(1 << bit_offset); +  }  void Scumm_v2::o2_getBitVar() {  	getResultPos(); -	byte var = fetchScriptWord(); +	int var = fetchScriptWord();  	byte a = getVarOrDirectByte(0x80);  	int bit_var = var + a; | 
