4 * Copyright 1999 Andreas Mohr
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
34 #include "wine/debug.h"
36 WINE_DEFAULT_DEBUG_CHANNEL(tapi
);
39 static const char szCountrylistKey
[] =
40 "Software\\Microsoft\\Windows\\CurrentVersion\\Telephony\\Country List";
41 static const char szLocationsKey
[] =
42 "Software\\Microsoft\\Windows\\CurrentVersion\\Telephony\\Locations";
43 static const char szCardsKey
[] =
44 "Software\\Microsoft\\Windows\\CurrentVersion\\Telephony\\Cards";
47 /***********************************************************************
48 * lineAccept (TAPI32.@)
50 DWORD WINAPI
lineAccept(HCALL hCall
, LPCSTR lpsUserUserInfo
, DWORD dwSize
)
52 FIXME("(%p, %s, %d): stub.\n", hCall
, lpsUserUserInfo
, dwSize
);
56 /***********************************************************************
57 * lineAddProviderA (TAPI32.@)
59 DWORD WINAPI
lineAddProviderA(LPCSTR lpszProviderName
, HWND hwndOwner
, LPDWORD lpdwPermanentProviderID
)
61 FIXME("(%s, %p, %p): stub.\n", lpszProviderName
, hwndOwner
, lpdwPermanentProviderID
);
62 return LINEERR_OPERATIONFAILED
;
65 /***********************************************************************
66 * lineAddProviderW (TAPI32.@)
68 DWORD WINAPI
lineAddProviderW(LPCWSTR lpszProviderName
, HWND hwndOwner
, LPDWORD lpdwPermanentProviderID
)
70 FIXME("(%s, %p, %p): stub.\n", wine_dbgstr_w(lpszProviderName
), hwndOwner
, lpdwPermanentProviderID
);
71 return LINEERR_OPERATIONFAILED
;
74 /***********************************************************************
75 * lineAddToConference (TAPI32.@)
77 DWORD WINAPI
lineAddToConference(HCALL hConfCall
, HCALL hConsultCall
)
79 FIXME("(%p, %p): stub.\n", hConfCall
, hConsultCall
);
83 /***********************************************************************
84 * lineAnswer (TAPI32.@)
86 DWORD WINAPI
lineAnswer(HCALL hCall
, LPCSTR lpsUserUserInfo
, DWORD dwSize
)
88 FIXME("(%p, %s, %d): stub.\n", hCall
, lpsUserUserInfo
, dwSize
);
92 /***********************************************************************
93 * lineBlindTransfer (TAPI32.@)
95 DWORD WINAPI
lineBlindTransferA(HCALL hCall
, LPCSTR lpszDestAddress
, DWORD dwCountryCode
)
97 FIXME("(%p, %s, %08x): stub.\n", hCall
, lpszDestAddress
, dwCountryCode
);
101 /***********************************************************************
102 * lineClose (TAPI32.@)
104 DWORD WINAPI
lineClose(HLINE hLine
)
106 FIXME("(%p): stub.\n", hLine
);
110 /***********************************************************************
111 * lineCompleteCall (TAPI32.@)
113 DWORD WINAPI
lineCompleteCall(HCALL hCall
, LPDWORD lpdwCompletionID
, DWORD dwCompletionMode
, DWORD dwMessageID
)
115 FIXME("(%p, %p, %08x, %08x): stub.\n", hCall
, lpdwCompletionID
, dwCompletionMode
, dwMessageID
);
119 /***********************************************************************
120 * lineCompleteTransfer (TAPI32.@)
122 DWORD WINAPI
lineCompleteTransfer(HCALL hCall
, HCALL hConsultCall
, LPHCALL lphConfCall
, DWORD dwTransferMode
)
124 FIXME("(%p, %p, %p, %08x): stub.\n", hCall
, hConsultCall
, lphConfCall
, dwTransferMode
);
128 /***********************************************************************
129 * lineConfigDialog (TAPI32.@)
131 DWORD WINAPI
lineConfigDialogA(DWORD dwDeviceID
, HWND hwndOwner
, LPCSTR lpszDeviceClass
)
133 FIXME("(%08x, %p, %s): stub.\n", dwDeviceID
, hwndOwner
, lpszDeviceClass
);
137 /***********************************************************************
138 * lineConfigDialogW (TAPI32.@)
140 DWORD WINAPI
lineConfigDialogW(DWORD dwDeviceID
, HWND hwndOwner
, LPCWSTR lpszDeviceClass
)
142 FIXME("(%08x, %p, %s): stub.\n", dwDeviceID
, hwndOwner
, debugstr_w(lpszDeviceClass
));
146 /***********************************************************************
147 * lineConfigDialogEdit (TAPI32.@)
149 DWORD WINAPI
lineConfigDialogEditA(DWORD dwDeviceID
, HWND hwndOwner
, LPCSTR lpszDeviceClass
, LPVOID
const lpDeviceConfigIn
, DWORD dwSize
, LPVARSTRING lpDeviceConfigOut
)
155 /***********************************************************************
156 * lineConfigProvider (TAPI32.@)
158 DWORD WINAPI
lineConfigProvider(HWND hwndOwner
, DWORD dwPermanentProviderID
)
160 FIXME("(%p, %08x): stub.\n", hwndOwner
, dwPermanentProviderID
);
164 /***********************************************************************
165 * lineDeallocateCall (TAPI32.@)
167 DWORD WINAPI
lineDeallocateCall(HCALL hCall
)
169 FIXME("(%p): stub.\n", hCall
);
173 /***********************************************************************
174 * lineDevSpecific (TAPI32.@)
176 DWORD WINAPI
lineDevSpecific(HLINE hLine
, DWORD dwAddressId
, HCALL hCall
, LPVOID lpParams
, DWORD dwSize
)
178 FIXME("(%p, %08x, %p, %p, %d): stub.\n", hLine
, dwAddressId
, hCall
, lpParams
, dwSize
);
182 /***********************************************************************
183 * lineDevSpecificFeature (TAPI32.@)
185 DWORD WINAPI
lineDevSpecificFeature(HLINE hLine
, DWORD dwFeature
, LPVOID lpParams
, DWORD dwSize
)
187 FIXME("(%p, %08x, %p, %d): stub.\n", hLine
, dwFeature
, lpParams
, dwSize
);
191 /***********************************************************************
192 * lineDial (TAPI32.@)
194 DWORD WINAPI
lineDialA(HCALL hCall
, LPCSTR lpszDestAddress
, DWORD dwCountryCode
)
196 FIXME("(%p, %s, %08x): stub.\n", hCall
, lpszDestAddress
, dwCountryCode
);
200 /***********************************************************************
201 * lineDialW (TAPI32.@)
203 DWORD WINAPI
lineDialW(HCALL hCall
, LPCWSTR lpszDestAddress
, DWORD dwCountryCode
)
205 FIXME("(%p, %s, %08x): stub.\n", hCall
, debugstr_w(lpszDestAddress
), dwCountryCode
);
209 /***********************************************************************
210 * lineDrop (TAPI32.@)
212 DWORD WINAPI
lineDrop(HCALL hCall
, LPCSTR lpsUserUserInfo
, DWORD dwSize
)
214 FIXME("(%p, %s, %08x): stub.\n", hCall
, lpsUserUserInfo
, dwSize
);
218 /***********************************************************************
219 * lineForward (TAPI32.@)
221 DWORD WINAPI
lineForwardA(HLINE hLine
, DWORD bAllAddress
, DWORD dwAddressID
, LPLINEFORWARDLIST lpForwardList
, DWORD dwNumRingsNoAnswer
, LPHCALL lphConsultCall
, LPLINECALLPARAMS lpCallParams
)
227 /***********************************************************************
228 * lineGatherDigits (TAPI32.@)
230 DWORD WINAPI
lineGatherDigitsA(HCALL hCall
, DWORD dwDigitModes
, LPSTR lpsDigits
, DWORD dwNumDigits
, LPCSTR lpszTerminationDigits
, DWORD dwFirstDigitTimeout
, DWORD dwInterDigitTimeout
)
236 /***********************************************************************
237 * lineGenerateDigits (TAPI32.@)
239 DWORD WINAPI
lineGenerateDigitsA(HCALL hCall
, DWORD dwDigitModes
, LPCSTR lpszDigits
, DWORD dwDuration
)
241 FIXME("(%p, %08x, %s, %d): stub.\n", hCall
, dwDigitModes
, lpszDigits
, dwDuration
);
245 /***********************************************************************
246 * lineGenerateTone (TAPI32.@)
248 DWORD WINAPI
lineGenerateTone(HCALL hCall
, DWORD dwToneMode
, DWORD dwDuration
, DWORD dwNumTones
, LPLINEGENERATETONE lpTones
)
250 FIXME("(%p, %08x, %d, %d, %p): stub.\n", hCall
, dwToneMode
, dwDuration
, dwNumTones
, lpTones
);
254 /***********************************************************************
255 * lineGetAddressCaps (TAPI32.@)
257 DWORD WINAPI
lineGetAddressCapsA(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAddressID
, DWORD dwAPIVersion
, DWORD dwExtVersion
, LPLINEADDRESSCAPS lpAddressCaps
)
259 FIXME("(%p, %08x, %08x, %08x, %08x, %p): stub.\n", hLineApp
, dwDeviceID
, dwAddressID
, dwAPIVersion
, dwExtVersion
, lpAddressCaps
);
263 /***********************************************************************
264 * lineGetAddressID (TAPI32.@)
266 DWORD WINAPI
lineGetAddressIDA(HLINE hLine
, LPDWORD lpdwAddressID
, DWORD dwAddressMode
, LPCSTR lpsAddress
, DWORD dwSize
)
268 FIXME("%p, %p, %08x, %s, %d): stub.\n", hLine
, lpdwAddressID
, dwAddressMode
, lpsAddress
, dwSize
);
272 /***********************************************************************
273 * lineGetAddressStatus (TAPI32.@)
275 DWORD WINAPI
lineGetAddressStatusA(HLINE hLine
, DWORD dwAddressID
, LPLINEADDRESSSTATUS lpAddressStatus
)
277 FIXME("(%p, %08x, %p): stub.\n", hLine
, dwAddressID
, lpAddressStatus
);
281 /***********************************************************************
282 * lineGetAppPriority (TAPI32.@)
284 DWORD WINAPI
lineGetAppPriorityA(LPCSTR lpszAppFilename
, DWORD dwMediaMode
, LPLINEEXTENSIONID
const lpExtensionID
, DWORD dwRequestMode
, LPVARSTRING lpExtensionName
, LPDWORD lpdwPriority
)
286 FIXME("(%s, %08x, %p, %08x, %p, %p): stub.\n", lpszAppFilename
, dwMediaMode
, lpExtensionID
, dwRequestMode
, lpExtensionName
, lpdwPriority
);
290 /***********************************************************************
291 * lineGetCallInfo (TAPI32.@)
293 DWORD WINAPI
lineGetCallInfoA(HCALL hCall
, LPLINECALLINFO lpCallInfo
)
295 FIXME("(%p, %p): stub.\n", hCall
, lpCallInfo
);
299 /***********************************************************************
300 * lineGetCallStatus (TAPI32.@)
302 DWORD WINAPI
lineGetCallStatus(HCALL hCall
, LPLINECALLSTATUS lpCallStatus
)
304 FIXME("(%p, %p): stub.\n", hCall
, lpCallStatus
);
308 /***********************************************************************
309 * lineGetConfRelatedCalls (TAPI32.@)
311 DWORD WINAPI
lineGetConfRelatedCalls(HCALL hCall
, LPLINECALLLIST lpCallList
)
313 FIXME("(%p, %p): stub.\n", hCall
, lpCallList
);
317 /***********************************************************************
318 * lineGetCountryA (TAPI32.@)
320 DWORD WINAPI
lineGetCountryA(DWORD dwCountryID
, DWORD dwAPIVersion
, LPLINECOUNTRYLIST lpLineCountryList
)
322 DWORD dwAvailSize
, dwOffset
, i
, num_countries
, max_subkey_len
;
323 LPLINECOUNTRYENTRY lpLCE
;
327 if(!lpLineCountryList
) {
328 TRACE("(%08x, %08x, %p): stub. Returning LINEERR_INVALPOINTER\n",
329 dwCountryID
, dwAPIVersion
, lpLineCountryList
);
330 return LINEERR_INVALPOINTER
;
333 TRACE("(%08x, %08x, %p(%d)): stub.\n",
334 dwCountryID
, dwAPIVersion
, lpLineCountryList
,
335 lpLineCountryList
->dwTotalSize
);
337 if(RegOpenKeyA(HKEY_LOCAL_MACHINE
, szCountrylistKey
, &hkey
)
339 return LINEERR_INIFILECORRUPT
;
342 dwAvailSize
= lpLineCountryList
->dwTotalSize
;
343 dwOffset
= sizeof (LINECOUNTRYLIST
);
345 if(dwAvailSize
<dwOffset
)
346 return LINEERR_STRUCTURETOOSMALL
;
348 memset(lpLineCountryList
, 0, dwAvailSize
);
350 lpLineCountryList
->dwTotalSize
= dwAvailSize
;
351 lpLineCountryList
->dwUsedSize
= dwOffset
;
352 lpLineCountryList
->dwNumCountries
= 0;
353 lpLineCountryList
->dwCountryListSize
= 0;
354 lpLineCountryList
->dwCountryListOffset
= dwOffset
;
356 lpLCE
= (LPLINECOUNTRYENTRY
)(&lpLineCountryList
[1]);
358 if(RegQueryInfoKeyA(hkey
, NULL
, NULL
, NULL
, &num_countries
, &max_subkey_len
,
359 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
) != ERROR_SUCCESS
) {
361 return LINEERR_STRUCTURETOOSMALL
;
365 dwOffset
= sizeof (LINECOUNTRYENTRY
);
367 dwOffset
+= num_countries
* sizeof (LINECOUNTRYENTRY
);
370 subkey_name
= HeapAlloc(GetProcessHeap(), 0, max_subkey_len
);
371 for(i
= 0; i
< num_countries
; i
++)
373 DWORD len
, size
, size_int
, size_long
, size_name
, size_same
;
376 if(RegEnumKeyA(hkey
, i
, subkey_name
, max_subkey_len
) !=
380 if(dwCountryID
&& (atoi(subkey_name
) != dwCountryID
))
383 if(RegOpenKeyA(hkey
, subkey_name
, &hsubkey
) != ERROR_SUCCESS
)
386 RegQueryValueExA(hsubkey
, "InternationalRule", NULL
, NULL
,
390 RegQueryValueExA(hsubkey
, "LongDistanceRule", NULL
, NULL
,
394 RegQueryValueExA(hsubkey
, "Name", NULL
, NULL
,
398 RegQueryValueExA(hsubkey
, "SameAreaRule", NULL
, NULL
,
402 if(dwAvailSize
< (dwOffset
+len
))
405 RegCloseKey(hsubkey
);
411 lpLineCountryList
->dwNumCountries
++;
412 lpLineCountryList
->dwCountryListSize
+= sizeof (LINECOUNTRYENTRY
);
413 lpLineCountryList
->dwUsedSize
+= len
+ sizeof (LINECOUNTRYENTRY
);
418 lpLCE
[i
].dwCountryID
= atoi(subkey_name
);
419 size
= sizeof(DWORD
);
420 RegQueryValueExA(hsubkey
, "CountryCode", NULL
, NULL
,
421 (BYTE
*)&lpLCE
[i
].dwCountryCode
, &size
);
423 lpLCE
[i
].dwNextCountryID
= 0;
426 lpLCE
[i
-1].dwNextCountryID
= lpLCE
[i
].dwCountryID
;
428 /* add country name */
429 lpLCE
[i
].dwCountryNameSize
= size_name
;
430 lpLCE
[i
].dwCountryNameOffset
= dwOffset
;
431 RegQueryValueExA(hsubkey
, "Name", NULL
, NULL
,
432 ((LPBYTE
)lpLineCountryList
)+dwOffset
,
434 dwOffset
+= size_name
;
436 /* add Same Area Rule */
437 lpLCE
[i
].dwSameAreaRuleSize
= size_same
;
438 lpLCE
[i
].dwSameAreaRuleOffset
= dwOffset
;
439 RegQueryValueExA(hsubkey
, "SameAreaRule", NULL
, NULL
,
440 ((LPBYTE
)lpLineCountryList
)+dwOffset
,
442 dwOffset
+= size_same
;
444 /* add Long Distance Rule */
445 lpLCE
[i
].dwLongDistanceRuleSize
= size_long
;
446 lpLCE
[i
].dwLongDistanceRuleOffset
= dwOffset
;
447 RegQueryValueExA(hsubkey
, "LongDistanceRule", NULL
, NULL
,
448 ((LPBYTE
)lpLineCountryList
)+dwOffset
,
450 dwOffset
+= size_long
;
452 /* add Long Distance Rule */
453 lpLCE
[i
].dwInternationalRuleSize
= size_int
;
454 lpLCE
[i
].dwInternationalRuleOffset
= dwOffset
;
455 RegQueryValueExA(hsubkey
, "InternationalRule", NULL
, NULL
,
456 ((LPBYTE
)lpLineCountryList
)+dwOffset
,
458 dwOffset
+= size_int
;
459 RegCloseKey(hsubkey
);
461 TRACE("Added country %s at %p\n", (LPSTR
)lpLineCountryList
+ lpLCE
[i
].dwCountryNameOffset
,
464 if(dwCountryID
) break;
467 lpLineCountryList
->dwNeededSize
= dwOffset
;
469 TRACE("%d available %d required\n", dwAvailSize
, dwOffset
);
471 HeapFree(GetProcessHeap(), 0, subkey_name
);
477 /***********************************************************************
478 * lineGetCountryW (TAPI32.@)
480 DWORD WINAPI
lineGetCountryW(DWORD id
, DWORD version
, LPLINECOUNTRYLIST list
)
482 static const WCHAR country_listW
[] =
483 {'S','o','f','t','w','a','r','e','\\','M','i','c','r','o','s','o','f','t','\\',
484 'W','i','n','d','o','w','s','\\','C','u','r','r','e','n','t','V','e','r','s','i','o','n','\\',
485 'T','e','l','e','p','h','o','n','y','\\','C','o','u','n','t','r','y',' ','L','i','s','t',0};
486 static const WCHAR international_ruleW
[] =
487 {'I','n','t','e','r','n','a','t','i','o','n','a','l','R','u','l','e',0};
488 static const WCHAR longdistance_ruleW
[] =
489 {'L','o','n','g','D','i','s','t','a','n','c','e','R','u','l','e',0};
490 static const WCHAR samearea_ruleW
[] =
491 {'S','a','m','e','A','r','e','a','R','u','l','e',0};
492 static const WCHAR nameW
[] =
494 static const WCHAR country_codeW
[] =
495 {'C','o','u','n','t','r','y','C','o','d','e',0};
496 DWORD total_size
, offset
, i
, num_countries
, max_subkey_len
;
497 LINECOUNTRYENTRY
*entry
;
501 if (!list
) return LINEERR_INVALPOINTER
;
502 TRACE("(%08x, %08x, %p(%d))\n", id
, version
, list
, list
->dwTotalSize
);
504 if (RegOpenKeyW(HKEY_LOCAL_MACHINE
, country_listW
, &hkey
) != ERROR_SUCCESS
)
505 return LINEERR_INIFILECORRUPT
;
507 total_size
= list
->dwTotalSize
;
508 offset
= sizeof(LINECOUNTRYLIST
);
509 if (total_size
< offset
) return LINEERR_STRUCTURETOOSMALL
;
511 memset(list
, 0, total_size
);
512 list
->dwTotalSize
= total_size
;
513 list
->dwUsedSize
= offset
;
514 list
->dwNumCountries
= 0;
515 list
->dwCountryListSize
= 0;
516 list
->dwCountryListOffset
= offset
;
518 entry
= (LINECOUNTRYENTRY
*)(list
+ 1);
520 if (RegQueryInfoKeyW(hkey
, NULL
, NULL
, NULL
, &num_countries
, &max_subkey_len
,
521 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
) != ERROR_SUCCESS
)
524 return LINEERR_OPERATIONFAILED
;
526 if (id
) offset
= sizeof(LINECOUNTRYENTRY
);
527 else offset
+= num_countries
* sizeof(LINECOUNTRYENTRY
);
530 if (!(subkey_name
= HeapAlloc(GetProcessHeap(), 0, max_subkey_len
* sizeof(WCHAR
))))
533 return LINEERR_NOMEM
;
535 for (i
= 0; i
< num_countries
; i
++)
537 DWORD len
, size
, size_int
, size_long
, size_name
, size_same
;
540 if (RegEnumKeyW(hkey
, i
, subkey_name
, max_subkey_len
) != ERROR_SUCCESS
) continue;
541 if (id
&& (wcstol(subkey_name
, NULL
, 10) != id
)) continue;
542 if (RegOpenKeyW(hkey
, subkey_name
, &hsubkey
) != ERROR_SUCCESS
) continue;
544 RegQueryValueExW(hsubkey
, international_ruleW
, NULL
, NULL
, NULL
, &size_int
);
547 RegQueryValueExW(hsubkey
, longdistance_ruleW
, NULL
, NULL
, NULL
, &size_long
);
550 RegQueryValueExW(hsubkey
, nameW
, NULL
, NULL
, NULL
, &size_name
);
553 RegQueryValueExW(hsubkey
, samearea_ruleW
, NULL
, NULL
, NULL
, &size_same
);
556 if (total_size
< offset
+ len
)
559 RegCloseKey(hsubkey
);
563 list
->dwNumCountries
++;
564 list
->dwCountryListSize
+= sizeof(LINECOUNTRYENTRY
);
565 list
->dwUsedSize
+= len
+ sizeof(LINECOUNTRYENTRY
);
568 entry
[i
].dwCountryID
= wcstol(subkey_name
, NULL
, 10);
569 size
= sizeof(DWORD
);
570 RegQueryValueExW(hsubkey
, country_codeW
, NULL
, NULL
, (BYTE
*)&entry
[i
].dwCountryCode
, &size
);
571 entry
[i
].dwNextCountryID
= 0;
573 if (i
> 0) entry
[i
- 1].dwNextCountryID
= entry
[i
].dwCountryID
;
575 /* add country name */
576 entry
[i
].dwCountryNameSize
= size_name
;
577 entry
[i
].dwCountryNameOffset
= offset
;
578 RegQueryValueExW(hsubkey
, nameW
, NULL
, NULL
, (BYTE
*)list
+ offset
, &size_name
);
581 /* add Same Area Rule */
582 entry
[i
].dwSameAreaRuleSize
= size_same
;
583 entry
[i
].dwSameAreaRuleOffset
= offset
;
584 RegQueryValueExW(hsubkey
, samearea_ruleW
, NULL
, NULL
, (BYTE
*)list
+ offset
, &size_same
);
587 /* add Long Distance Rule */
588 entry
[i
].dwLongDistanceRuleSize
= size_long
;
589 entry
[i
].dwLongDistanceRuleOffset
= offset
;
590 RegQueryValueExW(hsubkey
, longdistance_ruleW
, NULL
, NULL
, (BYTE
*)list
+ offset
, &size_long
);
593 /* add Long Distance Rule */
594 entry
[i
].dwInternationalRuleSize
= size_int
;
595 entry
[i
].dwInternationalRuleOffset
= offset
;
596 RegQueryValueExW(hsubkey
, international_ruleW
, NULL
, NULL
, (BYTE
*)list
+ offset
, &size_int
);
598 RegCloseKey(hsubkey
);
600 TRACE("added country %s at %p\n",
601 debugstr_w((const WCHAR
*)((const char *)list
+ entry
[i
].dwCountryNameOffset
)), &entry
[i
]);
604 list
->dwNeededSize
= offset
;
606 TRACE("%d available %d required\n", total_size
, offset
);
608 HeapFree(GetProcessHeap(), 0, subkey_name
);
613 /***********************************************************************
614 * lineGetDevCapsW (TAPI32.@)
616 DWORD WINAPI
lineGetDevCapsW(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAPIVersion
,
617 DWORD dwExtVersion
, LPLINEDEVCAPS lpLineDevCaps
)
619 static int warn_once
;
622 FIXME("(%p, %08x, %08x, %08x, %p): stub.\n", hLineApp
, dwDeviceID
, dwAPIVersion
,
623 dwExtVersion
, lpLineDevCaps
);
624 return LINEERR_OPERATIONFAILED
;
627 /***********************************************************************
628 * lineGetDevCapsA (TAPI32.@)
630 DWORD WINAPI
lineGetDevCapsA(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAPIVersion
,
631 DWORD dwExtVersion
, LPLINEDEVCAPS lpLineDevCaps
)
633 static int warn_once
;
636 FIXME("(%p, %08x, %08x, %08x, %p): stub.\n", hLineApp
, dwDeviceID
, dwAPIVersion
,
637 dwExtVersion
, lpLineDevCaps
);
638 return LINEERR_OPERATIONFAILED
;
641 /***********************************************************************
642 * lineGetDevConfig (TAPI32.@)
644 DWORD WINAPI
lineGetDevConfigA(DWORD dwDeviceID
, LPVARSTRING lpDeviceConfig
, LPCSTR lpszDeviceClass
)
646 FIXME("(%08x, %p, %s): stub.\n", dwDeviceID
, lpDeviceConfig
, lpszDeviceClass
);
650 /***********************************************************************
651 * lineGetIDW (TAPI32.@)
653 DWORD WINAPI
lineGetIDW(HLINE hLine
, DWORD dwAddressID
, HCALL hCall
, DWORD dwSelect
,
654 LPVARSTRING lpDeviceID
, LPCWSTR lpszDeviceClass
)
656 FIXME("(%p, %08x, %p, %08x, %p, %s): stub.\n", hLine
, dwAddressID
, hCall
,
657 dwSelect
, lpDeviceID
,
658 debugstr_w(lpszDeviceClass
));
659 return LINEERR_OPERATIONFAILED
;
662 /***********************************************************************
663 * lineGetIDA (TAPI32.@)
665 DWORD WINAPI
lineGetIDA(HLINE hLine
, DWORD dwAddressID
, HCALL hCall
, DWORD dwSelect
,
666 LPVARSTRING lpDeviceID
, LPCSTR lpszDeviceClass
)
668 FIXME("(%p, %08x, %p, %08x, %p, %s): stub.\n", hLine
, dwAddressID
, hCall
,
669 dwSelect
, lpDeviceID
, lpszDeviceClass
);
670 return LINEERR_OPERATIONFAILED
;
673 /***********************************************************************
674 * lineGetIcon (TAPI32.@)
676 DWORD WINAPI
lineGetIconA(DWORD dwDeviceID
, LPCSTR lpszDeviceClass
, HICON
*lphIcon
)
678 FIXME("(%08x, %s, %p): stub.\n", dwDeviceID
, lpszDeviceClass
, lphIcon
);
682 /***********************************************************************
683 * lineGetLineDevStatus (TAPI32.@)
685 DWORD WINAPI
lineGetLineDevStatusA(HLINE hLine
, LPLINEDEVSTATUS lpLineDevStatus
)
687 FIXME("(%p, %p): stub.\n", hLine
, lpLineDevStatus
);
691 /***********************************************************************
692 * lineGetMessage (TAPI32.@)
694 DWORD WINAPI
lineGetMessage(HLINEAPP hLineApp
, LPLINEMESSAGE lpMessage
, DWORD dwTimeout
)
696 FIXME("(%p, %p, %08x): stub.\n", hLineApp
, lpMessage
, dwTimeout
);
700 /***********************************************************************
701 * lineGetNewCalls (TAPI32.@)
703 DWORD WINAPI
lineGetNewCalls(HLINE hLine
, DWORD dwAddressID
, DWORD dwSelect
, LPLINECALLLIST lpCallList
)
705 FIXME("(%p, %08x, %08x, %p): stub.\n", hLine
, dwAddressID
, dwSelect
, lpCallList
);
709 /***********************************************************************
710 * lineGetNumRings (TAPI32.@)
712 DWORD WINAPI
lineGetNumRings(HLINE hLine
, DWORD dwAddressID
, LPDWORD lpdwNumRings
)
714 FIXME("(%p, %08x, %p): stub.\n", hLine
, dwAddressID
, lpdwNumRings
);
718 /***********************************************************************
719 * lineGetProviderListA (TAPI32.@)
721 DWORD WINAPI
lineGetProviderListA(DWORD dwAPIVersion
, LPLINEPROVIDERLIST lpProviderList
)
723 FIXME("(%08x, %p): stub.\n", dwAPIVersion
, lpProviderList
);
724 return LINEERR_OPERATIONFAILED
;
727 /***********************************************************************
728 * lineGetProviderListW (TAPI32.@)
730 DWORD WINAPI
lineGetProviderListW(DWORD dwAPIVersion
, LPLINEPROVIDERLIST lpProviderList
)
732 FIXME("(%08x, %p): stub.\n", dwAPIVersion
, lpProviderList
);
733 return LINEERR_OPERATIONFAILED
;
736 /***********************************************************************
737 * lineGetRequest (TAPI32.@)
739 DWORD WINAPI
lineGetRequestA(HLINEAPP hLineApp
, DWORD dwRequestMode
, LPVOID lpRequestBuffer
)
741 FIXME("%p, %08x, %p): stub.\n", hLineApp
, dwRequestMode
, lpRequestBuffer
);
745 /***********************************************************************
746 * lineGetStatusMessages (TAPI32.@)
748 DWORD WINAPI
lineGetStatusMessages(HLINE hLine
, LPDWORD lpdwLineStatus
, LPDWORD lpdwAddressStates
)
750 FIXME("(%p, %p, %p): stub.\n", hLine
, lpdwLineStatus
, lpdwAddressStates
);
754 /***********************************************************************
755 * lineGetTranslateCaps (TAPI32.@)
757 * get address translate capabilities. Returns a LINETRANSLATECAPS
760 * +-----------------------+
764 * +-----------------------+
766 * |LocationsListSize |
767 * |LocationsListOffset | -+
768 * |CurrentLocationID | |
769 * +-----------------------+ |
772 * |CardListOffset | -|--+
773 * |CurrentPreferredCardID | | |
774 * +-----------------------+ | |
776 * |LINELOCATIONENTRY #1 | |
778 * +-----------------------+ |
780 * +-----------------------+ |
782 * |LINELOCATIONENTRY | |
784 * +-----------------------+ |
786 * |LINECARDENTRY #1 |
788 * +-----------------------+
790 * +-----------------------+
792 * |LINECARDENTRY #NumCards|
794 * +-----------------------+
795 * | room for strings named|
796 * | in the structures |
798 * +-----------------------+
800 DWORD WINAPI
lineGetTranslateCapsA(HLINEAPP hLineApp
, DWORD dwAPIVersion
,
801 LPLINETRANSLATECAPS lpTranslateCaps
)
803 HKEY hkLocations
, hkCards
, hkCardLocations
, hsubkey
;
804 int numlocations
, numcards
;
807 char *loc_key_name
= NULL
;
808 char *card_key_name
= NULL
;
814 LPLINELOCATIONENTRY pLocEntry
;
815 LPLINECARDENTRY pCardEntry
;
817 TRACE("(%p, %08x, %p (tot. size %d)\n", hLineApp
, dwAPIVersion
,
818 lpTranslateCaps
, lpTranslateCaps
->dwTotalSize
);
819 if( lpTranslateCaps
->dwTotalSize
< sizeof(LINETRANSLATECAPS
))
820 return LINEERR_STRUCTURETOOSMALL
;
821 if( RegCreateKeyA(HKEY_LOCAL_MACHINE
, szLocationsKey
, &hkLocations
)
823 ERR("unexpected registry error 1.\n");
824 return LINEERR_INIFILECORRUPT
;
826 lendword
= sizeof( DWORD
);
827 if( RegQueryValueExA( hkLocations
, "CurrentID", NULL
, NULL
,
828 (LPBYTE
) ¤tid
, &lendword
) != ERROR_SUCCESS
)
829 currentid
= -1; /* change this later */
830 if(RegQueryInfoKeyA(hkLocations
, NULL
, NULL
, NULL
, NULL
, &maxlockeylen
,
831 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
) != ERROR_SUCCESS
) {
832 RegCloseKey(hkLocations
);
833 ERR("unexpected registry error 2.\n");
834 return LINEERR_INIFILECORRUPT
;
837 if( maxlockeylen
< 10)
838 maxlockeylen
= 10; /* need this also if there is no key */
839 loc_key_name
= HeapAlloc( GetProcessHeap(), 0, maxlockeylen
);
840 /* first time through: calculate needed space */
844 while( RegEnumKeyA(hkLocations
, i
, loc_key_name
, maxlockeylen
)
848 if( _strnicmp(loc_key_name
, "location", 8) ||
849 (RegOpenKeyA(hkLocations
, loc_key_name
, &hsubkey
)
853 length
+= sizeof(LINELOCATIONENTRY
);
854 RegQueryValueExA(hsubkey
, "Name",NULL
,NULL
,NULL
,&size_val
);
856 RegQueryValueExA(hsubkey
, "AreaCode",NULL
,NULL
,NULL
,&size_val
);
858 RegQueryValueExA(hsubkey
, "OutsideAccess",NULL
,NULL
,NULL
,&size_val
);
860 RegQueryValueExA(hsubkey
, "LongDistanceAccess",NULL
,NULL
,NULL
,&size_val
);
862 RegQueryValueExA(hsubkey
, "DisableCallWaiting",NULL
,NULL
,NULL
,&size_val
);
864 /* fixme: what about TollPrefixList???? */
865 RegCloseKey(hsubkey
);
867 if(numlocations
== 0) {
868 /* add one location */
869 if( RegCreateKeyA( hkLocations
, "Location1", &hsubkey
)
874 length
+= sizeof(LINELOCATIONENTRY
) + 20 ;
875 RegSetValueExA( hsubkey
, "AreaCode", 0, REG_SZ
, (const BYTE
*)"010", 4);
876 GetLocaleInfoA( LOCALE_SYSTEM_DEFAULT
, LOCALE_ICOUNTRY
, buf
, 8);
878 RegSetValueExA( hsubkey
, "Country", 0, REG_DWORD
, (LPBYTE
)&dwval
,
880 RegSetValueExA( hsubkey
, "DisableCallWaiting", 0, REG_SZ
, (const BYTE
*)"", 1);
882 RegSetValueExA( hsubkey
, "Flags", 0, REG_DWORD
, (LPBYTE
)&dwval
,
884 RegSetValueExA( hsubkey
, "LongDistanceAccess", 0, REG_SZ
, (const BYTE
*)"", 1);
885 RegSetValueExA( hsubkey
, "Name", 0, REG_SZ
, (const BYTE
*)"New Location", 13);
886 RegSetValueExA( hsubkey
, "OutsideAccess", 0, REG_SZ
, (const BYTE
*)"", 1);
887 RegCloseKey(hsubkey
);
889 RegSetValueExA( hkLocations
, "CurrentID", 0, REG_DWORD
,
890 (LPBYTE
)&dwval
, sizeof(DWORD
));
892 RegSetValueExA( hkLocations
, "NextID", 0, REG_DWORD
, (LPBYTE
)&dwval
,
896 /* do the card list */
898 if( RegCreateKeyA(HKEY_CURRENT_USER
, szCardsKey
, &hkCards
)
900 if(RegQueryInfoKeyA(hkCards
, NULL
, NULL
, NULL
, NULL
, &maxcardkeylen
,
901 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
) == ERROR_SUCCESS
) {
903 if( maxcardkeylen
< 6) maxcardkeylen
= 6;
904 card_key_name
= HeapAlloc(GetProcessHeap(), 0, maxcardkeylen
);
906 while( RegEnumKeyA(hkCards
, i
, card_key_name
, maxcardkeylen
) ==
910 if( _strnicmp(card_key_name
, "card", 4) || ERROR_SUCCESS
!=
911 (RegOpenKeyA(hkCards
, card_key_name
, &hsubkey
) ))
914 length
+= sizeof(LINECARDENTRY
);
915 RegQueryValueExA(hsubkey
, "Name",NULL
,NULL
,NULL
,&size_val
);
917 RegQueryValueExA(hsubkey
, "LocalRule",NULL
,NULL
,NULL
,&size_val
);
919 RegQueryValueExA(hsubkey
, "LDRule",NULL
,NULL
,NULL
,&size_val
);
921 RegQueryValueExA(hsubkey
, "InternationalRule",NULL
,NULL
,NULL
,
924 RegCloseKey(hsubkey
);
927 /* add one card (direct call) */
929 ERROR_SUCCESS
== RegCreateKeyA( hkCards
, "Card1", &hsubkey
)) {
932 length
+= sizeof(LINECARDENTRY
) + 22 ;
933 RegSetValueExA( hsubkey
, "Name", 0, REG_SZ
, (const BYTE
*)"None (Direct Call)", 19);
935 RegSetValueExA( hsubkey
, "Flags", 0, REG_DWORD
, (LPBYTE
)&dwval
,
937 RegSetValueExA( hsubkey
, "InternationalRule", 0, REG_SZ
, (const BYTE
*)"", 1);
938 RegSetValueExA( hsubkey
, "LDRule", 0, REG_SZ
, (const BYTE
*)"", 1);
939 RegSetValueExA( hsubkey
, "LocalRule", 0, REG_SZ
, (const BYTE
*)"", 1);
940 RegCloseKey(hsubkey
);
942 RegSetValueExA( hkCards
, "NextID", 0, REG_DWORD
, (LPBYTE
)&dwval
,
945 } else hkCards
= 0; /* should really fail */
946 /* check if sufficient room is available */
947 lpTranslateCaps
->dwNeededSize
= sizeof(LINETRANSLATECAPS
) + length
;
948 if ( lpTranslateCaps
->dwNeededSize
> lpTranslateCaps
->dwTotalSize
) {
949 RegCloseKey( hkLocations
);
950 if( hkCards
) RegCloseKey( hkCards
);
951 HeapFree(GetProcessHeap(), 0, loc_key_name
);
952 HeapFree(GetProcessHeap(), 0, card_key_name
);
953 lpTranslateCaps
->dwUsedSize
= sizeof(LINETRANSLATECAPS
);
954 TRACE("Insufficient space: total %d needed %d used %d\n",
955 lpTranslateCaps
->dwTotalSize
,
956 lpTranslateCaps
->dwNeededSize
,
957 lpTranslateCaps
->dwUsedSize
);
960 /* fill in the LINETRANSLATECAPS structure */
961 lpTranslateCaps
->dwUsedSize
= lpTranslateCaps
->dwNeededSize
;
962 lpTranslateCaps
->dwNumLocations
= numlocations
;
963 lpTranslateCaps
->dwLocationListSize
= sizeof(LINELOCATIONENTRY
) *
964 lpTranslateCaps
->dwNumLocations
;
965 lpTranslateCaps
->dwLocationListOffset
= sizeof(LINETRANSLATECAPS
);
966 lpTranslateCaps
->dwCurrentLocationID
= currentid
;
967 lpTranslateCaps
->dwNumCards
= numcards
;
968 lpTranslateCaps
->dwCardListSize
= sizeof(LINECARDENTRY
) *
969 lpTranslateCaps
->dwNumCards
;
970 lpTranslateCaps
->dwCardListOffset
= lpTranslateCaps
->dwLocationListOffset
+
971 lpTranslateCaps
->dwLocationListSize
;
972 lpTranslateCaps
->dwCurrentPreferredCardID
= 0;
973 /* this is where the strings will be stored */
974 strptr
= ((LPBYTE
) lpTranslateCaps
) +
975 lpTranslateCaps
->dwCardListOffset
+ lpTranslateCaps
->dwCardListSize
;
976 pLocEntry
= (LPLINELOCATIONENTRY
) (lpTranslateCaps
+ 1);
977 /* key with Preferred CardIDs */
978 if( RegOpenKeyA(HKEY_CURRENT_USER
, szLocationsKey
, &hkCardLocations
)
981 /* second time through all locations */
983 while(RegEnumKeyA(hkLocations
, i
, loc_key_name
, maxlockeylen
)
987 if( _strnicmp(loc_key_name
, "location", 8) ||
988 (RegOpenKeyA(hkLocations
, loc_key_name
, &hsubkey
)
991 size_val
=sizeof(DWORD
);
992 if( RegQueryValueExA(hsubkey
, "ID",NULL
, NULL
,
993 (LPBYTE
) &(pLocEntry
->dwPermanentLocationID
), &size_val
) !=
995 pLocEntry
->dwPermanentLocationID
= atoi( loc_key_name
+ 8);
997 RegQueryValueExA(hsubkey
, "Name",NULL
,NULL
, strptr
, &size_val
);
998 pLocEntry
->dwLocationNameSize
= size_val
;
999 pLocEntry
->dwLocationNameOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1003 RegQueryValueExA(hsubkey
, "AreaCode",NULL
,NULL
, strptr
, &size_val
);
1004 pLocEntry
->dwCityCodeSize
= size_val
;
1005 pLocEntry
->dwCityCodeOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1009 RegQueryValueExA(hsubkey
, "OutsideAccess",NULL
,NULL
, strptr
, &size_val
);
1010 pLocEntry
->dwLocalAccessCodeSize
= size_val
;
1011 pLocEntry
->dwLocalAccessCodeOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1014 RegQueryValueExA(hsubkey
, "LongDistanceAccess",NULL
,NULL
, strptr
,
1016 pLocEntry
->dwLongDistanceAccessCodeSize
= size_val
;
1017 pLocEntry
->dwLongDistanceAccessCodeOffset
= strptr
-
1018 (LPBYTE
) lpTranslateCaps
;
1021 RegQueryValueExA(hsubkey
, "DisableCallWaiting",NULL
,NULL
, strptr
,
1023 pLocEntry
->dwCancelCallWaitingSize
= size_val
;
1024 pLocEntry
->dwCancelCallWaitingOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1027 pLocEntry
->dwTollPrefixListSize
= 0; /* FIXME */
1028 pLocEntry
->dwTollPrefixListOffset
= 0; /* FIXME */
1030 size_val
=sizeof(DWORD
);
1031 RegQueryValueExA(hsubkey
, "Country",NULL
,NULL
,
1032 (LPBYTE
) &(pLocEntry
->dwCountryCode
), &size_val
);
1033 pLocEntry
->dwCountryID
= pLocEntry
->dwCountryCode
; /* FIXME */
1034 RegQueryValueExA(hsubkey
, "Flags",NULL
,NULL
,
1035 (LPBYTE
) &(pLocEntry
->dwOptions
), &size_val
);
1036 RegCloseKey(hsubkey
);
1037 /* get preferred cardid */
1038 pLocEntry
->dwPreferredCardID
= 0;
1039 if ( hkCardLocations
) {
1040 size_val
=sizeof(DWORD
);
1041 if(RegOpenKeyA(hkCardLocations
, loc_key_name
, &hsubkey
) ==
1043 RegQueryValueExA(hsubkey
, "CallingCard",NULL
,NULL
,
1044 (LPBYTE
) &(pLocEntry
->dwPreferredCardID
), &size_val
);
1045 RegCloseKey(hsubkey
);
1049 /* make sure there is a currentID */
1050 if(currentid
== -1){
1051 currentid
= pLocEntry
->dwPermanentLocationID
;
1052 lpTranslateCaps
->dwCurrentLocationID
= currentid
;
1054 if(pLocEntry
->dwPermanentLocationID
== currentid
)
1055 lpTranslateCaps
->dwCurrentPreferredCardID
=
1056 pLocEntry
->dwPreferredCardID
;
1057 TRACE("added: ID %d %s CountryCode %d CityCode %s CardID %d "
1058 "LocalAccess: %s LongDistanceAccess: %s CountryID %d "
1059 "Options %d CancelCallWait %s\n",
1060 pLocEntry
->dwPermanentLocationID
,
1061 debugstr_a( (char*)lpTranslateCaps
+ pLocEntry
->dwLocationNameOffset
),
1062 pLocEntry
->dwCountryCode
,
1063 debugstr_a( (char*)lpTranslateCaps
+ pLocEntry
->dwCityCodeOffset
),
1064 pLocEntry
->dwPreferredCardID
,
1065 debugstr_a( (char*)lpTranslateCaps
+ pLocEntry
->dwLocalAccessCodeOffset
),
1066 debugstr_a( (char*)lpTranslateCaps
+ pLocEntry
->dwLongDistanceAccessCodeOffset
),
1067 pLocEntry
->dwCountryID
,
1068 pLocEntry
->dwOptions
,
1069 debugstr_a( (char*)lpTranslateCaps
+ pLocEntry
->dwCancelCallWaitingOffset
));
1072 pCardEntry
= (LPLINECARDENTRY
) pLocEntry
;
1073 /* do the card list */
1076 while( RegEnumKeyA(hkCards
, i
, card_key_name
, maxcardkeylen
) ==
1080 if( _strnicmp(card_key_name
, "card", 4) ||
1081 (RegOpenKeyA(hkCards
, card_key_name
, &hsubkey
) != ERROR_SUCCESS
))
1083 size_val
=sizeof(DWORD
);
1084 if( RegQueryValueExA(hsubkey
, "ID",NULL
, NULL
,
1085 (LPBYTE
) &(pCardEntry
->dwPermanentCardID
), &size_val
) !=
1087 pCardEntry
->dwPermanentCardID
= atoi( card_key_name
+ 4);
1089 RegQueryValueExA(hsubkey
, "Name",NULL
,NULL
, strptr
, &size_val
);
1090 pCardEntry
->dwCardNameSize
= size_val
;
1091 pCardEntry
->dwCardNameOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1093 pCardEntry
->dwCardNumberDigits
= 1; /* FIXME */
1095 RegQueryValueExA(hsubkey
, "LocalRule",NULL
,NULL
, strptr
, &size_val
);
1096 pCardEntry
->dwSameAreaRuleSize
= size_val
;
1097 pCardEntry
->dwSameAreaRuleOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1100 RegQueryValueExA(hsubkey
, "LDRule",NULL
,NULL
, strptr
, &size_val
);
1101 pCardEntry
->dwLongDistanceRuleSize
= size_val
;
1102 pCardEntry
->dwLongDistanceRuleOffset
= strptr
- (LPBYTE
) lpTranslateCaps
;
1105 RegQueryValueExA(hsubkey
, "InternationalRule",NULL
,NULL
, strptr
,
1107 pCardEntry
->dwInternationalRuleSize
= size_val
;
1108 pCardEntry
->dwInternationalRuleOffset
= strptr
-
1109 (LPBYTE
) lpTranslateCaps
;
1111 size_val
=sizeof(DWORD
);
1112 RegQueryValueExA(hsubkey
, "Flags",NULL
, NULL
,
1113 (LPBYTE
) &(pCardEntry
->dwOptions
), &size_val
);
1114 TRACE( "added card: ID %d name %s SameArea %s LongDistance %s International %s Options 0x%x\n",
1115 pCardEntry
->dwPermanentCardID
,
1116 debugstr_a( (char*)lpTranslateCaps
+ pCardEntry
->dwCardNameOffset
),
1117 debugstr_a( (char*)lpTranslateCaps
+ pCardEntry
->dwSameAreaRuleOffset
),
1118 debugstr_a( (char*)lpTranslateCaps
+ pCardEntry
->dwLongDistanceRuleOffset
),
1119 debugstr_a( (char*)lpTranslateCaps
+ pCardEntry
->dwInternationalRuleOffset
),
1120 pCardEntry
->dwOptions
);
1126 if(hkLocations
) RegCloseKey(hkLocations
);
1127 if(hkCards
) RegCloseKey(hkCards
);
1128 if(hkCardLocations
) RegCloseKey(hkCardLocations
);
1129 HeapFree(GetProcessHeap(), 0, loc_key_name
);
1130 HeapFree(GetProcessHeap(), 0, card_key_name
);
1131 TRACE(" returning success tot %d needed %d used %d\n",
1132 lpTranslateCaps
->dwTotalSize
,
1133 lpTranslateCaps
->dwNeededSize
,
1134 lpTranslateCaps
->dwUsedSize
);
1135 return 0; /* success */
1138 /***********************************************************************
1139 * lineHandoff (TAPI32.@)
1141 DWORD WINAPI
lineHandoffA(HCALL hCall
, LPCSTR lpszFileName
, DWORD dwMediaMode
)
1143 FIXME("(%p, %s, %08x): stub.\n", hCall
, lpszFileName
, dwMediaMode
);
1147 /***********************************************************************
1148 * lineHold (TAPI32.@)
1150 DWORD WINAPI
lineHold(HCALL hCall
)
1152 FIXME("(%p): stub.\n", hCall
);
1156 /***********************************************************************
1157 * lineInitialize (TAPI32.@)
1159 DWORD WINAPI
lineInitialize(
1160 LPHLINEAPP lphLineApp
,
1161 HINSTANCE hInstance
,
1162 LINECALLBACK lpfnCallback
,
1164 LPDWORD lpdwNumDevs
)
1166 FIXME("(%p, %p, %p, %s, %p): stub.\n", lphLineApp
, hInstance
,
1167 lpfnCallback
, debugstr_a(lpszAppName
), lpdwNumDevs
);
1171 /***********************************************************************
1172 * lineInitializeExA (TAPI32.@)
1174 LONG WINAPI
lineInitializeExA(LPHLINEAPP lphLineApp
, HINSTANCE hInstance
, LINECALLBACK lpfnCallback
, LPCSTR lpszFriendlyAppName
, LPDWORD lpdwNumDevs
, LPDWORD lpdwAPIVersion
, LPLINEINITIALIZEEXPARAMS lpLineInitializeExParams
)
1176 FIXME("(%p, %p, %p, %s, %p, %p, %p): stub.\n", lphLineApp
, hInstance
,
1177 lpfnCallback
, debugstr_a(lpszFriendlyAppName
), lpdwNumDevs
, lpdwAPIVersion
, lpLineInitializeExParams
);
1181 /***********************************************************************
1182 * lineInitializeExW (TAPI32.@)
1184 LONG WINAPI
lineInitializeExW(LPHLINEAPP lphLineApp
, HINSTANCE hInstance
, LINECALLBACK lpfnCallback
, LPCWSTR lpszFriendlyAppName
, LPDWORD lpdwNumDevs
, LPDWORD lpdwAPIVersion
, LPLINEINITIALIZEEXPARAMS lpLineInitializeExParams
)
1186 FIXME("(%p, %p, %p, %s, %p, %p, %p): stub.\n", lphLineApp
, hInstance
,
1187 lpfnCallback
, debugstr_w(lpszFriendlyAppName
), lpdwNumDevs
, lpdwAPIVersion
, lpLineInitializeExParams
);
1191 /***********************************************************************
1192 * lineMakeCallW (TAPI32.@)
1194 DWORD WINAPI
lineMakeCallW(HLINE hLine
, LPHCALL lphCall
, LPCWSTR lpszDestAddress
,
1195 DWORD dwCountryCode
, LPLINECALLPARAMS lpCallParams
)
1197 FIXME("(%p, %p, %s, %08x, %p): stub.\n", hLine
, lphCall
, debugstr_w(lpszDestAddress
),
1198 dwCountryCode
, lpCallParams
);
1199 return LINEERR_OPERATIONFAILED
;
1202 /***********************************************************************
1203 * lineMakeCallA (TAPI32.@)
1205 DWORD WINAPI
lineMakeCallA(HLINE hLine
, LPHCALL lphCall
, LPCSTR lpszDestAddress
,
1206 DWORD dwCountryCode
, LPLINECALLPARAMS lpCallParams
)
1208 FIXME("(%p, %p, %s, %08x, %p): stub.\n", hLine
, lphCall
, lpszDestAddress
,
1209 dwCountryCode
, lpCallParams
);
1210 return LINEERR_OPERATIONFAILED
;
1213 /***********************************************************************
1214 * lineMonitorDigits (TAPI32.@)
1216 DWORD WINAPI
lineMonitorDigits(HCALL hCall
, DWORD dwDigitModes
)
1218 FIXME("(%p, %08x): stub.\n", hCall
, dwDigitModes
);
1222 /***********************************************************************
1223 * lineMonitorMedia (TAPI32.@)
1225 DWORD WINAPI
lineMonitorMedia(HCALL hCall
, DWORD dwMediaModes
)
1227 FIXME("(%p, %08x): stub.\n", hCall
, dwMediaModes
);
1231 /***********************************************************************
1232 * lineMonitorTones (TAPI32.@)
1234 DWORD WINAPI
lineMonitorTones(HCALL hCall
, LPLINEMONITORTONE lpToneList
, DWORD dwNumEntries
)
1236 FIXME("(%p, %p, %08x): stub.\n", hCall
, lpToneList
, dwNumEntries
);
1240 /***********************************************************************
1241 * lineNegotiateAPIVersion (TAPI32.@)
1243 DWORD WINAPI
lineNegotiateAPIVersion(
1246 DWORD dwAPILowVersion
,
1247 DWORD dwAPIHighVersion
,
1248 LPDWORD lpdwAPIVersion
,
1249 LPLINEEXTENSIONID lpExtensionID
1252 static int warn_once
;
1255 FIXME("(%p, %d, %d, %d, %p, %p): stub.\n", hLineApp
, dwDeviceID
,
1256 dwAPILowVersion
, dwAPIHighVersion
, lpdwAPIVersion
, lpExtensionID
);
1257 *lpdwAPIVersion
= dwAPIHighVersion
;
1261 /***********************************************************************
1262 * lineNegotiateExtVersion (TAPI32.@)
1264 DWORD WINAPI
lineNegotiateExtVersion(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAPIVersion
, DWORD dwExtLowVersion
, DWORD dwExtHighVersion
, LPDWORD lpdwExtVersion
)
1270 /***********************************************************************
1271 * lineOpenW (TAPI32.@)
1273 DWORD WINAPI
lineOpenW(HLINEAPP hLineApp
, DWORD dwDeviceID
, LPHLINE lphLine
, DWORD dwAPIVersion
, DWORD dwExtVersion
, DWORD dwCallbackInstance
, DWORD dwPrivileges
, DWORD dwMediaModes
, LPLINECALLPARAMS lpCallParams
)
1279 /***********************************************************************
1280 * lineOpen (TAPI32.@)
1282 DWORD WINAPI
lineOpenA(HLINEAPP hLineApp
, DWORD dwDeviceID
, LPHLINE lphLine
, DWORD dwAPIVersion
, DWORD dwExtVersion
, DWORD dwCallbackInstance
, DWORD dwPrivileges
, DWORD dwMediaModes
, LPLINECALLPARAMS lpCallParams
)
1288 /***********************************************************************
1289 * linePark (TAPI32.@)
1291 DWORD WINAPI
lineParkA(HCALL hCall
, DWORD dwParkMode
, LPCSTR lpszDirAddress
, LPVARSTRING lpNonDirAddress
)
1293 FIXME("(%p, %08x, %s, %p): stub.\n", hCall
, dwParkMode
, lpszDirAddress
, lpNonDirAddress
);
1297 /***********************************************************************
1298 * linePickup (TAPI32.@)
1300 DWORD WINAPI
linePickupA(HLINE hLine
, DWORD dwAddressID
, LPHCALL lphCall
, LPCSTR lpszDestAddress
, LPCSTR lpszGroupID
)
1302 FIXME("(%p, %08x, %p, %s, %s): stub.\n", hLine
, dwAddressID
, lphCall
, lpszDestAddress
, lpszGroupID
);
1306 /***********************************************************************
1307 * linePrepareAddToConference (TAPI32.@)
1309 DWORD WINAPI
linePrepareAddToConferenceA(HCALL hConfCall
, LPHCALL lphConsultCall
, LPLINECALLPARAMS lpCallParams
)
1311 FIXME("(%p, %p, %p): stub.\n", hConfCall
, lphConsultCall
, lpCallParams
);
1315 /***********************************************************************
1316 * lineRedirect (TAPI32.@)
1318 DWORD WINAPI
lineRedirectA(
1320 LPCSTR lpszDestAddress
,
1321 DWORD dwCountryCode
) {
1327 /***********************************************************************
1328 * lineRegisterRequestRecipient (TAPI32.@)
1330 DWORD WINAPI
lineRegisterRequestRecipient(HLINEAPP hLineApp
, DWORD dwRegistrationInstance
, DWORD dwRequestMode
, DWORD dwEnable
)
1332 FIXME("(%p, %08x, %08x, %08x): stub.\n", hLineApp
, dwRegistrationInstance
, dwRequestMode
, dwEnable
);
1336 /***********************************************************************
1337 * lineReleaseUserUserInfo (TAPI32.@)
1339 DWORD WINAPI
lineReleaseUserUserInfo(HCALL hCall
)
1341 FIXME("(%p): stub.\n", hCall
);
1345 /***********************************************************************
1346 * lineRemoveFromConference (TAPI32.@)
1348 DWORD WINAPI
lineRemoveFromConference(HCALL hCall
)
1350 FIXME("(%p): stub.\n", hCall
);
1354 /***********************************************************************
1355 * lineRemoveProvider (TAPI32.@)
1357 DWORD WINAPI
lineRemoveProvider(DWORD dwPermanentProviderID
, HWND hwndOwner
)
1359 FIXME("(%08x, %p): stub.\n", dwPermanentProviderID
, hwndOwner
);
1363 /***********************************************************************
1364 * lineSecureCall (TAPI32.@)
1366 DWORD WINAPI
lineSecureCall(HCALL hCall
)
1368 FIXME("(%p): stub.\n", hCall
);
1372 /***********************************************************************
1373 * lineSendUserUserInfo (TAPI32.@)
1375 DWORD WINAPI
lineSendUserUserInfo(HCALL hCall
, LPCSTR lpsUserUserInfo
, DWORD dwSize
)
1377 FIXME("(%p, %s, %08x): stub.\n", hCall
, lpsUserUserInfo
, dwSize
);
1381 /***********************************************************************
1382 * lineSetAppPriority (TAPI32.@)
1384 DWORD WINAPI
lineSetAppPriorityA(LPCSTR lpszAppFilename
, DWORD dwMediaMode
, LPLINEEXTENSIONID
const lpExtensionID
, DWORD dwRequestMode
, LPCSTR lpszExtensionName
, DWORD dwPriority
)
1386 FIXME("(%s, %08x, %p, %08x, %s, %08x): stub.\n", lpszAppFilename
, dwMediaMode
, lpExtensionID
, dwRequestMode
, lpszExtensionName
, dwPriority
);
1390 /***********************************************************************
1391 * lineSetAppSpecific (TAPI32.@)
1393 DWORD WINAPI
lineSetAppSpecific(HCALL hCall
, DWORD dwAppSpecific
)
1395 FIXME("(%p, %08x): stub.\n", hCall
, dwAppSpecific
);
1399 /***********************************************************************
1400 * lineSetCallParams (TAPI32.@)
1402 DWORD WINAPI
lineSetCallParams(HCALL hCall
, DWORD dwBearerMode
, DWORD dwMinRate
, DWORD dwMaxRate
, LPLINEDIALPARAMS lpDialParams
)
1404 FIXME("(%p, %08x, %08x, %08x, %p): stub.\n", hCall
, dwBearerMode
, dwMinRate
, dwMaxRate
, lpDialParams
);
1408 /***********************************************************************
1409 * lineSetCallPrivilege (TAPI32.@)
1411 DWORD WINAPI
lineSetCallPrivilege(HCALL hCall
, DWORD dwCallPrivilege
)
1413 FIXME("(%p, %08x): stub.\n", hCall
, dwCallPrivilege
);
1417 /***********************************************************************
1418 * lineSetCurrentLocation (TAPI32.@)
1420 DWORD WINAPI
lineSetCurrentLocation(HLINEAPP hLineApp
, DWORD dwLocation
)
1422 FIXME("(%p, %08x): stub.\n", hLineApp
, dwLocation
);
1426 /***********************************************************************
1427 * lineSetDevConfig (TAPI32.@)
1429 DWORD WINAPI
lineSetDevConfigA(DWORD dwDeviceID
, LPVOID lpDeviceConfig
, DWORD dwSize
, LPCSTR lpszDeviceClass
)
1431 FIXME("(%08x, %p, %08x, %s): stub.\n", dwDeviceID
, lpDeviceConfig
, dwSize
, lpszDeviceClass
);
1435 /***********************************************************************
1436 * lineSetMediaControl (TAPI32.@)
1438 DWORD WINAPI
lineSetMediaControl(
1443 LPLINEMEDIACONTROLDIGIT
const lpDigitList
,
1444 DWORD dwDigitNumEntries
,
1445 LPLINEMEDIACONTROLMEDIA
const lpMediaList
,
1446 DWORD dwMediaNumEntries
,
1447 LPLINEMEDIACONTROLTONE
const lpToneList
,
1448 DWORD dwToneNumEntries
,
1449 LPLINEMEDIACONTROLCALLSTATE
const lpCallStateList
,
1450 DWORD dwCallStateNumEntries
)
1456 /***********************************************************************
1457 * lineSetMediaMode (TAPI32.@)
1459 DWORD WINAPI
lineSetMediaMode(HCALL hCall
, DWORD dwMediaModes
)
1461 FIXME("(%p, %08x): stub.\n", hCall
, dwMediaModes
);
1465 /***********************************************************************
1466 * lineSetNumRings (TAPI32.@)
1468 DWORD WINAPI
lineSetNumRings(HLINE hLine
, DWORD dwAddressID
, DWORD dwNumRings
)
1470 FIXME("(%p, %08x, %08x): stub.\n", hLine
, dwAddressID
, dwNumRings
);
1474 /***********************************************************************
1475 * lineSetStatusMessages (TAPI32.@)
1477 DWORD WINAPI
lineSetStatusMessages(HLINE hLine
, DWORD dwLineStates
, DWORD dwAddressStates
)
1479 FIXME("(%p, %08x, %08x): stub.\n", hLine
, dwLineStates
, dwAddressStates
);
1483 /***********************************************************************
1484 * lineSetTerminal (TAPI32.@)
1486 DWORD WINAPI
lineSetTerminal(HLINE hLine
, DWORD dwAddressID
, HCALL hCall
, DWORD dwSelect
, DWORD dwTerminalModes
, DWORD dwTerminalID
, DWORD bEnable
)
1488 FIXME("(%p, %08x, %p, %08x, %08x, %08x, %08x): stub.\n", hLine
, dwAddressID
, hCall
, dwSelect
, dwTerminalModes
, dwTerminalID
, bEnable
);
1492 /***********************************************************************
1493 * lineSetTollList (TAPI32.@)
1495 DWORD WINAPI
lineSetTollListA(HLINEAPP hLineApp
, DWORD dwDeviceID
, LPCSTR lpszAddressIn
, DWORD dwTollListOption
)
1497 FIXME("(%p, %08x, %s, %08x): stub.\n", hLineApp
, dwDeviceID
, lpszAddressIn
, dwTollListOption
);
1501 /***********************************************************************
1502 * lineSetupConference (TAPI32.@)
1504 DWORD WINAPI
lineSetupConferenceA(HCALL hCall
, HLINE hLine
, LPHCALL lphConfCall
, LPHCALL lphConsultCall
, DWORD dwNumParties
, LPLINECALLPARAMS lpCallParams
)
1506 FIXME("(%p, %p, %p, %p, %08x, %p): stub.\n", hCall
, hLine
, lphConfCall
, lphConsultCall
, dwNumParties
, lpCallParams
);
1510 /***********************************************************************
1511 * lineSetupTransfer (TAPI32.@)
1513 DWORD WINAPI
lineSetupTransferA(HCALL hCall
, LPHCALL lphConsultCall
, LPLINECALLPARAMS lpCallParams
)
1515 FIXME("(%p, %p, %p): stub.\n", hCall
, lphConsultCall
, lpCallParams
);
1519 /***********************************************************************
1520 * lineShutdown (TAPI32.@)
1522 DWORD WINAPI
lineShutdown(HLINEAPP hLineApp
)
1524 FIXME("(%p): stub.\n", hLineApp
);
1528 /***********************************************************************
1529 * lineSwapHold (TAPI32.@)
1531 DWORD WINAPI
lineSwapHold(HCALL hActiveCall
, HCALL hHeldCall
)
1533 FIXME("(active: %p, held: %p): stub.\n", hActiveCall
, hHeldCall
);
1537 /***********************************************************************
1538 * lineTranslateAddress (TAPI32.@)
1540 DWORD WINAPI
lineTranslateAddressA(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAPIVersion
, LPCSTR lpszAddressIn
, DWORD dwCard
, DWORD dwTranslateOptions
, LPLINETRANSLATEOUTPUT lpTranslateOutput
)
1542 FIXME("(%p, %08x, %08x, %s, %08x, %08x, %p): stub.\n", hLineApp
, dwDeviceID
, dwAPIVersion
, lpszAddressIn
, dwCard
, dwTranslateOptions
, lpTranslateOutput
);
1546 /***********************************************************************
1547 * lineTranslateAddressW (TAPI32.@)
1549 DWORD WINAPI
lineTranslateAddressW(HLINEAPP hLineApp
, DWORD dwDeviceID
,
1550 DWORD dwAPIVersion
, LPCWSTR lpszAddressIn
, DWORD dwCard
,
1551 DWORD dwTranslateOptions
, LPLINETRANSLATEOUTPUT lpTranslateOutput
)
1553 FIXME("(%p, %08x, %08x, %s, %08x, %08x, %p): stub.\n", hLineApp
, dwDeviceID
, dwAPIVersion
,
1554 debugstr_w(lpszAddressIn
), dwCard
, dwTranslateOptions
, lpTranslateOutput
);
1558 /***********************************************************************
1559 * lineTranslateDialog (TAPI32.@)
1561 DWORD WINAPI
lineTranslateDialogA(HLINEAPP hLineApp
, DWORD dwDeviceID
, DWORD dwAPIVersion
, HWND hwndOwner
, LPCSTR lpszAddressIn
)
1563 FIXME("(%p, %08x, %08x, %p, %s): stub.\n", hLineApp
, dwDeviceID
, dwAPIVersion
, hwndOwner
, lpszAddressIn
);
1567 /***********************************************************************
1568 * lineTranslateDialogW (TAPI32.@)
1570 DWORD WINAPI
lineTranslateDialogW(HLINEAPP hLineApp
, DWORD dwDeviceID
,
1571 DWORD dwAPIVersion
, HWND hwndOwner
, LPCWSTR lpszAddressIn
)
1573 FIXME("(%p, %08x, %08x, %p, %s): stub.\n", hLineApp
, dwDeviceID
,
1574 dwAPIVersion
, hwndOwner
, debugstr_w(lpszAddressIn
));
1578 /***********************************************************************
1579 * lineUncompleteCall (TAPI32.@)
1581 DWORD WINAPI
lineUncompleteCall(HLINE hLine
, DWORD dwCompletionID
)
1583 FIXME("(%p, %08x): stub.\n", hLine
, dwCompletionID
);
1587 /***********************************************************************
1588 * lineUnhold (TAPI32.@)
1590 DWORD WINAPI
lineUnhold(HCALL hCall
)
1592 FIXME("(%p): stub.\n", hCall
);
1596 /***********************************************************************
1597 * lineUnpark (TAPI32.@)
1599 DWORD WINAPI
lineUnparkA(HLINE hLine
, DWORD dwAddressID
, LPHCALL lphCall
, LPCSTR lpszDestAddress
)
1601 FIXME("(%p, %08x, %p, %s): stub.\n", hLine
, dwAddressID
, lphCall
, lpszDestAddress
);