Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Delphi Function (WIMGetMountedImageInfo) (https://www.delphipraxis.net/178081-function-wimgetmountedimageinfo.html)

Sir Rufo 17. Dez 2013 23:39

AW: Function (WIMGetMountedImageInfo)
 
@Zacherl

Folgendes würde ich ändern
  • Wenn Delphi-Referenz durchsuchenLoadLibrary dann auch Delphi-Referenz durchsuchenFreeLibrary inkl. Fehlerbehandlung (Exception)
  • Delphi-Referenz durchsuchenGetLastError nur einmal aufrufen
    Zitat:

    Der Aufruf dieser Funktion setzt in der Regel den Fehlerstatus des Betriebssystems zurück.
  • Da alle anderen Fehlermeldungen in diesem Kontext eine Ausnahme sind, würde ich auch eine Exception werfen
  • Statt
    Delphi-Quellcode:
    PChar
    auf jeden Fall
    Delphi-Quellcode:
    PWideChar
    nehmen, denn hier gibt es nur
    Delphi-Quellcode:
    WCHAR
    (und
    Delphi-Quellcode:
    PChar
    ist abhängig vom Compiler -> bei der nächsten Umstellung des Standard-String-Typs sind wieder alle am Weinen :mrgreen: ).
    Wenn sich die API ändert, dann ändert die sich eben ... nachführen
Delphi-Quellcode:
var
  Lwimgapi                                 : HMODULE;
  LSuccess                                 : Boolean;
  LBuffer                                  : PWIM_MOUNT_INFO_LEVEL0_LIST;
  LBufferLength, LReturnLength, LImageCount : DWord;
  LIdx                                     : Integer;
  LLastError                               : Cardinal;

begin
  Lwimgapi := LoadLibrary( 'wimgapi.dll' );
  if Lwimgapi = 0
  then
    RaiseLastOSError;

  try
    @WIMGetMountedImageInfo := GetProcAddress( Lwimgapi, 'WIMGetMountedImageInfo' );
    LBufferLength          := SizeOf( WIM_MOUNT_INFO_LEVEL0 ) * 8;
    GetMem( LBuffer, LBufferLength );
    try
      repeat
        LSuccess := WIMGetMountedImageInfo( MountedImageInfoLevel0, LImageCount, LBuffer, LBufferLength, LReturnLength );
        if LSuccess
        then
          begin
            for LIdx := 0 to LImageCount - 1 do
              begin
                ShowMessage( StrPas( PWideChar( @LBuffer^[LIdx].WimPath[0] ) ) );
              end;
          end
        else
          begin
            LLastError := GetLastError;
            case LLastError of
              ERROR_INSUFFICIENT_BUFFER :
                begin
                  ReallocMem( LBuffer, LReturnLength );
                end;
            else
              RaiseLastOSError( LLastError );
            end;
          end;
      until LSuccess;
    finally
      FreeMem( LBuffer );
    end;
  finally
    FreeLibrary( Lwimgapi );
  end;
end;
EDIT
Delphi-Quellcode:
GetProcAddress
ist auch noch ein Kandidat zum Prüfen ... aber jetzt nicht mehr :)

Zacherl 18. Dez 2013 00:07

AW: Function (WIMGetMountedImageInfo)
 
Dein Code sieht auf jeden Fall besser aus, als mein nächtlicher Versuch :), aber der Hinweis zu GetLastError in der Delphi Hilfe ist definitiv falsch :D Habe es unter verschiedenen Windows Versionen getestet und der Error Code wird auf jeden Fall nicht resetted. Im MSDN ist unter MSDN-Library durchsuchenGetLastError ebenfalls kein Hinweis darauf zu finden.

Sir Rufo 18. Dez 2013 00:25

AW: Function (WIMGetMountedImageInfo)
 
Zitat:

Zitat von Zacherl (Beitrag 1240158)
Dein Code sieht auf jeden Fall besser aus, als mein nächtlicher Versuch :), aber der Hinweis zu GetLastError in der Delphi Hilfe ist definitiv falsch :D Habe es unter verschiedenen Windows Versionen getestet und der Error Code wird auf jeden Fall nicht resetted. Im MSDN ist unter MSDN-Library durchsuchenGetLastError ebenfalls kein Hinweis darauf zu finden.

Nun ja irgendwie schon
Zitat:

You should call the GetLastError function immediately ...
Also immer direkt nach dem API Aufruf ist gewährleistet, dass da der passende Fehlercode zu finden ist.
Danach kann schon wieder sonst was drin stehen (you never know).

Potentiell handelt man sich so diese unliebsamen SideEffects ein ;)

Zacherl 18. Dez 2013 01:40

AW: Function (WIMGetMountedImageInfo)
 
Der Vollständigkeit halber:
Zitat:

You should call the GetLastError function immediately when a function's return value indicates that such a call will return useful data. That is because some functions call SetLastError with a zero when they succeed, wiping out the error code set by the most recently failed function.
Solange man also nicht bewusst eine andere API / Funktion aufruft, sollte der Wert von GetLastError demnach unverändert bleiben. Empfinde den Text in der Delphi Hilfe deshalb nach wie vor als unzutreffend, da GetLastError selbst nichts resetted.

Sir Rufo 18. Dez 2013 02:08

AW: Function (WIMGetMountedImageInfo)
 
Problematisch ist aber eben der unbewusste Aufruf von API Funktionen (weil die mit einem harmlosen Befehl irgendwo versteckt aufgerufen werden).

Bei MS wird es erklärt und Emba schürt Angst ;)

SlpLow 18. Dez 2013 20:34

AW: Function (WIMGetMountedImageInfo)
 
Zitat:

Zitat von Zacherl (Beitrag 1240154)
Thats because of the C style boolean definition:
You can just check the flag like this:
Delphi-Quellcode:
if (Buffer^[I].MountedForRW) then

Genau. Aber richtig identifiziert das nur, wenn Sie die Konstanten ändern
MountedImageInfoLevel0 = 0;
Warum?

Sir Rufo Vielen Dank!

Zacherl 19. Dez 2013 00:03

AW: Function (WIMGetMountedImageInfo)
 
Zitat:

Zitat von SlpLow (Beitrag 1240292)
Genau. Aber richtig identifiziert das nur, wenn Sie die Konstanten ändern
MountedImageInfoLevel0 = 0;
Warum?

I dont know the correct value for that constant. I could not found it in the MSDN, but i googled it and it seems to be 1.

SlpLow 19. Dez 2013 01:00

AW: Function (WIMGetMountedImageInfo)
 
Zitat:

Zitat von Zacherl (Beitrag 1240302)
I dont know the correct value for that constant. I could not found it in the MSDN, but i googled it and it seems to be 1.

In den Header-Dateien = 1 auch.

// MOUNTED_IMAGE_INFO_LEVELS
MountedImageInfoLevel0 = 1;
MountedImageInfoLevel1 = 2;
MountedImageInfoLevelInvalid = 3;


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:47 Uhr.
Seite 2 von 2     12   

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