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/)
-   -   Rückgabe von CommandLineToArgvW (https://www.delphipraxis.net/154595-rueckgabe-von-commandlinetoargvw.html)

Garfield 17. Sep 2010 16:24

AW: Rückgabe von CommandLineToArgvW
 
Zitat:

Zitat von samso (Beitrag 1050293)
Zweites Speicherloch:
Delphi-Quellcode:
GlobalFree(THandle(TempArgs));
denn TempArgs ist nicht mehr gültig (wegen Inc()).

Das sollte sich mit einem weiteren PPWideChar lösen lassen, welchem nach

Delphi-Quellcode:
TempArgs := CommandLineToArgvW(GetCommandLineW, NumArgs);
der Wert von TempArgs zugewiesen wird.

samso 17. Sep 2010 16:46

AW: Rückgabe von CommandLineToArgvW
 
Ja, das ist wohl war. Es gibt viele Wege zum Ziel. Es geht auch so:
Delphi-Quellcode:
procedure GetCommandLineArgs(Args: TStrings);
var
  NumArgs: Integer;
  TempArgs, p: PPWideChar;
  i: Integer;
begin
  TempArgs := CommandLineToArgvW(GetCommandLineW, NumArgs);
  try
    if TempArgs <> nil then
    begin
      p := TempArgs;
      for i := 0 to NumArgs - 1 do
      begin
        Args.Add(p^);
        Inc(p);
      end;
    end
    else
      RaiseLastOSError;
  finally
    LocalFree(THandle(TempArgs));
  end;
end;
Gegenüber der Lösung in Antwort #6 sieht das hier zwar nicht so schön aus, dafür übersteht es aber eine Bereichsprüfung.

Garfield 17. Sep 2010 17:51

AW: Rückgabe von CommandLineToArgvW
 
Man muss Prioritäten setzen. Schönheit oder Korrektheit. :wink:

Dezipaitor 17. Sep 2010 18:09

AW: Rückgabe von CommandLineToArgvW
 
Naja, das try finally ist hier garnicht notwendig und macht es imo unübersichtlich. Besser sollte es weg und das LocalFree in die if-Bed mit rein.

Luckie 17. Sep 2010 22:47

AW: Rückgabe von CommandLineToArgvW
 
Also so:
Delphi-Quellcode:
procedure GetCommandLineArgs(Args: TStrings);
type
  TPWideCharArray = array[0..0] of PWideChar;
var
  NumArgs: Integer;
  TempArgs: PPWideChar;
  i: Integer;
begin
  TempArgs := CommandLineToArgvW(GetCommandLineW, NumArgs);
  if TempArgs <> nil then
  begin
    for i := 0 to NumArgs - 1 do
      Args.Add(TPWideCharArray(TempArgs^)[i]);
    LocalFree(THandle(TempArgs));
  end
  else
    RaiseLastOSError;
end;

samso 18. Sep 2010 08:41

AW: Rückgabe von CommandLineToArgvW
 
Nunja, ich hatte auch darüber nachgedacht, ob das try finally notwendig ist. Ich hatte es drinn gelassen, weil die Add-funktion bei einer leeren Liste (args=nil oder args nicht gültig) eine Exception erzeugen würde. Falls man den Fall LocalFree(0) abfangen möchte (was ich nicht für notwendig halte), dann könnte man das ja auch noch auf anderen Wegen erreichen.

himitsu 19. Sep 2010 08:36

AW: Rückgabe von CommandLineToArgvW
 
Zitat:

Delphi-Quellcode:
for i := 0 to NumArgs - 1 do
  Args.Add(TempArgs^[i]);

Zitat:

Zitat von Luckie (Beitrag 1050233)
Danke funktioniert. Aber warum? Kannst du mir das auch noch erklären?

Delphi-Quellcode:
for i := 0 to NumArgs - 1 do
  Args.Add(TempArgs[i]);
Es müste auch funktionieren, wenn du das ^ weglassen würdest.

Über ^ dereferenzierst du den PPWideChar und der Index [i] wird dann als Zeichenindex im 1. PWideChar gezählt.
Ohne ^ wäre es aber der Index im PPWideChar, also im Array.

bzw. so müßte es auch gehn.
Delphi-Quellcode:
type TTempArgs: array[0..0] of PWideChar;
var TempArgs: ^TempArgs;

TempArgs := Ponter(CommandLineToArgvW(GetCommandLineW, NumArgs));
...
for i := 0 to NumArgs - 1 do
  Args.Add(TempArgs[i]);

Luckie 19. Sep 2010 14:13

AW: Rückgabe von CommandLineToArgvW
 
Danke für die Erklärung.


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:11 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