Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Delphi [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag? (https://www.delphipraxis.net/181718-%5Bxe%5D-bug-tdirectory-copy-gibts-schon-einen-qc-eintrag.html)

Memnarch 4. Sep 2014 15:31


[XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Moin,
Habe einen Bug in TDirectory.Copy festgestellt. Habe nachgeguckt ob es bereits einen QC-Eintrag gibt, schien aber nicht so(vllt hab ich auch falsch gesucht, kann das jemand bestätigen?).
Könntet ihr vllt einmal nachgucken, ob der Bug in einer der Folgeversionen (xe2-xe7, jenachdem was ihr habt) gefixxt wurde?

Der Bug:
Normalerweise kopiert TDirectory.Copy die Ordnerstruktur von Source nach Destination, undzwar rekursiv.
Wenn ich folgenden pfad habe:
C:\Foo\FooB\File.txt

kann ich folgendes machen um alles zu kopieren:

Delphi-Quellcode:
TDirectory.Copy('C:\Foo', 'D:\Target')
Bei folgendem geht es aber nicht, der Ordner FooB ist dann nämlich leer:

Delphi-Quellcode:
TDirectory.Copy('C:\Foo\', 'D:\Target')
Kaputt geht es nur, weil am Ende ein Backslash angefügt wurde. In der Methode gibt es einen aufruf zu StuffString, dort möchte man den SourcePfad vom kompletten Pfad am Anfang abschneiden(also praktisch soetwas wie ExtractRelativePath)

Die Länge des SourceDir-Strings wird allerdings falsch berechnet, nämlich so:

Delphi-Quellcode:
Length(SourceDir) + Length('\')
Es wird also immer ein Backslash dazugerechnet, hat der Pfad also bereits eines, geht der erste Buchstabe des relativen Pfades verloren. TFile.Copy schlägt dann fehl(was auch nicht zurückgegeben wird). Wahrscheinlich wäre

Delphi-Quellcode:
Length(IncludeTrailingPathDelimiter(SourceDir))
besser gewesen.

Jedenfalls: Gibts diesen Bug in den folgeversionen noch oder vllt schon einen QC Eintrag, den ich nur übersehen habe?

MFG
Memnarch

Sir Rufo 4. Sep 2014 15:48

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Ich sehe das gar nicht als Bug an.
Delphi-Quellcode:
TDirectory = class
...
class procedure Copy(const SourceDirName, DestDirName: string); static;
...
end;
Da steht also etwas von
Delphi-Quellcode:
SourceDirname
und
Delphi-Quellcode:
DestDirName
und nicht etwa
Delphi-Quellcode:
SourcePath
oder
Delphi-Quellcode:
DestPath
.

Und ein Path zeichnet sich immer durch einen PathDelimiter am Ende aus und ein Directory durch einen fehlenden PathDelimiter am Ende.
Code:
Path = C:\Foo\
Directory = C:\Foo
Wenn du also jetzt statt eines Directory einen Path übergibst, dann hast du einfach einen falschen Wert übergeben, erwartest aber, dass es trotz falscher Werte richtig funktioniert. ;)

Faxe 4. Sep 2014 16:27

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Aber die Hilfe redet von Pfaden:

Use Copy to copy a directory and its contents from a given path to another path. :)

SourceDirName
The path of the source directory that will be copied.

DestDirName
The destination path to which the directory will be copied.

Sir Rufo 4. Sep 2014 16:34

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Zitat:

Zitat von Faxe (Beitrag 1271057)
Aber die Hilfe redet von Pfaden:

Use Copy to copy a directory and its contents from a given path to another path. :)

SourceDirName
The path of the source directory that will be copied.

DestDirName
The destination path to which the directory will be copied.

Ja, auch bei Emba gibt es Menschen, die den Unterschied zwischen einem Verzeichnis und einem Pfad nicht kennen.
Noch schlimmer ist es allerdings, dass es auch Entwickler bei Emba gibt, die den nicht kennen und Verzeichnis schreiben und Pfad meinen, bzw. Pfad schreiben und Verzeichnis meinen.

Uwe Raabe 4. Sep 2014 16:34

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Also bei XE2-XE7 wird unterschieden, ob das letzte Zeichen ein Path-Separator ist oder nicht.

Sir Rufo 4. Sep 2014 16:43

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1271060)
Also bei XE2-XE7 wird unterschieden, ob das letzte Zeichen ein Path-Separator ist oder nicht.

Ähm, du meinst sicher Delphi-Referenz durchsuchenTPath.DirectorySeparatorChar und nicht Delphi-Referenz durchsuchenTPath.PathSeparator

Uwe Raabe 4. Sep 2014 19:10

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Zitat:

Zitat von Sir Rufo (Beitrag 1271063)
Zitat:

Zitat von Uwe Raabe (Beitrag 1271060)
Also bei XE2-XE7 wird unterschieden, ob das letzte Zeichen ein Path-Separator ist oder nicht.

Ähm, du meinst sicher Delphi-Referenz durchsuchenTPath.DirectorySeparatorChar und nicht Delphi-Referenz durchsuchenTPath.PathSeparator

Nein, ich habe ja auch gar nicht TPath.PathSeparator erwähnt.

Die Abfrage heißt

Delphi-Quellcode:
        if not TPath.IsPathSeparator(Ch) then


was zwar in der Nomenklatur obigen Schluss zulassen würde, aber ganz anders implementiert ist.

Sir Rufo 4. Sep 2014 19:36

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1271079)
Zitat:

Zitat von Sir Rufo (Beitrag 1271063)
Zitat:

Zitat von Uwe Raabe (Beitrag 1271060)
Also bei XE2-XE7 wird unterschieden, ob das letzte Zeichen ein Path-Separator ist oder nicht.

Ähm, du meinst sicher Delphi-Referenz durchsuchenTPath.DirectorySeparatorChar und nicht Delphi-Referenz durchsuchenTPath.PathSeparator

Nein, ich habe ja auch gar nicht TPath.PathSeparator erwähnt.

Die Abfrage heißt

Delphi-Quellcode:
        if not TPath.IsPathSeparator(Ch) then


was zwar in der Nomenklatur obigen Schluss zulassen würde, aber ganz anders implementiert ist.

Oh, da stimmt die Namensgebung auch nicht so richtig überein ...

Uwe Raabe 4. Sep 2014 21:07

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Zitat:

Zitat von Sir Rufo (Beitrag 1271082)
Oh, da stimmt die Namensgebung auch nicht so richtig überein ...

Nicht nur das - die Implementation ist auch buggy: Endet der Pfad mit einem Doppelpunkt, wird fälschlicherweise nämlich kein Backslash eingefügt. Aber wer kopiert auch schon ganze Laufwerke, nicht wahr?:roll:

Memnarch 4. Sep 2014 22:07

AW: [XE] Bug in TDirectory.Copy, gibts schon einen QC eintrag?
 
Naja, alles was nicht mit einem Backslash endet scheint eher ein Dateiname zu sein(Soweit sehen es zumindest z.B. die Winapi funktionen).
Und auch ExtractRelativePath würde das letzte Element als Dateiname nehmen, wenn "\" fehlt.


Und zumindest hätte ich bei der Exception-Politik erwartet, dass es dann mit einer Exception in die binsen geht. Zumindest den Resultwert von TFile.Copy hätte man verwerten können. Es kann schließlich auch nicht sein, dass eine funktion ohne Probleme durchrennt und dann nicht funktioniert hat.


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:41 Uhr.
Seite 1 von 3  1 23      

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