Jump to content
rm4453

(SOLVED)Calling Function That Calls Original Function

Recommended Posts

rm4453

How would I get this code to work? If not possible/If there is a better way... How would I do it? I can't seem to get it to work properly...

 

Func Go()
;Do stuff
Re-Go()
EndFunc

Func Re-Go()
Go()
EndFunc

 

Edited by rm4453
(Solved)

Share this post


Link to post
Share on other sites
Dgameman1

Not sure why you don't just use a loop but here you go

Go()

Func Go()
    ;DoStuff
    ReGo()
EndFunc   ;==>Go

Func ReGo()
    Go()
EndFunc   ;==>Re-Go

 

Share this post


Link to post
Share on other sites
rm4453
18 minutes ago, Dgameman1 said:

Not sure why you don't just use a loop but here you go

Go()

Func Go()
    ;DoStuff
    ReGo()
EndFunc   ;==>Go

Func ReGo()
    Go()
EndFunc   ;==>Re-Go

 

Ok so there is a better way? if so how would I do this "loop" I don't want it to be a while 1 infinite loop because the func go() checks to see if a variable has changed or not before it runs itself all of the way... "however I need it to for sure run the first part even if that variable has not changed..."

Share this post


Link to post
Share on other sites
InunoTaishou

Post some more code, a better example of what you're trying to accomplish, because I don't understand.

Putting a loop in the Go function that calls Go would be more effective.

Share this post


Link to post
Share on other sites
rm4453
21 minutes ago, InunoTaishou said:

Post some more code, a better example of what you're trying to accomplish, because I don't understand.

Putting a loop in the Go function that calls Go would be more effective.

Here is a retry at the code Will that work?

 

Go()

Func Go()
Do
;Do Stuff

If $Stop_Submit = 0 Then
;Do More Stuff
Else

Endif

$rand = Random(800, 1150)
$PIIM = ($rand * 60 * GUICtrlRead($Post_Interval_In_Minutes)) ; PIIM = Park Interval In Minutes Use RAND for variation so Server Time is Limited
$PIIMR = $PIIM / 60000 ; PIIMR = Park Interval In Minutes Recalculated (converted to minutes)
$continue = MsgBox(4, "Continue?", "Click NO To Stop Submission Proccess or Click YES To Continue Submitting . This Box Will Timeout And Continue Submitting In " & $PIIMR & " Minutes", $PIIMR)
If $continue = 7 Then
$Stop_Submit = 1
Else

EndIf

Until $Stop_Submit = 1
Endfunc

 

18 minutes ago, JohnOne said:

What you have there is called recursion. I'm sure it has its place, but I've never needed it.

If you use recursion wrong it will crash your script eventually, or AutoIt will end it.

Thanks for the terminology :D I think I found a simpler way.... :D That code up there is what I think might work... can either of you confirm for me?

Edited by rm4453
Fixed spelling error

Share this post


Link to post
Share on other sites
InunoTaishou

Nasty. It would work but idk why you wouldn't just return. I can't make your example work since I don't have your variables and the GUI, but maybe this will give you an idea.

Go()

Func Go()
    Local $iLoops = 0
    Local $iTimer = TimerInit()
    While (True)
        ConsoleWrite("Currently looped count: " & $iLoops & @LF)

        If (TimerDiff($iTimer) > 3000) Then
            If (MsgBox(4, "Continue?", "Would you like to continue looping?") = 7) Then
                Return ConsoleWrite("Finally exited that loop!" & @LF)
            Else
                ConsoleWrite("User opted to continue looping >.<" & @LF)
                $iTimer = TimerInit()
            EndIf
        EndIf

        Sleep(200)
        $iLoops += 1
    WEnd
EndFunc

 

Share this post


Link to post
Share on other sites
rm4453
1 minute ago, InunoTaishou said:

Nasty. It would work but idk why you wouldn't just return. I can't make your example work since I don't have your variables and the GUI, but maybe this will give you an idea.

Go()

Func Go()
    Local $iLoops = 0
    Local $iTimer = TimerInit()
    While (True)
        ConsoleWrite("Currently looped count: " & $iLoops & @LF)

        If (TimerDiff($iTimer) > 3000) Then
            If (MsgBox(4, "Continue?", "Would you like to continue looping?") = 7) Then
                Return ConsoleWrite("Finally exited that loop!" & @LF)
            Else
                ConsoleWrite("User opted to continue looping >.<" & @LF)
                $iTimer = TimerInit()
            EndIf
        EndIf

        Sleep(200)
        $iLoops += 1
    WEnd
EndFunc

 

I kind of understand that... however I am using a Somewhat Random time that is based off of a user selection for the timeout interval "how long the message box will essentially "pause" the script while allowing the user to still stop it if need be..." That way It will only submit the information to the server when they need it to instead of over polling my system and their system... Your code is kind of confusing to me if you could explain to me how it works that would be very much appreciated! Thanks! (I also want them to be able to see when the next submission will occur so I will be including a timestamp for next submission)

Share this post


Link to post
Share on other sites
InunoTaishou

All my code does is infinitely loop (While (True)) until the user clicks "No" on the message box. I didn't want the MessageBox to pop up every milisecond so I put it on a timer for every 3 seconds. (TimerDiff($iTimer) > 3000, so when the difference between the current time and when the timer was started is greater than 3000.)

Once you hit "No" on the MessageBox then I return. This might be the part where you do your Stop and Submit stuff. If you hit "Yes" (to continue) then I reset the timer so you get another MessageBox in 3 minutes.

Share this post


Link to post
Share on other sites
rm4453
6 minutes ago, InunoTaishou said:

All my code does is infinitely loop (While (True)) until the user clicks "No" on the message box. I didn't want the MessageBox to pop up every milisecond so I put it on a timer for every 3 seconds. (TimerDiff($iTimer) > 3000, so when the difference between the current time and when the timer was started is greater than 3000.)

Once you hit "No" on the MessageBox then I return. This might be the part where you do your Stop and Submit stuff. If you hit "Yes" (to continue) then I reset the timer so you get another MessageBox in 3 minutes.

Okay that makes a little bit more sense... Any way you could adapt it for me so I can see how I would implement it?

$PIIM = Park Interval In Minutes (How long to essentially stop the script and wait)

$Post_Interval_In_Minutes = How Long In Minutes The User Wanted To Have The Script Wait

$PIIM is calculated by getting a random number between 800 (aka 800 milliseconds) and 1150 (aka 1150 milliseconds) and multiplying by 60 and $Post_Interval_In_Minutes

$PIIMR is calculated by dividing PIIM by 60000 (60000 milliseconds = 1 minute)

Share this post


Link to post
Share on other sites
rm4453

ERROR! I accidentally messed up my code! LOL Let me repost sorry guys... put actions in wrong area... XD *A DERPA DERP*

 

Go()

Func Go()
Do
;Do Stuff

If $Stop_Submit = 0 Then
    ;Do More Stuff

    $rand = Random(800, 1150)
    $PIIM = ($rand * 60 * GUICtrlRead($Post_Interval_In_Minutes)) ; PIIM = Park Interval In Minutes Use RAND for variation so Server Time is Limited
    $PIIMR = $PIIM / 60000 ; PIIMR = Park Interval In Minutes Recalculated (converted to minutes)
    $continue = MsgBox(4, "Continue?", "Click NO To Stop Submission Proccess or Click YES To Continue Submitting . This Box Will Timeout And Continue Submitting In " & $PIIMR & " Minutes", $PIIMR)
    
        If $continue = 7 Then
        $Stop_Submit = 1
    Else

    EndIf

Else

Endif

Until $Stop_Submit = 1
Endfunc

Sorry bout that guys... I misplaced where the code should have gone :sweating:

Share this post


Link to post
Share on other sites
InunoTaishou

Something like this maybe

Go()

Func Go()
    Local $Post_Interval_In_Minutes = 1
    Local $Stop_Submit = False

    While (Not $Stop_Submit)
        ; Random number between 800 and 1150 * 60 * the minutes read from the GUI Control, then converted to minutes
        Local $rand = Random(800, 1150)
        Local $PIIM = ($rand * 60 * $Post_Interval_In_Minutes) ; PIIM = Park Interval In Minutes Use RAND for variation so Server Time is Limited
        Local $PIIMR = $PIIM / 60000 ; PIIMR = Park Interval In Minutes Recalculated (converted to minutes)

        If (MsgBox(4, "Continue?", "Click NO To Stop Submission Proccess or Click YES To Continue Submitting . This Box Will Timeout And Continue Submitting In " & $PIIMR & " Minutes", $PIIMR) = 7) Then
            $Stop_Submit = True
        Else
            ConsoleWrite("Continue Submitting" & @LF)
        EndIf
    WEnd

    ConsoleWrite("Stop Submitting" & @LF)
EndFunc   ;==>Go

You've got the wrong Timeout for MsgBox though.

Share this post


Link to post
Share on other sites
rm4453
5 minutes ago, InunoTaishou said:

Something like this maybe

Go()

Func Go()
    Local $Post_Interval_In_Minutes = 1
    Local $Stop_Submit = False

    While (Not $Stop_Submit)
        ; Random number between 800 and 1150 * 60 * the minutes read from the GUI Control, then converted to minutes
        Local $rand = Random(800, 1150)
        Local $PIIM = ($rand * 60 * $Post_Interval_In_Minutes) ; PIIM = Park Interval In Minutes Use RAND for variation so Server Time is Limited
        Local $PIIMR = $PIIM / 60000 ; PIIMR = Park Interval In Minutes Recalculated (converted to minutes)

        If (MsgBox(4, "Continue?", "Click NO To Stop Submission Proccess or Click YES To Continue Submitting . This Box Will Timeout And Continue Submitting In " & $PIIMR & " Minutes", $PIIMR) = 7) Then
            $Stop_Submit = True
        Else
            ConsoleWrite("Continue Submitting" & @LF)
        EndIf
    WEnd

    ConsoleWrite("Stop Submitting" & @LF)
EndFunc   ;==>Go

You've got the wrong Timeout for MsgBox though.

Saw that and am fixing it Thanks ! I will look at your code and see if I can figure it out and all that Thanks so much! :lmao:

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • nooneclose
      By nooneclose
      How do I properly convert this to Autoit? This is a VBA macro that I recorded in Excel.
       ActiveSheet.Outline.ShowLevels RowLevels:=2 I need this to close my subtotal once it is finished. 
      any help will be greatly appreciated. 
    • iMacg3
      By iMacg3
      Hi,
      I was looking into a way to delete a registry key (not a specific value, an entire key) if it is present. I was considering using RegRead and RegDelete. However, RegRead appears to only read values, not just keys. Is there a way to delete an entire registry key if it is present? I have heard that the below function may help.
       
      #include-once ; #UDF# ======================================================================================================================= ; Title .........: Reads\Search the name of a Key\Subkey\Value ; AutoIt Version : 3.3.8.1 ; Language ......: English ; Description ...: Lists all Keys\Subkeys\Values in a specified registry key ; Author(s) .....: DXRW4E ; Notes .........: ; =============================================================================================================================== ; #CURRENT# ===================================================================================================================== ;~ _RegEnumKeyEx ;~ _RegEnumValEx ; =============================================================================================================================== #Region ;**** Global constants and vars **** Global Const $sValueTypes[12] = ["REG_NONE","REG_SZ","REG_EXPAND_SZ","REG_BINARY","REG_DWORD","REG_DWORD_BIG_ENDIAN","REG_LINK","REG_MULTI_SZ","REG_RESOURCE_LIST","REG_FULL_RESOURCE_DESCRIPTOR","REG_RESOURCE_REQUIREMENTS_LIST","REG_QWORD"] #EndRegion ;**** Global constants and vars **** ; #FUNCTION# ======================================================================================================================== ; Name...........: _RegEnumKeyEx ; Description ...: Lists all subkeys in a specified registry key ; Syntax.........: _RegEnumKeyEx($KeyName[, $iFlag = 0[, $sFilter = "*"]]) ; Parameters ....: $KeyName - The registry key to read. ; $iFlag - Optional specifies Recursion (add the flags together for multiple operations): ; |$iFlag = 0 (Default) All Key-SubKeys Recursive Mod ; |$iFlag = 1 All SubKeys Not Recursive Mod ; |$iFlag = 2 Include in ArrayList in the first element $KeyName ; |$iFlag = 16 $sFilter do Case-Sensitive matching (By Default $sFilter do Case-Insensitive matching) ; |$iFlag = 32 Disable the return the count in the first element - effectively makes the array 0-based (must use UBound() to get the size in this case). ; By Default the first element ($array[0]) contains the number of strings returned, the remaining elements ($array[1], $array[2], etc.) ; |$iFlag = 64 $sFilter is REGEXP Mod, See Pattern Parameters in StringRegExp ; |$iFlag = 128 Enum value's name (_RegEnumKeyEx Return a 2D array, maximum Array Size limit is 3999744 Key\Value) ; |$iFlag = 256 Reads a value data, this flag will be ignored if the $iFlag = 128 is not set ; $sFilter - Optional the filter to use, default is *. (Multiple filter groups such as "All "*.XXx|*.YYY|*.ZZZ") ; Search the Autoit3 helpfile for the word "WildCards" For details. ; $vFilter - Optional the filter to use for ValueName, $vFilter will be ignored if the $iFlag = 128 is not set ; default is *. (Multiple filter groups such as "All "*.XXx|*.YYY|*.ZZZ") Search the Autoit3 helpfile for the word "WildCards" For details. ; $iValueTypes - Optional, set Value Types to search (Default $iValueTypes = 0 Read All), $iValueTypes will be ignored if the $iFlag = 128 is not set ; (add the flags together for multiple operations): ; 1 = REG_SZ ; 2 = REG_EXPAND_SZ ; 3 = REG_BINARY ; 4 = REG_DWORD ; 5 = REG_DWORD_BIG_ENDIAN ; 6 = REG_LINK ; 7 = REG_MULTI_SZ ; 8 = REG_RESOURCE_LIST ; 9 = REG_FULL_RESOURCE_DESCRIPTOR ; 10 = REG_RESOURCE_REQUIREMENTS_LIST ; 11 = REG_QWORD ; Return values .: Success - Return Array List (See Remarks) ; Failure - @Error ; |1 = Invalid $sFilter ; |2 = No Key-SubKey(s) Found ; |3 = Invalid $vFilter ; |4 = No Value-Name(s) Found ; Author ........: DXRW4E ; Modified.......: ; Remarks .......: The array returned is one-dimensional and is made up as follows: ; $array[0] = Number of Key-SubKeys returned ; $array[1] = 1st Key\SubKeys ; $array[2] = 2nd Key\SubKeys ; $array[3] = 3rd Key\SubKeys ; $array[n] = nth Key\SubKeys ; ; If is set the $iFlag = 128 The array returned is 2D array and is made up as follows: ; $array[0][0] = Number of Key-SubKeys returned ; $array[1][0] = 1st Key\SubKeys ; $array[1][1] = 1st Value name ; $array[1][2] = 1st Value Type (REG_NONE or REG_SZ or REG_EXPAND_SZ ect ect) ; $array[1][3] = 1st Value Data (If is set $iFlag = 256 Else Value Data = "") ; $array[2][0] = 2nd Key\SubKeys ; $array[2][1] = 2nd Value name ; $array[2][2] = 2nd Value Type (REG_NONE or REG_SZ or REG_EXPAND_SZ ect ect) ; $array[2][3] = 2nd Value Data (If is set $iFlag = 256 Else Value Data = "") ; $array[n][0] = nth Key\SubKeys ; Related .......: _RegEnumValEx() ; Link ..........: ; Example .......: _RegEnumKeyEx("HKEY_CURRENT_USER\Software\AutoIt v3") ; Note ..........: ; =================================================================================================================================== Func _RegEnumKeyEx($KeyName, $iFlag = 0, $sFilter = "*", $vFilter = "*", $iValueTypes = 0) If StringRegExp($sFilter, StringReplace("^\s*$|\v|\\|^\||\|\||\|$", Chr(BitAND($iFlag, 64) + 28) & "\|^\||\|\||\|$", "\\\\")) Then Return SetError(1, 0, "") Local $IndexSubKey[101] = [100], $SubKeyName, $BS = "\", $sKeyList, $I = 1, $sKeyFlag = BitAND($iFlag, 1), $sKeyFilter = StringReplace($sFilter, "*", "") If BitAND($iFlag, 2) Then $sKeyList = @LF & $KeyName If Not BitAND($iFlag, 64) Then $sFilter = StringRegExpReplace(BitAND($iFlag, 16) & "(?i)(", "16\(\?\i\)|\d+", "") & StringRegExpReplace(StringRegExpReplace(StringRegExpReplace(StringRegExpReplace($sFilter, "[^*?|]+", "\\Q$0\\E"), "\\E(?=\||$)", "$0\$"), "(?<=^|\|)\\Q", "^$0"), "\*+", ".*") & ")" While $I $IndexSubKey[$I] += 1 $SubKeyName = RegEnumKey($KeyName, $IndexSubKey[$I]) If @error Then $IndexSubKey[$I] = 0 $I -= 1 $KeyName = StringLeft($KeyName, StringInStr($KeyName, "\", 1, -1) - 1) ContinueLoop EndIf If $sKeyFilter Then If StringRegExp($SubKeyName, $sFilter) Then $sKeyList &= @LF & $KeyName & $BS & $SubKeyName Else $sKeyList &= @LF & $KeyName & $BS & $SubKeyName EndIf If $sKeyFlag Then ContinueLoop $I += 1 If $I > $IndexSubKey[0] Then $IndexSubKey[0] += 100 ReDim $IndexSubKey[$IndexSubKey[0] + 1] EndIf $KeyName &= $BS & $SubKeyName WEnd If Not $sKeyList Then Return SetError(2, 0, "") If BitAND($iFlag, 128) <> 128 Then Return StringSplit(StringTrimLeft($sKeyList, 1), @LF, StringReplace(BitAND($iFlag, 32), "32", 2)) $sKeyList = _RegEnumValEx(StringSplit(StringTrimLeft($sKeyList, 1), @LF), $iFlag, $vFilter, $iValueTypes) Return SetError(@Error, 0, $sKeyList) EndFunc ; #FUNCTION# ======================================================================================================================== ; Name...........: _RegEnumValEx ; Description ...: Lists all values in a specified registry key ; Syntax.........: _RegEnumValEx($KeyName[, $iFlag = 0[, $sFilter = "*"]]) ; Parameters ....: $KeyName - The registry key to read Or one-dimensional array RegKeyList ; use _RegEnumKeyEx() to get $RegKeyList (example $RegKeyList = [3, 1st Key\SubKeys, 2st Key\SubKeys, nth Key\SubKeys]) ; |$iFlag = 16 $sFilter do Case-Sensitive matching (By Default $sFilter do Case-Insensitive matching) ; |$iFlag = 32 Disable the return the count in the first element - effectively makes the array 0-based (must use UBound() to get the size in this case). ; By Default the first element ($array[0]) contains the number of strings returned, the remaining elements ($array[1], $array[2], etc.) ; |$iFlag = 64 $sFilter is REGEXP Mod, See Pattern Parameters in StringRegExp ; |$iFlag = 256 Reads a value data ; $sFilter - Optional the filter to use, default is *. (Multiple filter groups such as "All "*.XXx|*.YYY|*.ZZZ") ; Search the Autoit3 helpfile for the word "WildCards" For details. ; $iValueTypes - Optional, set Value Types to search (Default $iValueTypes = 0 Read All) ; (add the flags together for multiple operations): ; 1 = REG_SZ ; 2 = REG_EXPAND_SZ ; 3 = REG_BINARY ; 4 = REG_DWORD ; 5 = REG_DWORD_BIG_ENDIAN ; 6 = REG_LINK ; 7 = REG_MULTI_SZ ; 8 = REG_RESOURCE_LIST ; 9 = REG_FULL_RESOURCE_DESCRIPTOR ; 10 = REG_RESOURCE_REQUIREMENTS_LIST ; 11 = REG_QWORD ; Return values .: Success - Return Array List (See Remarks) ; Failure - @Error ; |3 = Invalid $sFilter ; |4 = No Value-Name(s) Found ; Author ........: DXRW4E ; Modified.......: ; Remarks .......: The array returned is 2D array and is made up as follows: ; $array[0][0] = Number of Key-SubKeys returned ; $array[1][0] = 1st Key\SubKeys ; $array[1][1] = 1st Value name ; $array[1][2] = 1st Value Type (REG_NONE or REG_SZ or REG_EXPAND_SZ ect ect) ; $array[1][3] = 1st Value Data (If is set $iFlag = 256 Else Value Data = "") ; $array[2][0] = 2nd Key\SubKeys ; $array[2][1] = 2nd Value name ; $array[2][2] = 2nd Value Type (REG_NONE or REG_SZ or REG_EXPAND_SZ ect ect) ; $array[2][3] = 2nd Value Data (If is set $iFlag = 256 Else Value Data = "") ; $array[n][0] = nth Key\SubKeys ; Related .......: _RegEnumKeyEx() ; Link ..........: ; Example .......: _RegEnumValEx("HKEY_CURRENT_USER\Software\AutoIt v3") ; Note ..........: ; =================================================================================================================================== Func _RegEnumValEx($aKeyList, $iFlag = 0, $sFilter = "*", $iValueTypes = 0) If StringRegExp($sFilter, "\v") Then Return SetError(3, 0, "") If Not IsArray($aKeyList) Then $aKeyList = StringSplit($aKeyList, @LF) Local $aKeyValList[1954][4], $iKeyVal = Int(BitAND($iFlag, 32) = 0), $sKeyVal = 1953, $sRegEnumVal, $iRegEnumVal, $RegRead = BitAND($iFlag, 256), $vFilter = StringReplace($sFilter, "*", "") If Not BitAND($iFlag, 64) Then $sFilter = StringRegExpReplace(BitAND($iFlag, 16) & "(?i)(", "16\(\?\i\)|\d+", "") & StringRegExpReplace(StringRegExpReplace(StringRegExpReplace(StringRegExpReplace($sFilter, "[^*?|]+", "\\Q$0\\E"), "\\E(?=\||$)", "$0\$"), "(?<=^|\|)\\Q", "^$0"), "\*+", ".*") & ")" For $i = 1 To $aKeyList[0] $iRegEnumVal = 0 While 1 If $iKeyVal = $sKeyVal Then If $sKeyVal = 3999744 Then ExitLoop $sKeyVal *= 2 ReDim $aKeyValList[$sKeyVal + 1][4] EndIf $aKeyValList[$iKeyVal][0] = $aKeyList[$i] $iRegEnumVal += 1 $sRegEnumVal = RegEnumVal($aKeyList[$i], $iRegEnumVal) If @Error <> 0 Then If $iRegEnumVal = 1 And $vFilter = "" Then $iKeyVal += 1 ExitLoop EndIf $aKeyValList[$iKeyVal][2] = $sValueTypes[@Extended] If BitAND(@Extended, $iValueTypes) <> $iValueTypes Then ContinueLoop If $vFilter And Not StringRegExp($sRegEnumVal, $sFilter) Then ContinueLoop $aKeyValList[$iKeyVal][1] = $sRegEnumVal If $RegRead Then $aKeyValList[$iKeyVal][3] = RegRead($aKeyList[$i], $sRegEnumVal) $iKeyVal += 1 WEnd Next $sRegEnumVal = $iKeyVal - Int(BitAND($iFlag, 32) = 0) If Not $sRegEnumVal Or ($sRegEnumVal = 1 And $vFilter = "" And $aKeyValList[$iKeyVal - $sRegEnumVal][2] = "") Then Return SetError(4, 0, "") ReDim $aKeyValList[$iKeyVal][4] If Not BitAND($iFlag, 32) Then $aKeyValList[0][0] = $iKeyVal - 1 Return $aKeyValList EndFunc Thanks.
       
    • great77
      By great77
      ; put the root in a variable $sRoot = "C:\Project\PHexample\" Global $sCurrentTime = _NowCalc() ; We can use that variable here Global $aList = _FileListToArray($sRoot, Default, 2) If @error Then Exit ;;;;;;MsgBox(0, "Error", "_FileListToArray returned @error = " & @error) ;;;;;;;;;;;This is a loop that runs from 1 to the number of items listed in the first element of the returned  array For $i = 1 To UBound($aList) - 1     MsgBox(0, "Folder date", $sRoot & "" & $aList[$i] & @CRLF & @CRLF & FileGetTime($sRoot & "" & $aList[$i], 1, 1))     MsgBox(0, "Folder date", FileGetTime($sRoot & "" & $aList[$i], 1, 1))      $a_filenew = StringReplace(StringReplace(StringReplace(_NowCalc(), "/", ""), ":", ""), " ", "")       MsgBox(0, "Folder date", $a_filenew) $adex =  _DateDiff('D', FileGetTime($sRoot & "" & $aList[$i], 1, 1), $a_filenew)  MsgBox(0,"ade", $adex) Next I have a code as seen above, but the difference in time is returning zero. I understand that the date yyyymmddhhmmss but how can I find the difference.
      The purpose is to try find the difference in days. Any suggestion?  
    • TrashBoat
      By TrashBoat
      So i have been working on this 2d physics game and added some physics to it but got stuck on this problem that the character ( the cube ) is sliding all the time but it should not do that because of this friction function:
      If $horizontalVelocity > 0 Then If $inAir Then $currFriction = $airFriction $horizontalVelocity -= $currFriction $birbX += $horizontalVelocity EndIf this line "$horizontalVelocity -= $currFriction" should nullify the velocity to 0 but it stays somewhere in 0.09. How do i fix this?
      Here's the game's source code and what i have done so far:
      Now i don't expect you reading my nasty code and understanding what it does but any help would be appreciated.
       
      Edit: I guess the problem is solved, i have updated the source code if anyone needs it.
    • Dzenan03
      By Dzenan03
      I want to make a while loop, that creates variables based on a array. For thist I created the array $iDsO with the number and the name of folders in an other folder. Every folder has a different name an I want to create variables(arrays) for each folder that show me all the files in that folder. For example: I have the Folder \Folder1. In it there are the Folders \1, \2, \3. In 1, 2 and 3 there are some files(.png). The array for Folder1 is $iDsO and now I want to crate the arrays $iDsO1, $iDsO2 and $iDsO3 with the files in them can I make something like this:
      While $iDs > 0 ;$iDs is the number of files in Folder1>> $iDsO[0] $iDs#here should come the Foldername for example '1'# = _FileListtoArray(@ProgramFilesDir&"\Folder1\"&$iDsO[$iDs]) $iDs = $iDs - 1 Wend So that in the End I have three variabels ($iDs1, $iDs2 and $iDs3)
       
      Is this posible or if not what could I do instead ( I don´t know the number of folders in Folder1 in the begining).
×