Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Delphi Exception bei AssignFile mit langem Dateipfad (https://www.delphipraxis.net/194718-exception-bei-assignfile-mit-langem-dateipfad.html)

devidespe 27. Dez 2017 19:28

Exception bei AssignFile mit langem Dateipfad
 
Hallo zusammen,

mit einer Suchfunktion suche ich bestimmte Dateien einer Partition und möchte diese lesend öffnen, um die Dateigröße zu bestimmen. Das klappt soweit auch ganz gut per AssignFile:

Delphi-Quellcode:
var F : file of Byte;
begin
   …
   AssignFile(F, FileName);
   Filemode:=0; {nur Lesen !!!}
   {$I-} Reset(F); {$I+}
   if IOResult = 0 then
   begin
     Result:=FileSize(F);
     CloseFile(F);  
   end;
   …
end;
Nun ist es aber so, dass ein Pfad sehr lang ist, und zwar wievolgt:

C:\Windows.old\WINDOWS\SoftwareDistribution\Downlo ad\4890056fe7c9079e4389ab89db94aaa5\amd64_Microsof t-Windows-Client-Features-Package~~AMD64~~10.0.17063.1000\amd64_dual_buttonc onverter.inf_31bf3856ad364e35_10.0.17063.1000_none _d7273a158fb55cdb\buttonconverter.inf

Dies führt dazu, dass AssignFile mit einer Exception abstürzt und mir folgenden Fehlertext liefert:

Es ist eine ExceptClass Exception mit folgendem Inhalt aufgetreten:Ungültiger Dateiname - %s

Kann mir dazu jemand etwas sagen? Wie kann ich die Exception vorab abfangen? Liegt das daran, dass Pfad plus Dateiname länger als 256 Zeichen sind? Per TotalCommander finde ich die Datei an der besagten Stelle. Es handelt sich um Delphi XE 10.1 unter Windows 10 x64. Danke vorab.

LTE5 27. Dez 2017 20:09

AW: Exception bei AssignFile mit langem Dateipfad
 
Der Pfad ist länger als MAX_PATH (260 Zeichen)
[Laufwerk][:][\][257 Zeichen übrig für den Pfad].

Setz mal \\?\ vor den Pfad. Das sollte helfen.

Vielleicht hilft auch das https://msdn.microsoft.com/en-us/lib...(v=vs.85).aspx
MAX_PATH gibt es bei Windows 10 wohl nicht mehr.

Der schöne Günther 27. Dez 2017 22:05

AW: Exception bei AssignFile mit langem Dateipfad
 
Zitat:

Zitat von LTE5 (Beitrag 1389722)
MAX_PATH gibt es bei Windows 10 wohl nicht mehr.

Es ist alles wie vorher. Ab Win10 (1607) kann man das systemweit deaktivieren, ich glaube aber nicht dass man das sollte. Die meisten Applikationen werden wohl immer einen festen Buffer von 260 Zeichen anfordern und schwer verwirrt sein wenn Windows auf einmal mehr Zeichen zurückliefert.

LTE5 27. Dez 2017 22:19

AW: Exception bei AssignFile mit langem Dateipfad
 
Ich gehe immer den Weg über \\?\. Hatte noch nie Probleme.

Der schöne Günther 27. Dez 2017 22:53

AW: Exception bei AssignFile mit langem Dateipfad
 
Glaube ich, das ist ja auch der beste Weg 8-)

devidespe 28. Dez 2017 13:08

AW: Exception bei AssignFile mit langem Dateipfad
 
Hmm, also wenn ich die Pfadlänge prüfe und im Fall von mehr als 260 Zeichen (MAX_PATH) ein "\\?\" davorsetze, bricht AssignFile immer noch mit einer Exception ab.

Uwe Raabe 28. Dez 2017 13:23

AW: Exception bei AssignFile mit langem Dateipfad
 
Zitat:

Zitat von devidespe (Beitrag 1389763)
Hmm, also wenn ich die Pfadlänge prüfe und im Fall von mehr als 260 Zeichen (MAX_PATH) ein "\\?\" davorsetze, bricht AssignFile immer noch mit einer Exception ab.

Das geht auch nicht mit AssignFile, denn dort wird schon auf Delphi-Seite auf maximal 259 Zeichen getestet und gegebenenfalls entsprechend gekürzt (ergibt dann in Windows eben einen falschen Dateinamen oder direkt einen IO-Error). Eventuell hast du mit TFileStream hier mehr Glück, denn dort wird direkt an die Windows-API weitergeleitet.

Delphi.Narium 28. Dez 2017 13:27

AW: Exception bei AssignFile mit langem Dateipfad
 
Was liefert Dir denn ein
Delphi-Quellcode:
FileExists('C:\Windows.old\WINDOWS\SoftwareDistribution\Download\4890056fe7c9079e4389ab89db94aaa5\amd64_Microsoft-Windows-Client-Features-Package~~AMD64~~10.0.17063.1000\amd64_dual_buttonconverter.inf_31bf3856ad364e35_10.0.17063.1000_none_d7273a158fb55cdb\buttonconverter.inf');
?

Gibt es die Datei überhaupt?

Ansonsten versuchs doch mal so:
Delphi-Quellcode:
function GetFileSize(fileName : wideString) : Int64;
var
  sr : TSearchRec;
begin
  if FindFirst(fileName, faAnyFile, sr) = 0 then
     result := Int64(sr.FindData.nFileSizeHigh) shl Int64(32) + Int64(sr.FindData.nFileSizeLow)
  else
     result := -1;
  FindClose(sr);
end;
Siehe: https://www.thoughtco.com/file-size-...delphi-1057888

Uwe Raabe 28. Dez 2017 13:36

AW: Exception bei AssignFile mit langem Dateipfad
 
Wenn es nur um die Größe geht, könnte auch dieser Ansatz erfolgreich sein:
Delphi-Quellcode:
function GetFileSize(const AFileName: string): Int64;
var
  handle: THandle;
begin
  handle := FileCreate(AFileName);
  try
    Result := FileSeek(handle, Int64(0), 2);
  finally
    FileClose(handle);
  end;
end;

devidespe 28. Dez 2017 13:44

AW: Exception bei AssignFile mit langem Dateipfad
 
Danke für eure Antworten. Also FileExists liefert False zurück, ich finde die Datei aber im TotelCommander und auch im Explorer.

Beide GetFileSize-Varianten funktionieren leider nicht, und liefern beide -1 zurück. Schade.

Uwe Raabe 28. Dez 2017 13:47

AW: Exception bei AssignFile mit langem Dateipfad
 
Zitat:

Zitat von devidespe (Beitrag 1389769)
Beide GetFileSize-Varianten funktionieren leider nicht, und liefern beide -1 zurück. Schade.

Benutzt du denn auch das \\?\ Prefix? Andernfalls kann das auch nicht gehen.

LTE5 28. Dez 2017 14:05

AW: Exception bei AssignFile mit langem Dateipfad
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1389767)
Wenn es nur um die Größe geht, könnte auch dieser Ansatz erfolgreich sein:
Delphi-Quellcode:
function GetFileSize(const AFileName: string): Int64;
var
  handle: THandle;
begin
  handle := FileCreate(AFileName);
  try
    Result := FileSeek(handle, Int64(0), 2);
  finally
    FileClose(handle);
  end;
end;

OT: dieses FileSize ist etwas schneller und sollte auch mit \\?\ funktionieren.
Delphi-Quellcode:
function GetFileSize(const aFileName: string): Int64;
var
 FileInfo: TWin32FileAttributeData;
begin
 Result := -1;

 FillChar(FileInfo, SizeOf(FileInfo), 0);
 if GetFileAttributesEx(PChar(aFileName), GetFileExInfoStandard, @FileInfo) then
  begin
   Int64Rec(Result).Hi := FileInfo.nFileSizeHigh;
   Int64Rec(Result).Lo := FileInfo.nFileSizeLow;
  end;
end;

p80286 28. Dez 2017 14:50

AW: Exception bei AssignFile mit langem Dateipfad
 
Wenn man eine Datei nicht findet, ist
a) der Dateiname falsch geschrieben,(wenn der Dateiname Sonderzeichen enthält, die falsch dargestellt werden, hat man schon ein Problem)
b) die Attribute nicht beachtet worden


Gruß
K-H

Delphi.Narium 28. Dez 2017 15:33

AW: Exception bei AssignFile mit langem Dateipfad
 
c) Oder der Dateiname incl. Pfad zu lang.

Hab's gerade mal ausprobiert:

Wenn man der Datei die Dateiendung "klaut", funktioniert es, andernfalls bekommt man die Meldung: Nicht gefunden bzw. Dateigröße = -1.

Je nach Software werden wohl andere API-Funktionen genutzt, so dass das Anlegen von längeren Pfad- und Dateinamenkombinationen möglich ist. Totalcommander (und Co.) können sowas anzeigen, man kann aber nicht zwingend in den so angezeigten Verzeichnissen Dateien anlegen oder diese lesen und bearbeiten.

@devidespe

Kannst Du die vom Totalcommander angezeigte Datei mit Notepad (o. ä.) öffnen?

Luckie 28. Dez 2017 20:13

AW: Exception bei AssignFile mit langem Dateipfad
 
Ich hatte mal den aberwitzigen Fall, dass ich mich in einem Batch-Sript vertan hatte. Windows hat da mehrere Dutzend Ebenen tief Unterverzeichnisse angelegt. So viel bis der Explorer die nicht mehr löschen konnte weil, der Pfad zu lang war. Windows hat sich da quasi wunderschön selbst ins Knie geschossen. :mrgreen:

himitsu 1. Jan 2018 14:22

AW: Exception bei AssignFile mit langem Dateipfad
 
Zitat:

[Laufwerk][:][\][257 Zeichen übrig für den Pfad].
[Laufwerk][:][\][256 Zeichen übrig für den Pfad, zzgl. abschließendem #0].


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