[Erledigt] XP/RGSS: Nach Soft-Reset ungeplante/findbare Loop
Namd.
Nachdem ich jetzt schon eine Weile gesucht hab, muss ich leider euch nach einer Hilfestellung zu meinem Problem fragen:
Ich habe eine kleine Erweiterung and RPG::Sprite vorgenommen. Im Zuge dessen hab ich natürlich auch initialize erweitert.
Wenn ich mein Spiel nun starte, und mit F12 zum Titelbildschirm zurückkehre, bekomm ich in der old_init nen SystemStackError. Seit dem die Erweiterung da ist. Ein Sprite_Character wird unendlich oft geladen.
Sprite_Character ist unverändert
Game_Title lädt auch nur regulär eine Game_Map
und Game_Map ist unverändert
etc.
irgendwo muss ein Fehler drin sein, sonst hätte ich das Problem ja nicht.
Dummerweise müsste ich ja praktisch das komplette Projekt schicken, um euch das checken zu lassen - und das sollt ihr auch nicht.
Meine Frage also: kann ich irgendwie mir ausgeben lassen, WO eine Funktion aufgerufen wurde? Ähnlich wie der Trace einer Fehlermeldung? So dass ich rausfunden kann, an welcher stelle das initialize unendlich aufgerufen wird?
Meine Frage also: kann ich irgendwie mir ausgeben lassen, WO eine Funktion aufgerufen wurde? Ähnlich wie der Trace einer Fehlermeldung? So dass ich rausfunden kann, an welcher stelle das initialize unendlich aufgerufen wird?
...
Das weiß ich leider nicht, aber:
die endlosschleife wird durch den alias befehl verursacht (bzw eigentlich durch die initialize methode).
das liegt daran, dass nur der für dich zugeängliche rgss-teil beim soft-reset neu geladen wird.
die alte RPG::Sprite klasse wird somit nicht neu geladen, weshalb der alias befehl dafür sorgt, dass old_init auf deine initialize methode statt der originalen verweist.
deshalb sind old_init und initialize nach dem soft-reset dieselbe methode und du landest in einer rekursiven endlos-schleife, sobald du initialize aufrufst (bzw ein objekt erzeugst)
Beim Soft-Reset werden alle Scripte im Scripteditor neu ausgeführt. Das kann zu vielerlei Fehlern führen (insbesondere beim Einsatz von alias). Du kannst das Neuausführen des Scripteditors verhindern, in dem du am Anfang des Scripteditors abfragst ob die Scripte schon einmal geladen wurden. Falls ja, dann lass das Main-Script ausführen.
Könnte in etwa so aussehen:
Zitat
Meine Frage also: kann ich irgendwie mir ausgeben lassen, WO eine Funktion aufgerufen wurde? Ähnlich wie der Trace einer Fehlermeldung?
...
Den aktuellen Stacktrace bekommst du mit der Methode Kernel#caller. Aber das hilft dir wenig. Die Endlosschleife ist ja im initialize selbst (genauer: initialize -> old_init -> initialize -> ...)
@ShiningAdvances: Müsste method_defined?(:"old_init") statt defined?(old_init) heißen. Sonst prüfst du nur auf Singletonmethoden.
Danke an euch beide. Dass alles neu eingelesen wird war mir nicht bewusst, das erklärt das Problem definitiv. Ich werd vermutlich allerdings ShiningAdvances Ansatz nehmen - KDs Ansatz heb ich mir potentiell auf, (ich prober die Tage ein wenig damit herum vermutlich), aber meine Konzentration reicht grad nicht, um mir bewusst zu machen, welche Auswirkungen das hat, ausser eben diese aliases zum umgehen - und ob ich da mehr ausser der normalen main-loop einfügen muss. Normal wär ich dazu denk ich in der Lage, aber Konzentration ist grad ein wenig low. Wenn ich Zeit hab da drüber nachzudenken kann es passieren, dass mir das dann doch besser gefällt.
Danke für Kernel#caller. Kann immernoch nützlich sein an nem anderen Punkt bzw aufjedenfall für verbessertes Ruby-Verständnis. Leider noch nicht viel davon ausserhalb der RGSS machen können.
-----Update
Hab KDs Vorschlag umgesetzt, nachdem ich die Simpelheit gesehen hab. Hilft gegen alle weiteren Probleme dieser Art. Hab auch nun mal Entdeckt, dass ich wider Erwarten in KDs Tutorial noch was lernen kann - v.a. über Iteratoren & Blöcke. Aufgrund dessen hätt ich mir einiges einfacher machen können - und werd es in Zukunft auch.