[SOLVED] Anything wrong with this code?
Posted: Mon Feb 24, 2025 10:23 am
				
				EDIT: Problem found: https://www.purebasic.fr/english/viewtopic.php?t=86390
I'm trying to switch from ASM to C, but I now have crashes that never happened before (no error log). The following procedure does not run independently, but maybe you'll see something obviously wrong in my code:
And when it does not crash, there is ~2 seconds lag for no obvious reason. I can also see "RR2" printed twice in a row, which to me should be impossible without printing "RR1" before?
Debug log looks like this:
RR1
RR2 (lag/crash here)
match$
RR2
			I'm trying to switch from ASM to C, but I now have crashes that never happened before (no error log). The following procedure does not run independently, but maybe you'll see something obviously wrong in my code:
Code: Select all
Procedure$ ReplaceReplacers(line$)
    Define regex
    
    Debug "RR1" ; DEBUG
    
    regex = CreateRegularExpression(#PB_Any, "\*\*(.*?)\*\*")
    ExamineRegularExpression(regex, line$)
    While NextRegularExpressionMatch(regex)
      Define match$ = RegularExpressionMatchString(regex)
      match$ = Trim(ReplaceString(match$, "**", ""))
      Define func_line$ = StringField(match$, 1, "(")
      Define args_line$ = StringField(StringField(match$, 2, "("), 1, ")")
      args_line$ = Trim(ReplaceString(args_line$, ", ", ","))
      args_line$ = ReplaceReplacers(args_line$)
      Define func.__RuntimeReplacer = GetRuntimeInteger("RH_Encounter::" + func_line$ + "()")
      If func = 0
        xyError::FatalError("Error at replacer " + match$ + ": '" + func_line$ + "' is not a valid function.")
      EndIf
      line$ = ReplaceString(line$, RegularExpressionMatchString(regex), func(args_line$), #PB_String_CaseSensitive, 1, 1)
      
      Debug match$ ; DEBUG
      
    Wend
    FreeRegularExpression(regex)
    
    Debug "RR2" ; DEBUG
    
    ProcedureReturn line$
  EndProcedure
  Debug log looks like this:
RR1
RR2 (lag/crash here)
match$
RR2
 because it's not declared at the right place, it's not a float at in the procedure's scope and then it gets auto-declared as an integer (32/64 bits system default type). There's also nothing wrong with using Globals, especially when you do it right. When many variables are always used in groups, you may want to use a structure/pointer perhaps; big apps often do this with a "GlobalsStruct" that holds all configuration and important states.
 because it's not declared at the right place, it's not a float at in the procedure's scope and then it gets auto-declared as an integer (32/64 bits system default type). There's also nothing wrong with using Globals, especially when you do it right. When many variables are always used in groups, you may want to use a structure/pointer perhaps; big apps often do this with a "GlobalsStruct" that holds all configuration and important states.