#! perl -slw
use strict;
use Win32::API::Prototype;
ApiLink( 'Kernel32',
q[ HANDLE FindFirstFile( LPCTSTR lpFileName, LPWIN32_FIND_DATA lpF
+FData )]
) or die $^E;
ApiLink( 'Kernel32',
q[ BOOL FindNextFile( HANDLE hFindFile, LPWIN32_FIND_DATA lpFFData
+ ) )]
) or die $^E;
ApiLink( 'Kernel32',
q[ HANDLE FindClose( HANDLE hFindDile )]
) or die $^E;
=pod
typedef struct _WIN32_FIND_DATA {
DWORD dwFileAttributes; # 4
FILETIME ftCreationTime; # 8
FILETIME ftLastAccessTime; # 8
FILETIME ftLastWriteTime; # 8
DWORD nFileSizeHigh; # 4
DWORD nFileSizeLow; # 4
DWORD dwReserved0; # 4
DWORD dwReserved1; # 4
TCHAR cFileName[MAX_PATH]; # 260
TCHAR cAlternateFileName[14]; # 14
} WIN32_FIND_DATA, # 328
*PWIN32_FIND_DATA;
=cut
my $FFData = chr(0) x 328;
my $hFF = FindFirstFile( '.\*', $FFData ) or die $^E;
do {
print unpack 'x44Z260', $FFData;
} while FindNextFile( $hFF, $FFData );
FindClose( $hFF );
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
Lingua non convalesco, consenesco et abolesco. -- Rule 1 has a caveat! -- Who broke the cabal?
"Science is about questioning the status quo. Questioning authority".
The "good enough" maybe good enough for the now, and perfection maybe unobtainable, but that should not preclude us from striving for perfection, when time, circumstance or desire allow.
| [reply] [d/l] |
That looks quite promising, thanks! I'll play around with that.
| [reply] |
#! perl -slw
use strict;
use Win32::API::Prototype;
ApiLink( 'Kernel32', q[ HANDLE FindFirstFileW( LPCTSTR lpFileName, LPW
+IN32_FIND_DATA lpFindFileData )] ) or die $^E;
ApiLink( 'Kernel32', q[ BOOL FindNextFileW( HANDLE hFindFile, LPWIN32_
+FIND_DATA lpFindFileData ) )] ) or die $^E;
ApiLink( 'Kernel32', q[ HANDLE FindClose( HANDLE hFindDile )] ) or die
+ $^E;
=pod
typedef struct _WIN32_FIND_DATA {
DWORD dwFileAttributes; # 4
FILETIME ftCreationTime; # 8
FILETIME ftLastAccessTime; # 8
FILETIME ftLastWriteTime; # 8
DWORD nFileSizeHigh; # 4
DWORD nFileSizeLow; # 4
DWORD dwReserved0; # 4
DWORD dwReserved1; # 4
TCHAR cFileName[MAX_PATH]; # 260
TCHAR cAlternateFileName[14]; # 14
} WIN32_FIND_DATA, # 328
*PWIN32_FIND_DATA;
=cut
my $FFData = chr(0) x 1024; ## Allow some extra room for long unicode
+paths?
## See the MSDN docs for where the \\?\... syntax comes from
## It is recognising this syntax as without it I get
## The filename, directory name, or volume label syntax is incorrect
## And with it I get
## The system cannot find the file specified
## Which suggests that it can't file any file in the path I'm specifyi
+ng
## but there are files there to be found.
my $hFF = FindFirstFileW( '\\?\p:\test\*', $FFData ) > 0 or die $^E;
## Note: the > 0 test above Failure results in a -1 returncode.
print $hFF;
do {
print unpack 'x44U*', $FFData;
} while FindNextFileW( $hFF, $FFData );
__END__
P:\test>ffw
The system cannot find the file specified at P:\test\FFW.pl line 27.
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
Lingua non convalesco, consenesco et abolesco. -- Rule 1 has a caveat! -- Who broke the cabal?
"Science is about questioning the status quo. Questioning authority".
The "good enough" maybe good enough for the now, and perfection maybe unobtainable, but that should not preclude us from striving for perfection, when time, circumstance or desire allow.
| [reply] [d/l] |
Well, you could create a interface to FindFirstFileW or FindFirstFileExW, FindNextFileW and FindClose using Win32::API.
Update: It seems that BrowserUK has already implemented that to which I was refering, except he implemented the non-unicode version of the calls.
| [reply] |
So I see. I'm playing with it now. Thanks for the input!
| [reply] |