Tetris - Bitte testen II



  • WebFritzi schrieb:

    Scheint bei dir nicht zu funktionieren. Kannst du dir vorstellen warum? Bei mir befindet sich der Temp-Ordner hier: C:\Dokumente und Einstellungen\WebFritzi\Lokale Einstellungen\Temp. Ich hole mir den Pfad mit der WinAPI-Funktion GetTempPath()

    Ich schau's mir mal mit dem Process Explorer an (die access violation solltest du IMHO trotdem verhindern).



  • 17832	20:54:23,4046316	Tetrissimo.exe	3352	CreateFile	C:\Windows\Prefetch\TETRISSIMO.EXE-89595503.pf	NAME NOT FOUND	Desired Access: Generic Read, Disposition: Open, Options: Synchronous IO Non-Alert, Attributes: n/a, ShareMode: , AllocationSize: n/a
    17882	20:54:23,4069482	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.exe.Local	NAME NOT FOUND	
    17997	20:54:23,4122957	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\WINMM.DLL	NAME NOT FOUND	
    18038	20:54:23,4138437	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\OLEACC.dll	NAME NOT FOUND	
    18358	20:54:23,4241427	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.exe.Local	NAME NOT FOUND	
    18424	20:54:23,4266134	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.exe.Local	NAME NOT FOUND	
    18489	20:54:23,4290398	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\OLEACCRC.DLL	NAME NOT FOUND	
    18884	20:54:23,4427266	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DEU	NAME NOT FOUND	
    18886	20:54:23,4428253	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DEU	NAME NOT FOUND	
    18893	20:54:23,4429154	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DEU.DLL	NAME NOT FOUND	
    18896	20:54:23,4430198	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DE	NAME NOT FOUND	
    18898	20:54:23,4431104	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DE	NAME NOT FOUND	
    18901	20:54:23,4431979	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.DE.DLL	NAME NOT FOUND	
    18924	20:54:23,4439969	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\uxtheme.dll	NAME NOT FOUND	
    19308	20:54:23,4587081	Tetrissimo.exe	3352	CreateFile	C:\Windows\System32\uxtheme.dll.Config	NAME NOT FOUND	Desired Access: Generic Read/Execute, Disposition: Open, Options: Synchronous IO Non-Alert, Non-Directory File, Attributes: n/a, ShareMode: Read, Delete, AllocationSize: n/a
    19316	20:54:23,4593677	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.exe.Local	NAME NOT FOUND	
    23019	20:54:24,9582999	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\Tetrissimo.exe.Local	NAME NOT FOUND	
    23748	20:54:29,3331138	Tetrissimo.exe	3352	QueryOpen	D:\Profildaten\Michael\Desktop\imageres.dll	NAME NOT FOUND
    

    Keine Ahnung ich seh hier nichts von Midi-Dateien. Wie sollen die dann heißen?



  • Optimizer schrieb:

    die access violation solltest du IMHO trotdem verhindern

    Ja, klar.

    Optimizer schrieb:

    Keine Ahnung ich seh hier nichts von Midi-Dateien. Wie sollen die dann heißen?

    Sind zwei Stück. Die eine heißt Tetrissimo - TITLE_MIDI und die andere Tetrissimo - HIGHSCORE_MIDI. Aber da ja eh vorher ein Fehler passiert, ist schon irgendwie klar, warum keine Dateien erstellt werden. Wann genau kommt denn die AccessViolation? Evtl. beim Klicken auf Game->New? Das einzige mal, dass ich eine Funktion aus shlwapi.dll benutze, ist hier:

    BOOL CMidiFile::LoadFromResource(LPCTSTR res_name, LPCTSTR str_id)
    {  // str_id is a string id which. Choose one per song.
       TCHAR fn[MAX_PATH];
       GetTempPath(MAX_PATH, fn);
       strcpy(fn + lstrlen(fn), str_id);
    
       if( !PathFileExists(fn) ) // <-- das ist die Funktion
       {
          ...
    


  • Ja, beim Klicken auf Game -> New.



  • Kann das evtl. mit fehlenden Admin-Rechten zusammenhängen?



  • TCHAR fn[MAX_PATH];
    GetTempPath(MAX_PATH, fn);
    strcpy(fn + lstrlen(fn), str_id);

    Das läuft über wenn der Pfad länger als MAX_PATH/2 ist.



  • DrGreenthumb schrieb:

    TCHAR fn[MAX_PATH];
    GetTempPath(MAX_PATH, fn);
    strcpy(fn + lstrlen(fn), str_id);

    Das läuft über wenn der Pfad länger als MAX_PATH/2 ist.

    Wieso das? 😕

    @Optimizer: Wo liegt denn dein TEMP-Pfad?



  • Wird bei GetTempPath eigentlich auf MAX_PATH gekürzt?



  • WebFritzi schrieb:

    DrGreenthumb schrieb:

    TCHAR fn[MAX_PATH];
    GetTempPath(MAX_PATH, fn);
    strcpy(fn + lstrlen(fn), str_id);

    Das läuft über wenn der Pfad länger als MAX_PATH/2 ist.

    Wieso das? 😕

    @Optimizer: Wo liegt denn dein TEMP-Pfad?

    C:\Users\Michael\AppData\Local\Temp\
    Da drin hast du alle Rechte, die du dir nur wünschen kannst.

    WebFritzi schrieb:

    Kann das evtl. mit fehlenden Admin-Rechten zusammenhängen?

    Ich weiß nicht, was du sonst noch so machst. Als Admin führe ich das Programm nicht aus, ich habe jetzt aber auch keine besonders restriktiven Rechte. Du kannst mir ja mal dein Programm komplett schicken, dann sag ich dir die Code-Zeile. Amsonsten ist mir im ProcessMonitor auch nichts ungewöhnliches aufgefallen, aber ich kenn mich mit dem Teil auch nicht aus.



  • WebFritzi schrieb:

    DrGreenthumb schrieb:

    TCHAR fn[MAX_PATH];
    GetTempPath(MAX_PATH, fn);
    strcpy(fn + lstrlen(fn), str_id);

    Das läuft über wenn der Pfad länger als MAX_PATH/2 ist.

    Wieso das? 😕

    Wie ich da auf MAX_PATH/2 gekommen bin weiß ich jetzt auch nicht mehr; war schon spät.

    Kann aber trotzdem überlaufen. GetTempPath schreibt u.U. den ganzen Buffer voll und dann schreibst du noch die str_id dahinter.



  • DrGreenthumb schrieb:

    WebFritzi schrieb:

    DrGreenthumb schrieb:

    TCHAR fn[MAX_PATH];
    GetTempPath(MAX_PATH, fn);
    strcpy(fn + lstrlen(fn), str_id);

    Das läuft über wenn der Pfad länger als MAX_PATH/2 ist.

    Wieso das? 😕

    Wie ich da auf MAX_PATH/2 gekommen bin weiß ich jetzt auch nicht mehr; war schon spät.

    Kann aber trotzdem überlaufen. GetTempPath schreibt u.U. den ganzen Buffer voll und dann schreibst du noch die str_id dahinter.

    Ja, stimmt. Ist nicht bombensicher. Ich habe es angepasst:

    BOOL CMidiFile::LoadFromResource(LPCTSTR res_name, LPCTSTR str_id)
    {  // str_id is a string id which. Choose one per song.
       LPTSTR fn;
       DWORD buf_len = GetTempPath(0, NULL);
       fn = new TCHAR[buf_len + lstrlen(str_id) + 1];
       GetTempPath(buf_len, fn);
       lstrcpy(fn + lstrlen(fn), str_id);
    
       if( !PathFileExists(fn) )
       {
          ...
    

    EDIT: Habe die EXE geupdatet. Könntest du die neue EXE nochmal bitte bei dir testen, Optimizer.



  • Ist nicht behoben.



  • @Opti: Hätte nicht damit gerechnet, dass du so schnell bist. Hab es da noch nicht raufgeladen gehabt. Bitte bitte nochmal. 🙄

    EDIT: Du erkennst die neue EXE daran, dass sie größer ist als vorher.



  • Ok, ist aber immer noch.
    Größe der .exe: 297.984 Bytes



  • Optimizer schrieb:

    Größe der .exe: 297.984 Bytes

    Äh, nö. Wo hast du die denn her? Wenn ich mir das ZIP-File runterlade und dann entpacke, hat die entpackte EXE eine Größe von 692.736 Bytes. 😮



  • Von deiner Seite und da krieg ich immer noch genau die selbe her.





  • Hä? Wenn ich auf deinen geposteten Link gehe, die Datei herunterlade und dann entpacke, hat die EXE die von mir oben angegebene Größe. Hat das was mit deinem Cache zu tun oder so? 😕 Auf dem Server ist nur noch diese eine Tetrissimo-Datei. Die neue halt. 😕 😕 😕



  • Frickelfox halt. Die access violation ist jetzt eine andere: Zugriff auf Adresse 00000002. Wieder beim Starten des Spiels, wie vorher.



  • Danke für's Testen. Auch in der SHLWAPI.DLL? Ich würd dir ja gerne mein ganzes Projekt schicken, aber ich habe deine Email-Addi nicht. Meine ist webfritzi[bei]gmx.de.


Anmelden zum Antworten