Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Die Delphi-IDE (https://www.delphipraxis.net/62-die-delphi-ide/)
-   -   SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE (https://www.delphipraxis.net/158070-shgetfileinfo-win7-erzeugt-harten-d2010-ide-absturz-mit-fehler-eeface.html)

Jaynder 4. Feb 2011 08:48

SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Hallo,

habe leider erhebliche Probleme, wenn ich SHGetFileInfo verwende und mein Programm aus der IDE heraus starte. Es komme dann in ca. 2 von 3 Fällen eine harter Absturz der IDE mit der Meldung
Code:
 Externe Exception EEFFACE
und ich muss IDE mit dem TaskMgr abschießen und neu starten.

Starte ich das Programm direkt, gibt es keine Probleme.

Es gibt zwar einen Thread zu diesem Thema (https://forums.embarcadero.com/threa...threadID=31348), aber hier ist das Problem definitiv nicht abhängig von einem externen Programm und tritt nur unter Win7 (evtl nur 64 bit) auf. Unter XP ist alles Takko.

Hat jemand eine Idee ?

Snippet:
Code:
  // Get the file type
  if SHGetFileInfo(PWideChar(aFilename), 0, rSHFI, SizeOf(rSHFI), SHGFI_TYPENAME) <> 0 then
  begin
    aInfo.FileType := rSHFI.szTypeName;
  end;

  iRet := SHGetFileInfo(PWideChar(aFilename), 0, rSHFI, SizeOf(rSHFI), SHGFI_EXETYPE);
  if iRet <> 0 then
  begin
    // determine whether the OS can obtain version information
    VerSize := GetFileVersionInfoSize(PChar(aFilename), VerHandle);
    if VerSize > 0 then
    begin
      VerBuf := AllocMem(VerSize);
      try
        with aInfo do
        begin
          CompanyName     := QueryValue('CompanyName');
          FileDescription := QueryValue('FileDescription');
          FileVersion     := QueryValue('FileVersion');
          InternalName    := QueryValue('InternalName');
          LegalCopyRight  := QueryValue('LegalCopyRight');
          LegalTradeMarks := QueryValue('LegalTradeMarks');
          OriginalFileName := QueryValue('OriginalFileName');
          ProductName     := QueryValue('ProductName');
          ProductVersion  := QueryValue('ProductVersion');
          Comments        := QueryValue('Comments');
          SpecialBuildStr := QueryValue('SpecialBuild');
          PrivateBuildStr := QueryValue('PrivateBuild');
          // Fill the VS_FIXEDFILEINFO structure
          FixedFileInfo   := GetFixedFileInfo;
          DebugBuild      := HasdwFileFlags(FixedFileInfo,VS_FF_DEBUG);
          PreRelease      := HasdwFileFlags(FixedFileInfo,VS_FF_PRERELEASE);
          PrivateBuild    := HasdwFileFlags(FixedFileInfo,VS_FF_PRIVATEBUILD);
          SpecialBuild    := HasdwFileFlags(FixedFileInfo,VS_FF_SPECIALBUILD);
          Patched         := HasdwFileFlags(FixedFileInfo,VS_FF_PATCHED);
          InfoInferred    := HasdwFileFlags(FixedFileInfo,VS_FF_INFOINFERRED);
          FileFunction    := GetFileSubType(FixedFileInfo);
        end;

      finally
        FreeMem(VerBuf, VerSize);
      end;

      GetFileInfo(aFilename,aInfo.FileInfoVersion);
      result := True;
    end;
  end

Dezipaitor 4. Feb 2011 09:43

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Hi, die EEFFACE Exception wird geworfen, wenn eine C++ Exception beim Delphiexceptionhandler ankommt und dieser sie nicht umwandeln kann. Siehe
http://www.audacia-software.de/de/bc...on-eefface.htm

Ich kann nur vermuten, dass die Shellfunktion eine Exception wirft, die intern abgefangen wird. Wenn aber Delphi debuggt, dann werden Exceptions normalerweise an den Debugger weitergegeben, der in so einem Fall das Programm anhält und in diesem Fall sich wohl auch selbst :? Das kann ich aber wirklich nur mutmaßen.

Versuche mal eines oder mehrere dieser Dinge:
1. Füge in den Delphi-Optionen DebuggerAusnahmen, die EExternalException hinzu, so dass Delphi da nicht mehr stehenbleibt. (Sorry, hab grad kein Delphi, ka wo das ist)
2. Initialisiere die Struktur rSHFI mit 0 vorher.

Jaynder 4. Feb 2011 10:38

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Danke für die fundierte Antwort an Dezipaitor. Wie es aber Murphy immer so macht, tritt im Moment der Fehler nicht mehr auf. Da ich inzwischen aber auch einiges andere am Programm geändert habe, ist vermutlich die fehlende Initialisierung der Stackvaribalen rSHFI eine gute Idee. Werde es erstmal auskommentiert einbauen, um dies als Lösung verifizieren zu können! Melde mich dann wieder-

Luckie 4. Feb 2011 11:56

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Zitat:

Zitat von Dezipaitor (Beitrag 1079482)
2. Initialisiere die Struktur rSHFI mit 0 vorher.

Das sollte man sowieso immer mit Strukturen machen, die man an eine Funktion übergibt.

Jaynder 4. Feb 2011 12:00

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Zitat:

Zitat von Luckie (Beitrag 1079522)
Zitat:

Zitat von Dezipaitor (Beitrag 1079482)
2. Initialisiere die Struktur rSHFI mit 0 vorher.

Das sollte man sowieso immer mit Strukturen machen, die man an eine Funktion übergibt.

seh ich nicht so, einen out-Parameter soll gefälligst der Lieferant des Ergebnisses initialisieren. Wenns ein var-Parameter ist, hast du recht. Kann man natürlich hier nicht sehen, da es ein API-Call ist:wink:

Luckie 4. Feb 2011 12:05

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Sicher ist sicher. Und was schadet ein Aufruf von ZeroMemory?

Jaynder 4. Feb 2011 12:45

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Zitat:

Zitat von Luckie (Beitrag 1079526)
Sicher ist sicher. Und was schadet ein Aufruf von ZeroMemory?

nichts, außer das die Fingerkuppen durch das Schreiben unnotiger Anweisungen mehr abnutzen :wink:

Außerdem - als Zwischenergebnis zum ursprünglichen Problem- : es nützt in diesem Falle leider auch nichts - der Fehler ist wieder aufgetreten.

Versuche es jetzt mit dem Ignorieren der EExternalException...

Dezipaitor 4. Feb 2011 13:10

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Bei WinAPI Funktionen gibt es keine reine OUT-Parameter. In der MSDN Dok steht auch dazu, dass es ein IN/OUT ist. Weil letztendlich ist es ein Zeiger, der vorher initialisiert werden muss.

Jaynder 5. Feb 2011 10:31

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Weiteres negatives Zwischenergebnis: EExternalExceptions zu ignorieren hilft leider auch nicht. Habe auch versucht, $EEFACE als native BS-Exception zu definierten, was aber auch nichts gebracht hat.

Dezipaitor 5. Feb 2011 13:37

AW: SHGetFileInfo Win7 erzeugt harten D2010-IDE-Absturz mit Fehler EEFACE
 
Dann wäre es nun gut, wenn du den Code soweit vervollständigst, dass man mehr sehen kann. Wie sieht SHGetFileInfo aus? Benutzt du VCL, JEDI? Welche Dateinamen stecken in aFileName ?


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:11 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz