Small fixes.
[wine/multimedia.git] / win32 / newfns.c
blobced6b0630871b457b4b172c1927b685bef98c27c
1 /*
2 * Win32 miscellaneous functions
4 * Copyright 1995 Thomas Sandford (tdgsandf@prds-grn.demon.co.uk)
5 */
7 /* Misc. new functions - they should be moved into appropriate files
8 at a later date. */
10 #include <string.h>
11 #include <sys/time.h>
12 #include <unistd.h>
13 #include "windows.h"
14 #include "winnt.h"
15 #include "winerror.h"
16 #include "heap.h"
17 #include "debug.h"
18 #include "debugstr.h"
20 /****************************************************************************
21 * UTRegister (KERNEL32.697)
23 BOOL32 WINAPI UTRegister(HMODULE32 hModule,
24 LPSTR lpsz16BITDLL,
25 LPSTR lpszInitName,
26 LPSTR lpszProcName,
27 /*UT32PROC*/ LPVOID *ppfn32Thunk,
28 /*FARPROC*/ LPVOID pfnUT32CallBack,
29 LPVOID lpBuff)
31 FIXME(updown, "(%#x,...): stub\n",hModule);
32 return TRUE;
35 /****************************************************************************
36 * UTUnRegister (KERNEL32.698)
38 BOOL32 WINAPI UTUnRegister(HMODULE32 hModule)
40 FIXME(updown, "(%#x...): stub\n", hModule);
41 return TRUE;
45 /****************************************************************************
46 * QueryPerformanceCounter (KERNEL32.564)
48 BOOL32 WINAPI QueryPerformanceCounter(LPLARGE_INTEGER counter)
50 struct timeval tv;
52 gettimeofday(&tv,NULL);
53 counter->LowPart = tv.tv_usec+tv.tv_sec*1000000;
54 counter->HighPart = 0;
55 return TRUE;
58 /****************************************************************************
59 * QueryPerformanceFrequency (KERNEL32.565)
61 BOOL32 WINAPI QueryPerformanceFrequency(LPLARGE_INTEGER frequency)
63 frequency->LowPart = 1000000;
64 frequency->HighPart = 0;
65 return TRUE;
68 /****************************************************************************
69 * FlushInstructionCache (KERNEL32.261)
71 BOOL32 WINAPI FlushInstructionCache(DWORD x,DWORD y,DWORD z) {
72 FIXME(debug,"(0x%08lx,0x%08lx,0x%08lx): stub\n",x,y,z);
73 return TRUE;
76 /***********************************************************************
77 * CreateNamedPipeA (KERNEL32.168)
79 HANDLE32 WINAPI CreateNamedPipeA (LPCSTR lpName, DWORD dwOpenMode,
80 DWORD dwPipeMode, DWORD nMaxInstances,
81 DWORD nOutBufferSize, DWORD nInBufferSize,
82 DWORD nDefaultTimeOut,
83 LPSECURITY_ATTRIBUTES lpSecurityAttributes)
85 FIXME (win32, "(Name=%s, OpenMode=%#08lx, dwPipeMode=%#08lx, MaxInst=%ld, OutBSize=%ld, InBuffSize=%ld, DefTimeOut=%ld, SecAttr=%p): stub\n",
86 debugstr_a(lpName), dwOpenMode, dwPipeMode, nMaxInstances,
87 nOutBufferSize, nInBufferSize, nDefaultTimeOut,
88 lpSecurityAttributes);
89 /* if (nMaxInstances > PIPE_UNLIMITED_INSTANCES) {
90 SetLastError (ERROR_INVALID_PARAMETER);
91 return INVALID_HANDLE_VALUE;
92 } */
94 SetLastError (ERROR_UNKNOWN);
95 return INVALID_HANDLE_VALUE32;
98 /***********************************************************************
99 * CreateNamedPipeW (KERNEL32.169)
101 HANDLE32 WINAPI CreateNamedPipeW (LPCWSTR lpName, DWORD dwOpenMode,
102 DWORD dwPipeMode, DWORD nMaxInstances,
103 DWORD nOutBufferSize, DWORD nInBufferSize,
104 DWORD nDefaultTimeOut,
105 LPSECURITY_ATTRIBUTES lpSecurityAttributes)
107 FIXME (win32, "(Name=%s, OpenMode=%#08lx, dwPipeMode=%#08lx, MaxInst=%ld, OutBSize=%ld, InBuffSize=%ld, DefTimeOut=%ld, SecAttr=%p): stub\n",
108 debugstr_w(lpName), dwOpenMode, dwPipeMode, nMaxInstances,
109 nOutBufferSize, nInBufferSize, nDefaultTimeOut,
110 lpSecurityAttributes);
112 SetLastError (ERROR_UNKNOWN);
113 return INVALID_HANDLE_VALUE32;
116 /***********************************************************************
117 * CreatePipe (KERNEL32.170)
120 BOOL32 WINAPI CreatePipe(PHANDLE hReadPipe,
121 PHANDLE hWritePipe,
122 LPSECURITY_ATTRIBUTES lpPipeAttributes,
123 DWORD nSize)
125 FIXME (win32,"ReadPipe=%p WritePipe=%p SecAttr=%p Size=%ld",
126 hReadPipe,hWritePipe,lpPipeAttributes,nSize);
127 SetLastError(ERROR_UNKNOWN);
128 return FALSE;
131 /***********************************************************************
132 * GetSystemPowerStatus (KERNEL32.621)
134 BOOL32 WINAPI GetSystemPowerStatus(LPSYSTEM_POWER_STATUS sps_ptr)
136 return FALSE; /* no power management support */
140 /***********************************************************************
141 * SetSystemPowerState (KERNEL32.630)
143 BOOL32 WINAPI SetSystemPowerState(BOOL32 suspend_or_hibernate,
144 BOOL32 force_flag)
146 /* suspend_or_hibernate flag: w95 does not support
147 this feature anyway */
149 for ( ;0; )
151 if ( force_flag )
154 else
158 return TRUE;
162 /******************************************************************************
163 * CreateMailslot32A [KERNEL32.164]
165 HANDLE32 WINAPI CreateMailslot32A( LPCSTR lpName, DWORD nMaxMessageSize,
166 DWORD lReadTimeout, LPSECURITY_ATTRIBUTES sa)
168 FIXME(win32, "(%s,%ld,%ld,%p): stub\n", debugstr_a(lpName),
169 nMaxMessageSize, lReadTimeout, sa);
170 return 1;
174 /******************************************************************************
175 * CreateMailslot32W [KERNEL32.165] Creates a mailslot with specified name
177 * PARAMS
178 * lpName [I] Pointer to string for mailslot name
179 * nMaxMessageSize [I] Maximum message size
180 * lReadTimeout [I] Milliseconds before read time-out
181 * sa [I] Pointer to security structure
183 * RETURNS
184 * Success: Handle to mailslot
185 * Failure: INVALID_HANDLE_VALUE
187 HANDLE32 WINAPI CreateMailslot32W( LPCWSTR lpName, DWORD nMaxMessageSize,
188 DWORD lReadTimeout, LPSECURITY_ATTRIBUTES sa )
190 FIXME(win32, "(%s,%ld,%ld,%p): stub\n", debugstr_w(lpName),
191 nMaxMessageSize, lReadTimeout, sa);
192 return 1;
196 /******************************************************************************
197 * GetMailslotInfo [KERNEL32.347] Retrieves info about specified mailslot
199 * PARAMS
200 * hMailslot [I] Mailslot handle
201 * lpMaxMessageSize [O] Address of maximum message size
202 * lpNextSize [O] Address of size of next message
203 * lpMessageCount [O] Address of number of messages
204 * lpReadTimeout [O] Address of read time-out
206 * RETURNS
207 * Success: TRUE
208 * Failure: FALSE
210 BOOL32 WINAPI GetMailslotInfo( HANDLE32 hMailslot, LPDWORD lpMaxMessageSize,
211 LPDWORD lpNextSize, LPDWORD lpMessageCount,
212 LPDWORD lpReadTimeout )
214 FIXME(win32, "(%d): stub\n",hMailslot);
215 *lpMaxMessageSize = (DWORD)NULL;
216 *lpNextSize = (DWORD)NULL;
217 *lpMessageCount = (DWORD)NULL;
218 *lpReadTimeout = (DWORD)NULL;
219 return TRUE;
223 /******************************************************************************
224 * GetCompressedFileSize32A [KERNEL32.291]
226 * NOTES
227 * This should call the W function below
229 DWORD WINAPI GetCompressedFileSize32A(
230 LPCSTR lpFileName,
231 LPDWORD lpFileSizeHigh)
233 FIXME(win32, "(...): stub\n");
234 return 0xffffffff;
238 /******************************************************************************
239 * GetCompressedFileSize32W [KERNEL32.292]
241 * RETURNS
242 * Success: Low-order doubleword of number of bytes
243 * Failure: 0xffffffff
245 DWORD WINAPI GetCompressedFileSize32W(
246 LPCWSTR lpFileName, /* [in] Pointer to name of file */
247 LPDWORD lpFileSizeHigh) /* [out] Receives high-order doubleword of size */
249 FIXME(win32, "(%s,%p): stub\n",debugstr_w(lpFileName),lpFileSizeHigh);
250 return 0xffffffff;
254 /******************************************************************************
255 * GetProcessWindowStation [USER32.280] Returns handle of window station
257 * NOTES
258 * Docs say the return value is HWINSTA
260 * RETURNS
261 * Success: Handle to window station associated with calling process
262 * Failure: NULL
264 DWORD WINAPI GetProcessWindowStation(void)
266 FIXME(win32, "(void): stub\n");
267 return 1;
271 /******************************************************************************
272 * GetThreadDesktop [USER32.295] Returns handle to desktop
274 * NOTES
275 * Docs say the return value is HDESK
277 * PARAMS
278 * dwThreadId [I] Thread identifier
280 * RETURNS
281 * Success: Handle to desktop associated with specified thread
282 * Failure: NULL
284 DWORD WINAPI GetThreadDesktop( DWORD dwThreadId )
286 FIXME(win32, "(%lx): stub\n",dwThreadId);
287 return 1;
291 /******************************************************************************
292 * SetDebugErrorLevel [USER32.475]
293 * Sets the minimum error level for generating debugging events
295 * PARAMS
296 * dwLevel [I] Debugging error level
298 VOID WINAPI SetDebugErrorLevel( DWORD dwLevel )
300 FIXME(win32, "(%ld): stub\n", dwLevel);
304 /******************************************************************************
305 * WaitForDebugEvent [KERNEL32.720]
306 * Waits for a debugging event to occur in a process being debugged
308 * PARAMS
309 * lpDebugEvent [I] Address of structure for event information
310 * dwMilliseconds [I] Number of milliseconds to wait for event
312 * RETURNS STD
314 BOOL32 WINAPI WaitForDebugEvent( LPDEBUG_EVENT lpDebugEvent,
315 DWORD dwMilliseconds )
317 FIXME(win32, "(%p,%ld): stub\n", lpDebugEvent, dwMilliseconds);
318 return TRUE;
322 /******************************************************************************
323 * SetComputerName32A [KERNEL32.621]
325 BOOL32 WINAPI SetComputerName32A( LPCSTR lpComputerName )
327 LPWSTR lpComputerNameW = HEAP_strdupAtoW(GetProcessHeap(),0,lpComputerName);
328 BOOL32 ret = SetComputerName32W(lpComputerNameW);
329 HeapFree(GetProcessHeap(),0,lpComputerNameW);
330 return ret;
334 /******************************************************************************
335 * SetComputerName32W [KERNEL32.622]
337 * PARAMS
338 * lpComputerName [I] Address of new computer name
340 * RETURNS STD
342 BOOL32 WINAPI SetComputerName32W( LPCWSTR lpComputerName )
344 FIXME(win32, "(%s): stub\n", debugstr_w(lpComputerName));
345 return TRUE;
349 BOOL32 WINAPI EnumPorts32A(LPSTR name,DWORD level,LPBYTE ports,DWORD bufsize,LPDWORD bufneeded,LPDWORD bufreturned) {
350 FIXME(win32,"(%s,%ld,%p,%ld,%p,%p), stub!\n",name,level,ports,bufsize,bufneeded,bufreturned);
351 return FALSE;
354 /******************************************************************************
355 * IsDebuggerPresent [KERNEL32.827]
358 BOOL32 WINAPI IsDebuggerPresent() {
359 FIXME(win32," ... no debuggers yet, returning FALSE.\n");
360 return FALSE;
363 /******************************************************************************
364 * OpenDesktop32A [USER32.408]
366 * NOTES
367 * Return type should be HDESK
369 HANDLE32 WINAPI OpenDesktop32A( LPCSTR lpszDesktop, DWORD dwFlags,
370 BOOL32 fInherit, DWORD dwDesiredAccess )
372 FIXME(win32,"(%s,%lx,%i,%lx): stub\n",debugstr_a(lpszDesktop),dwFlags,
373 fInherit,dwDesiredAccess);
374 return 1;
378 BOOL32 WINAPI SetUserObjectInformation32A( HANDLE32 hObj, int nIndex,
379 LPVOID pvInfo, DWORD nLength )
381 FIXME(win32,"(%x,%d,%p,%lx): stub\n",hObj,nIndex,pvInfo,nLength);
382 return TRUE;
386 BOOL32 WINAPI SetThreadDesktop( HANDLE32 hDesktop )
388 FIXME(win32,"(%x): stub\n",hDesktop);
389 return TRUE;