Why I Had to Update The Script Once Again
After receiving some
data:image/s3,"s3://crabby-images/71673/716730f18bf7698eab1d4f305a424329b97ea8f2" alt="Bug Bug"
data:image/s3,"s3://crabby-images/beb77/beb779e71bec771a650061a94cd3cbd4e260ef32" alt="Dog Dog"
data:image/s3,"s3://crabby-images/b6e0f/b6e0fb7dc2d97097b5840371f8f5c3eb2b9730ac" alt="Incredible Incredible"
Fine, Melana.
data:image/s3,"s3://crabby-images/57087/570870a33f830586dbd8864b041d342c5a018b85" alt="Boring Boring"
data:image/s3,"s3://crabby-images/33c1a/33c1ad170b03f5fa42fe77d19acfe74516213f79" alt="Laughing Laughing"
data:image/s3,"s3://crabby-images/f0f17/f0f176d99168125cd8426a97b9654037a659b977" alt="Book Book"
What I told you before was half the truth of what had occurred to RMXP's Interpreter class.
SUMMARY
- The issue that made the RMXP engine get stuck after a script call event command was a real pain you know where.
Both false and nil results, both considered falsey values, were the worst nightmareRMXP Interpreter class had ever experienced.
- if result == false conditional statement was not the true culprit.
That was nothing but a goon, but the actual mastermind was in another castle, Mario!
It just was a symptom of a bigger issue we had not detected before or preferred to ignore it altogether for undisclosed reasons.
- @index += 1 addition was mandatory for sure.
Yet, the condition that made it relevant according to my previous post was WRONG. Thus, it had to be replaced by another one.
- The need for preparing the event for processing the next event command was real.
Again, what was terribly wrong was the condition that would apply the fix where it was relevant.
- I had introduced another
bug because of ignoring the second point indeed.
THE ROOT CAUSE
It was located in the Interpreter class for sure but it was in the script section known as Interpreter 1. There you can find a method called update which is very important, especially true if you're an eventer. Yes, eventers depend on it 100% or else they'd lose control of the map forever and ever
data:image/s3,"s3://crabby-images/6e49e/6e49e3d0106f182a41749d52197d7737d8945938" alt="Happy with a sweat Happy with a sweat"
data:image/s3,"s3://crabby-images/c93dc/c93dc335de5e0fc758ebe4c83aab16a054e7e244" alt="Killer Killer"
There returning a false or nil value as the end result of execute_command event command became a terrible issue!
Yes, I know that this part of the explanation sounds rather old, yet, that's on purpose even if that's not the end of the story.
data:image/s3,"s3://crabby-images/cb6fb/cb6fb091c08389337cfbb8a610911a495b49e236" alt="Shocked Shocked"
Why is it important?
You would understand the issue if you focus on this section of the update method:
Code:
if execute_command == false
return
end
What you can read there created the issue, even if it was not supposed to. You see, there are other methods that return a false value on purpose!
data:image/s3,"s3://crabby-images/4b249/4b249ff3061f1abd2982e3ba5b617e7440b1abf2" alt="Feeling sick Feeling sick"
After analyzing those other methods, I came up with 1 out of 2 simple conclusions.
1. They had something in common: they were disruptive by nature!
data:image/s3,"s3://crabby-images/cb6fb/cb6fb091c08389337cfbb8a610911a495b49e236" alt="Shocked Shocked"
If you called another type of scene or a gameover or anything the like, the engine was supposed to halt the execution of the update command ASAP.
2. Script Call event command was ALSO supposed to be just as disruptive as the calls to other scenes if the end result was false.
Here I guess that the Script Call command was intended to be used as some sort of multi-line condition and not really as an evaluation of a whole script or an internal or external method call. The only "official" way to prevent this from ever happening was to return true at the end of our call.
Where did I get that?
If I had only purchased RMXP, I'd probably still ignore the real issue. Nonetheless, having legal access to RMVX and RMVX ACE widened my perspective quite a bit. IIRC, you won't find the exact same issue there, especially in VX ACE. For some reason I haven't studied so far, VX does have a problem with either false or nil values, but only one of them is a pain...
VX ACE actually changed the way the methods are executed, by not testing the result of evaluating the script, to prevent it from changing the event processing based on its interpretation of that old event command over and over again, freezing the maker permanently. OR ignoring the event commands that come after a script call with false or nil as its return values.
The Real Fix
This is the most excentric part of the whole story. It's a mix of the good old "change the value of the result local variable" approach PLUS my @index += 1 increase without ignoring the issues caused by nil. The thing is that I had to properly find the best place to change the @index without altering any other event commands. That perfect place is inside the very same condition that started it all: if result == false itself!
data:image/s3,"s3://crabby-images/33c1a/33c1ad170b03f5fa42fe77d19acfe74516213f79" alt="Laughing Laughing"
"For God has not destined us for wrath, but for obtaining salvation through our Lord Jesus Christ," 1 Thessalonians 5:9
Maranatha!
The Internet might be either your friend or enemy. It just depends on whether or not she has a bad hair day.
![[Image: SP1-Scripter.png]](https://www.save-point.org/images/userbars/SP1-Scripter.png)
![[Image: SP1-Writer.png]](https://www.save-point.org/images/userbars/SP1-Writer.png)
![[Image: SP1-Poet.png]](https://www.save-point.org/images/userbars/SP1-Poet.png)
![[Image: SP1-PixelArtist.png]](https://www.save-point.org/images/userbars/SP1-PixelArtist.png)
![[Image: SP1-Reporter.png]](https://i.postimg.cc/GmxWbHyL/SP1-Reporter.png)
My Original Stories (available in English and Spanish)
List of Compiled Binary Executables I have published...
HiddenChest & Roole
Give me a free copy of your completed game if you include at least 3 of my scripts!data:image/s3,"s3://crabby-images/c73f7/c73f78094c99ef8406c5071a2249b68c5211d9ab" alt="Laughing + Tongue sticking out Laughing + Tongue sticking out"
Just some scripts I've already published on the board...
KyoGemBoost XP VX & ACE, RandomEnkounters XP, KSkillShop XP, Kolloseum States XP, KEvents XP, KScenario XP & Gosu, KyoPrizeShop XP Mangostan, Kuests XP, KyoDiscounts XP VX, ACE & MV, KChest XP VX & ACE 2016, KTelePort XP, KSkillMax XP & VX & ACE, Gem Roulette XP VX & VX Ace, KRespawnPoint XP, VX & VX Ace, GiveAway XP VX & ACE, Klearance XP VX & ACE, KUnits XP VX, ACE & Gosu 2017, KLevel XP, KRumors XP & ACE, KMonsterPals XP VX & ACE, KStatsRefill XP VX & ACE, KLotto XP VX & ACE, KItemDesc XP & VX, KPocket XP & VX, OpenChest XP VX & ACE
Maranatha!
The Internet might be either your friend or enemy. It just depends on whether or not she has a bad hair day.
![[Image: SP1-Scripter.png]](https://www.save-point.org/images/userbars/SP1-Scripter.png)
![[Image: SP1-Writer.png]](https://www.save-point.org/images/userbars/SP1-Writer.png)
![[Image: SP1-Poet.png]](https://www.save-point.org/images/userbars/SP1-Poet.png)
![[Image: SP1-PixelArtist.png]](https://www.save-point.org/images/userbars/SP1-PixelArtist.png)
![[Image: SP1-Reporter.png]](https://i.postimg.cc/GmxWbHyL/SP1-Reporter.png)
My Original Stories (available in English and Spanish)
List of Compiled Binary Executables I have published...
HiddenChest & Roole
Give me a free copy of your completed game if you include at least 3 of my scripts!
data:image/s3,"s3://crabby-images/c73f7/c73f78094c99ef8406c5071a2249b68c5211d9ab" alt="Laughing + Tongue sticking out Laughing + Tongue sticking out"
Just some scripts I've already published on the board...
KyoGemBoost XP VX & ACE, RandomEnkounters XP, KSkillShop XP, Kolloseum States XP, KEvents XP, KScenario XP & Gosu, KyoPrizeShop XP Mangostan, Kuests XP, KyoDiscounts XP VX, ACE & MV, KChest XP VX & ACE 2016, KTelePort XP, KSkillMax XP & VX & ACE, Gem Roulette XP VX & VX Ace, KRespawnPoint XP, VX & VX Ace, GiveAway XP VX & ACE, Klearance XP VX & ACE, KUnits XP VX, ACE & Gosu 2017, KLevel XP, KRumors XP & ACE, KMonsterPals XP VX & ACE, KStatsRefill XP VX & ACE, KLotto XP VX & ACE, KItemDesc XP & VX, KPocket XP & VX, OpenChest XP VX & ACE