aboutsummaryrefslogtreecommitdiff
path: root/engines/prince/prince.cpp
diff options
context:
space:
mode:
authorlukaslw2014-06-24 03:57:40 +0200
committerlukaslw2014-06-24 03:57:40 +0200
commita319f473f6502b4acd2b7da4aa5220a965335081 (patch)
tree3b8ba53c8c70f3b08503c3677e58d36eb6a4b9df /engines/prince/prince.cpp
parent11d062f2b222826965fb1653aade448fa359c1ac (diff)
downloadscummvm-rg350-a319f473f6502b4acd2b7da4aa5220a965335081.tar.gz
scummvm-rg350-a319f473f6502b4acd2b7da4aa5220a965335081.tar.bz2
scummvm-rg350-a319f473f6502b4acd2b7da4aa5220a965335081.zip
PRINCE: LMB outside of inventory - update
Diffstat (limited to 'engines/prince/prince.cpp')
-rw-r--r--engines/prince/prince.cpp24
1 files changed, 23 insertions, 1 deletions
diff --git a/engines/prince/prince.cpp b/engines/prince/prince.cpp
index 7fefae9f5f..04901d78fa 100644
--- a/engines/prince/prince.cpp
+++ b/engines/prince/prince.cpp
@@ -1685,8 +1685,11 @@ void PrinceEngine::drawInvItems() {
}
void PrinceEngine::leftMouseButton() {
+ int option = 0;
+
if (_optionsFlag) {
if (_optionEnabled < _optionsNumber) {
+ option = _optionEnabled;
_optionsFlag = 0;
// edi = optionsMob
// ebp = optionsMobNumber
@@ -1701,12 +1704,31 @@ void PrinceEngine::leftMouseButton() {
// @@walkto - TODO
return;
}
+ option = 0;
}
//do_option
// selectedMob = optionsMobNumber
if (_currentPointerNumber != 2) {
//skip_use_code
-
+ int optionScriptOffset = _script->getOptionScript(_room->_walkTo, option);
+ int optionEvent;
+ if (optionScriptOffset != 0) {
+ optionEvent = _script->scanMobEvents(_optionsMob, optionScriptOffset);
+ } else {
+ optionEvent = -1;
+ }
+ if (optionEvent == -1) {
+ if (option == 0) {
+ //@@walkto - TODO
+ return;
+ } else {
+ optionEvent = _script->getOptionScript(_script->_scriptInfo.stdExamine, option - 1);
+ }
+ }
+ // eax <- return (int)READ_UINT16(&_data[optionEvent]);
+ // store_new_pc:
+ // storeNewPC();
+ return;
} else if (_selectedMode != 0) {
//give_item