1 USING: alien alien.syntax alien.c-types alien.data alien.strings
2 math kernel sequences windows.errors windows.types io accessors
3 math.order namespaces make math.parser windows.kernel32
4 combinators locals specialized-arrays literals splitting
5 grouping classes.struct combinators.smart ;
6 SPECIALIZED-ARRAY: uchar
11 TYPEDEF: GUID* REFGUID
12 TYPEDEF: void* LPUNKNOWN
13 TYPEDEF: LPWSTR LPOLESTR
14 TYPEDEF: LPWSTR LPCOLESTR
19 TYPEDEF: REFGUID LPGUID
20 TYPEDEF: REFGUID REFIID
21 TYPEDEF: REFGUID REFCLSID
23 FUNCTION: HRESULT CoCreateInstance ( REFGUID rclsid, LPUNKNOWN pUnkOuter, DWORD dwClsContext, REFGUID riid, LPUNKNOWN out_ppv )
24 FUNCTION: HRESULT CoCreateGuid ( GUID* pguid )
25 FUNCTION: BOOL IsEqualGUID ( REFGUID rguid1, REFGUID rguid2 )
26 FUNCTION: int StringFromGUID2 ( REFGUID rguid, LPOLESTR lpsz, int cchMax )
27 FUNCTION: HRESULT CLSIDFromString ( LPOLESTR lpsz, REFGUID out_rguid )
31 CONSTANT: E_NOINTERFACE 0x80004002
32 CONSTANT: E_FAIL 0x80004005
33 CONSTANT: E_INVALIDARG 0x80070057
36 CONSTANT: DROPEFFECT_NONE 0
37 CONSTANT: DROPEFFECT_COPY 1
38 CONSTANT: DROPEFFECT_MOVE 2
39 CONSTANT: DROPEFFECT_LINK 4
40 CONSTANT: DROPEFFECT_SCROLL 0x80000000
41 CONSTANT: DD_DEFSCROLLINSET 11
42 CONSTANT: DD_DEFSCROLLDELAY 50
43 CONSTANT: DD_DEFSCROLLINTERVAL 50
44 CONSTANT: DD_DEFDRAGDELAY 200
45 CONSTANT: DD_DEFDRAGMINDIST 2
49 CONSTANT: CF_METAFILEPICT 3
53 CONSTANT: CF_OEMTEXT 7
55 CONSTANT: CF_PALETTE 9
56 CONSTANT: CF_PENDATA 10
59 CONSTANT: CF_UNICODETEXT 13
60 CONSTANT: CF_ENHMETAFILE 14
62 CONSTANT: CF_LOCALE 16
65 CONSTANT: CF_OWNERDISPLAY 0x0080
66 CONSTANT: CF_DSPTEXT 0x0081
67 CONSTANT: CF_DSPBITMAP 0x0082
68 CONSTANT: CF_DSPMETAFILEPICT 0x0083
69 CONSTANT: CF_DSPENHMETAFILE 0x008E
71 CONSTANT: DVASPECT_CONTENT 1
72 CONSTANT: DVASPECT_THUMBNAIL 2
73 CONSTANT: DVASPECT_ICON 4
74 CONSTANT: DVASPECT_DOCPRINT 8
76 CONSTANT: TYMED_HGLOBAL 1
77 CONSTANT: TYMED_FILE 2
78 CONSTANT: TYMED_ISTREAM 4
79 CONSTANT: TYMED_ISTORAGE 8
80 CONSTANT: TYMED_GDI 16
81 CONSTANT: TYMED_MFPICT 32
82 CONSTANT: TYMED_ENHMF 64
83 CONSTANT: TYMED_NULL 0
85 STRUCT: DVTARGETDEVICE
87 { tdDriverNameOffset WORD }
88 { tdDeviceNameOffset WORD }
89 { tdPortNameOffset WORD }
90 { tdExtDevmodeOffset WORD }
93 TYPEDEF: WORD CLIPFORMAT
97 { cfFormat CLIPFORMAT }
98 { ptd DVTARGETDEVICE* }
102 TYPEDEF: FORMATETC* LPFORMATETC
107 { punkForRelease LPUNKNOWN } ;
108 TYPEDEF: STGMEDIUM* LPSTGMEDIUM
110 CONSTANT: COINIT_MULTITHREADED 0
111 CONSTANT: COINIT_APARTMENTTHREADED 2
112 CONSTANT: COINIT_DISABLE_OLE1DDE 4
113 CONSTANT: COINIT_SPEED_OVER_MEMORY 8
115 FUNCTION: HRESULT OleInitialize ( void* reserved )
116 FUNCTION: HRESULT CoInitializeEx ( void* reserved, DWORD dwCoInit )
118 : succeeded? ( hresult -- ? )
119 0 0x7FFFFFFF between? ;
121 TUPLE: ole32-error code message ;
123 : <ole32-error> ( code -- error )
124 dup n>win32-error-string \ ole32-error boa ;
126 : check-ole32-error ( hresult -- )
127 dup succeeded? [ drop ] [ <ole32-error> throw ] if ;
129 : ole-initialize ( -- )
130 f OleInitialize check-ole32-error ;
133 [ 16 memory>byte-array ] same? ;
135 CONSTANT: GUID-STRING-LENGTH
136 $[ "{01234567-89ab-cdef-0123-456789abcdef}" length ]
138 : create-guid ( -- GUID )
139 GUID <struct> dup CoCreateGuid check-ole32-error ;
141 : string>guid ( string -- guid )
143 [ first3 [ hex> ] tri@ ]
144 [ 3 tail concat 2 group [ hex> ] B{ } map-as ] bi
147 : guid>string ( guid -- string )
150 [ Data1>> >hex 8 CHAR: 0 pad-head "-" ]
151 [ Data2>> >hex 4 CHAR: 0 pad-head "-" ]
152 [ Data3>> >hex 4 CHAR: 0 pad-head "-" ]
156 [ >hex 2 CHAR: 0 pad-head ]
157 [ >hex 2 CHAR: 0 pad-head "-" ]
158 [ >hex 2 CHAR: 0 pad-head ]
159 [ >hex 2 CHAR: 0 pad-head ]
160 [ >hex 2 CHAR: 0 pad-head ]
161 [ >hex 2 CHAR: 0 pad-head ]
162 [ >hex 2 CHAR: 0 pad-head ]
163 [ >hex 2 CHAR: 0 pad-head ]
168 ] "" append-outputs-as ;