1 USING: accessors alien.c-types alien.data alien.syntax
2 classes.struct combinators combinators.smart grouping kernel
3 literals math.order math.parser parser sequences
4 specialized-arrays splitting windows.errors windows.kernel32
5 windows.types words.constant ;
6 SPECIALIZED-ARRAY: uchar
11 TYPEDEF: GUID* REFGUID
12 TYPEDEF: void* LPUNKNOWN
13 TYPEDEF: LPWSTR OLESTR
14 TYPEDEF: LPWSTR LPOLESTR
15 TYPEDEF: LPWSTR LPCOLESTR
16 TYPEDEF: wchar_t* OLECHAR
22 TYPEDEF: REFGUID LPGUID
23 TYPEDEF: REFGUID LPCGUID
24 TYPEDEF: REFGUID REFIID
25 TYPEDEF: REFGUID REFCLSID
27 FUNCTION: HRESULT CoCreateInstance ( REFGUID rclsid, LPUNKNOWN pUnkOuter, DWORD dwClsContext, REFGUID riid, LPUNKNOWN out_ppv )
28 FUNCTION: HRESULT CoCreateGuid ( GUID* pguid )
29 FUNCTION: BOOL IsEqualGUID ( REFGUID rguid1, REFGUID rguid2 )
30 FUNCTION: int StringFromGUID2 ( REFGUID rguid, LPOLESTR lpsz, int cchMax )
31 FUNCTION: HRESULT CLSIDFromString ( LPOLESTR lpsz, REFGUID out_rguid )
35 CONSTANT: DRAGDROP_S_DROP 0x00040100
36 CONSTANT: DRAGDROP_S_CANCEL 0x00040101
37 CONSTANT: DRAGDROP_S_USEDEFAULTCURSORS 0x00040102
39 ERROR: hresult-error n ;
41 : check-hresult ( n -- )
42 dup S_OK = [ drop ] [ hresult-error ] if ;
45 : >long ( integer -- long )
46 long <ref> long deref ; inline
49 SYNTAX: LONG: scan-new-word scan-object >long define-constant ;
52 LONG: E_NOTIMPL 0x80004001
53 LONG: E_NOINTERFACE 0x80004002
54 LONG: E_FAIL 0x80004005
55 LONG: E_UNEXPECTED 0x8000FFFF
56 LONG: E_OUTOFMEMORY 0x8007000E
57 LONG: E_INVALIDARG 0x80070057
59 LONG: OLE_E_OLEVERB 0x80040000
60 LONG: OLE_E_ADVF 0x80040001
61 LONG: OLE_E_ENUM_NOMORE 0x80040002
62 LONG: OLE_E_ADVISENOTSUPPORTED 0x80040003
63 LONG: OLE_E_NOCONNECTION 0x80040004
64 LONG: OLE_E_NOTRUNNING 0x80040005
65 LONG: OLE_E_NOCACHE 0x80040006
66 LONG: OLE_E_BLANK 0x80040007
67 LONG: OLE_E_CLASSDIFF 0x80040008
68 LONG: OLE_E_CANT_GETMONIKER 0x80040009
69 LONG: OLE_E_CANT_BINDTOSOURCE 0x8004000A
70 LONG: OLE_E_STATIC 0x8004000B
71 LONG: OLE_E_PROMPTSAVECANCELLED 0x8004000C
72 LONG: OLE_E_INVALIDRECT 0x8004000D
73 LONG: OLE_E_WRONGCOMPOBJ 0x8004000E
74 LONG: OLE_E_INVALIDHWND 0x8004000F
75 LONG: OLE_E_NOT_INPLACEACTIVE 0x80040010
76 LONG: OLE_E_CANTCONVERT 0x80040011
77 LONG: OLE_E_NOSTORAGE 0x80040012
79 LONG: CO_E_NOTINITIALIZED 0x800401F0
80 LONG: CO_E_ALREADYINITIALIZED 0x800401F1
81 LONG: CO_E_CANTDETERMINECLASS 0x800401F2
82 LONG: CO_E_CLASSSTRING 0x800401F3
83 LONG: CO_E_IIDSTRING 0x800401F4
84 LONG: CO_E_APPNOTFOUND 0x800401F5
85 LONG: CO_E_APPSINGLEUSE 0x800401F6
86 LONG: CO_E_ERRORINAPP 0x800401F7
87 LONG: CO_E_DLLNOTFOUND 0x800401F8
88 LONG: CO_E_ERRORINDLL 0x800401F9
89 LONG: CO_E_WRONGOSFORAPP 0x800401FA
90 LONG: CO_E_OBJNOTREG 0x800401FB
91 LONG: CO_E_OBJISREG 0x800401FC
92 LONG: CO_E_OBJNOTCONNECTED 0x800401FD
93 LONG: CO_E_APPDIDNTREG 0x800401FE
94 LONG: CO_E_RELEASED 0x800401FF
97 CONSTANT: DROPEFFECT_NONE 0
98 CONSTANT: DROPEFFECT_COPY 1
99 CONSTANT: DROPEFFECT_MOVE 2
100 CONSTANT: DROPEFFECT_LINK 4
101 CONSTANT: DROPEFFECT_SCROLL 0x80000000
102 CONSTANT: DD_DEFSCROLLINSET 11
103 CONSTANT: DD_DEFSCROLLDELAY 50
104 CONSTANT: DD_DEFSCROLLINTERVAL 50
105 CONSTANT: DD_DEFDRAGDELAY 200
106 CONSTANT: DD_DEFDRAGMINDIST 2
108 CONSTANT: DVASPECT_CONTENT 1
109 CONSTANT: DVASPECT_THUMBNAIL 2
110 CONSTANT: DVASPECT_ICON 4
111 CONSTANT: DVASPECT_DOCPRINT 8
113 CONSTANT: TYMED_HGLOBAL 1
114 CONSTANT: TYMED_FILE 2
115 CONSTANT: TYMED_ISTREAM 4
116 CONSTANT: TYMED_ISTORAGE 8
117 CONSTANT: TYMED_GDI 16
118 CONSTANT: TYMED_MFPICT 32
119 CONSTANT: TYMED_ENHMF 64
120 CONSTANT: TYMED_NULL 0
122 STRUCT: DVTARGETDEVICE
124 { tdDriverNameOffset WORD }
125 { tdDeviceNameOffset WORD }
126 { tdPortNameOffset WORD }
127 { tdExtDevmodeOffset WORD }
130 TYPEDEF: WORD CLIPFORMAT
131 TYPEDEF: POINT POINTL
134 { cfFormat CLIPFORMAT }
135 { ptd DVTARGETDEVICE* }
139 TYPEDEF: FORMATETC* LPFORMATETC
144 { punkForRelease LPUNKNOWN } ;
145 TYPEDEF: STGMEDIUM* LPSTGMEDIUM
147 CONSTANT: COINIT_MULTITHREADED 0
148 CONSTANT: COINIT_APARTMENTTHREADED 2
149 CONSTANT: COINIT_DISABLE_OLE1DDE 4
150 CONSTANT: COINIT_SPEED_OVER_MEMORY 8
152 FUNCTION: HRESULT OleInitialize ( void* reserved )
153 FUNCTION: HRESULT CoInitializeEx ( void* reserved, DWORD dwCoInit )
155 : succeeded? ( hresult -- ? )
156 0 0x7FFFFFFF between? ;
158 TUPLE: ole32-error code message ;
160 : <ole32-error> ( code -- error )
161 dup n>win32-error-string \ ole32-error boa ;
163 : check-ole32-error ( hresult -- )
164 dup succeeded? [ drop ] [ <ole32-error> throw ] if ;
166 : ole-initialize ( -- )
167 f OleInitialize check-ole32-error ;
170 [ 16 memory>byte-array ] same? ;
172 CONSTANT: GUID-STRING-LENGTH
173 $[ "{01234567-89ab-cdef-0123-456789abcdef}" length ]
175 : create-guid ( -- GUID )
176 GUID <struct> dup CoCreateGuid check-ole32-error ;
178 : string>guid ( string -- guid )
180 [ first3 [ hex> ] tri@ ]
181 [ 3 tail concat 2 group [ hex> ] B{ } map-as ] bi
184 : guid>string ( guid -- string )
187 [ Data1>> >hex 8 CHAR: 0 pad-head "-" ]
188 [ Data2>> >hex 4 CHAR: 0 pad-head "-" ]
189 [ Data3>> >hex 4 CHAR: 0 pad-head "-" ]
193 [ >hex 2 CHAR: 0 pad-head ]
194 [ >hex 2 CHAR: 0 pad-head "-" ]
195 [ >hex 2 CHAR: 0 pad-head ]
196 [ >hex 2 CHAR: 0 pad-head ]
197 [ >hex 2 CHAR: 0 pad-head ]
198 [ >hex 2 CHAR: 0 pad-head ]
199 [ >hex 2 CHAR: 0 pad-head ]
200 [ >hex 2 CHAR: 0 pad-head ]
205 ] "" append-outputs-as ;