]> gitweb.factorcode.org Git - factor.git/blob - basis/system-info/windows/windows.factor
use radix literals
[factor.git] / basis / system-info / windows / windows.factor
1 ! Copyright (C) 2008 Doug Coleman.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors alien alien.c-types alien.data alien.strings
4 arrays byte-arrays classes.struct combinators kernel math
5 namespaces specialized-arrays system
6 vocabs.loader windows windows.advapi32
7 windows.errors windows.kernel32 words system-info ;
8 SPECIALIZED-ARRAY: ushort
9 IN: system-info.windows
10
11 : system-info ( -- SYSTEM_INFO )
12     SYSTEM_INFO <struct> [ GetSystemInfo ] keep ;
13
14 : page-size ( -- n )
15     system-info dwPageSize>> ;
16
17 ! 386, 486, 586, 2200 (IA64), 8664 (AMD_X8664)
18 : processor-type ( -- n )
19     system-info dwProcessorType>> ;
20
21 ! 0 = x86, 6 = Intel Itanium, 9 = x64 (AMD or Intel), 10 = WOW64, 0xffff = Unk
22 : processor-architecture ( -- n )
23     system-info dwOemId>> 0xffff0000 bitand ;
24
25 : os-version-struct ( -- os-version )
26     OSVERSIONINFO <struct>
27         OSVERSIONINFO heap-size >>dwOSVersionInfoSize
28     dup GetVersionEx win32-error=0/f ;
29
30 : windows-major ( -- n )
31     os-version-struct dwMajorVersion>> ;
32
33 : windows-minor ( -- n )
34     os-version-struct dwMinorVersion>> ;
35
36 M: windows os-version ( -- obj )
37     os-version-struct [ dwMajorVersion>> ] [ dwMinorVersion>> ] bi 2array ;
38     
39 : windows-build# ( -- n )
40     os-version-struct dwBuildNumber>> ;
41
42 : windows-platform-id ( -- n )
43     os-version-struct dwPlatformId>> ;
44
45 : windows-service-pack ( -- string )
46     os-version-struct szCSDVersion>> alien>native-string ;
47
48 : feature-present? ( n -- ? )
49     IsProcessorFeaturePresent zero? not ;
50
51 : sse2? ( -- ? )
52     PF_XMMI64_INSTRUCTIONS_AVAILABLE feature-present? ;
53
54 : sse3? ( -- ? )
55     PF_SSE3_INSTRUCTIONS_AVAILABLE feature-present? ;
56
57 : get-directory ( word -- str )
58     [ MAX_UNICODE_PATH [ ushort <c-array> ] keep dupd ] dip
59     execute win32-error=0/f alien>native-string ; inline
60
61 : windows-directory ( -- str )
62     \ GetWindowsDirectory get-directory ;
63
64 : system-directory ( -- str )
65     \ GetSystemDirectory get-directory ;
66
67 : system-windows-directory ( -- str )
68     \ GetSystemWindowsDirectory get-directory ;
69
70 M: windows cpus ( -- n )
71     system-info dwNumberOfProcessors>> ;
72
73 : memory-status ( -- MEMORYSTATUSEX )
74     MEMORYSTATUSEX <struct>
75     MEMORYSTATUSEX heap-size >>dwLength
76     dup GlobalMemoryStatusEx win32-error=0/f ;
77
78 M: windows memory-load ( -- n )
79     memory-status dwMemoryLoad>> ;
80
81 M: windows physical-mem ( -- n )
82     memory-status ullTotalPhys>> ;
83
84 M: windows available-mem ( -- n )
85     memory-status ullAvailPhys>> ;
86
87 M: windows total-page-file ( -- n )
88     memory-status ullTotalPageFile>> ;
89
90 M: windows available-page-file ( -- n )
91     memory-status ullAvailPageFile>> ;
92
93 M: windows total-virtual-mem ( -- n )
94     memory-status ullTotalVirtual>> ;
95
96 M: windows available-virtual-mem ( -- n )
97     memory-status ullAvailVirtual>> ;
98
99 : computer-name ( -- string )
100     MAX_COMPUTERNAME_LENGTH 1 +
101     [ <byte-array> dup ] keep uint <ref>
102     GetComputerName win32-error=0/f alien>native-string ;
103  
104 : username ( -- string )
105     UNLEN 1 +
106     [ <byte-array> dup ] keep uint <ref>
107     GetUserName win32-error=0/f alien>native-string ;