factor/basis/io/files/windows/nt/nt.factor

67 lines
1.9 KiB
Factor
Raw Normal View History

USING: continuations destructors io.buffers io.files io.backend
2008-12-13 06:06:28 -05:00
io.timeouts io.ports io.pathnames io.files.private
io.backend.windows io.files.windows io.encodings.utf16n windows
windows.kernel32 kernel libc math threads system environment
alien.c-types alien.arrays alien.strings sequences combinators
combinators.short-circuit ascii splitting alien strings assocs
namespaces make accessors tr windows.time windows.shell32
windows.errors specialized-arrays classes.struct ;
SPECIALIZED-ARRAY: ushort
IN: io.files.windows.nt
2007-09-20 18:09:08 -04:00
2008-04-02 21:09:56 -04:00
M: winnt cwd
2009-08-29 21:39:06 -04:00
MAX_UNICODE_PATH dup <ushort-array>
[ GetCurrentDirectory win32-error=0/f ] keep
2008-04-20 06:15:46 -04:00
utf16n alien>string ;
2008-04-02 21:09:56 -04:00
M: winnt cd
SetCurrentDirectory win32-error=0/f ;
2009-08-29 21:39:06 -04:00
CONSTANT: unicode-prefix "\\\\?\\"
2008-04-02 21:09:56 -04:00
M: winnt root-directory? ( path -- ? )
2008-03-27 17:22:24 -04:00
{
2008-09-18 18:45:15 -04:00
{ [ dup empty? ] [ drop f ] }
{ [ dup [ path-separator? ] all? ] [ drop t ] }
{ [ dup trim-tail-separators { [ length 2 = ]
2008-09-18 18:45:15 -04:00
[ second CHAR: : = ] } 1&& ] [ drop t ] }
{ [ dup unicode-prefix head? ]
[ trim-tail-separators length unicode-prefix length 2 + = ] }
2008-09-18 18:45:15 -04:00
[ drop f ]
} cond ;
: prepend-prefix ( string -- string' )
dup unicode-prefix head? [
unicode-prefix prepend
] unless ;
TR: normalize-separators "/" "\\" ;
2008-04-02 21:09:56 -04:00
M: winnt normalize-path ( string -- string' )
(normalize-path)
normalize-separators
prepend-prefix ;
2008-04-02 21:09:56 -04:00
M: winnt CreateFile-flags ( DWORD -- DWORD )
FILE_FLAG_OVERLAPPED bitor ;
2007-09-20 18:09:08 -04:00
<PRIVATE
: windows-file-size ( path -- size )
2009-08-29 21:39:06 -04:00
normalize-path 0 WIN32_FILE_ATTRIBUTE_DATA <struct>
[ GetFileAttributesEx win32-error=0/f ] keep
2009-08-29 21:39:06 -04:00
[ nFileSizeLow>> ] [ nFileSizeHigh>> ] bi >64bit ;
PRIVATE>
2008-05-06 05:26:46 -04:00
M: winnt open-append
[ dup windows-file-size ] [ drop 0 ] recover
[ (open-append) ] dip >>ptr ;
2008-10-18 22:24:14 -04:00
M: winnt home
{
[ "HOMEDRIVE" os-env "HOMEPATH" os-env append-path ]
[ "USERPROFILE" os-env ]
[ my-documents ]
} 0|| ;