1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
{
Copyright (C) 2007 Ricardo Pescuma Domenecci
This is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this file; see the file license.txt. If
not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
}
{$IFNDEF M_VOICESERVICE}
{$DEFINE M_VOICESERVICE}
const
MIID_VOICESERVICE:MUUID='{7D64437-EF2E-4F60-BB2D-3C518FE24D63};
{
This services are a mirror of the services/notifications in m_voice.h,
with the difference that that ones are to be used by protocols, and this ones
are to be used by plugins that can make calls to contacts in multiple protocols.
To get the devices for input/output and some options, query the db directly:
VoiceService/EchoCancelation BYTE default: TRUE
VoiceService/MicBoost BYTE default: TRUE
VoiceService/Input TString default: windows default
VoiceService/Output TString default: windows default
}
type
TVOICE_MODULE = record
cbSize :int; // sizeof(VOICE_MODULE)
description:TChar; // The description of the voice provider. This is the name that
// will be shown to the user
name :PAnsiChar; // The internal name of the voice provider. All PS_* serivces
// defined in m_voide.h need to be created based in this name.
// For example, PS_VOICE_CALL (/Voice/Call) need to be created
// as <name>/Voice/Call
icon :PAnsiChar; // Icon to identify provider (from icolib)
flags :int; // or of VOICE_CAPS_*. You don't need to send VOICE_CAPS_VOICE.
end;
{
Register a new plugin that can make/receive voice calls (a voice provider).
wParam: const VOICE_MODULE *
lParam: ignored
return: 0 on success
}
MS_VOICESERVICE_REGISTER:PAnsiChar = 'VoiceService/Register';
{
Unregister a plugin that can make/receive voice calls (a voice provider).
wParam: (const char *) Provider name
lParam: ignored
return: 0 on success
}
MS_VOICESERVICE_UNREGISTER:PAnsiChar = 'VoiceService/Unregister';
{
Request a voice call to hContact.
wParam: (HANDLE) hContact
lParam: ignored
return: the number of option calls for a contact. If > 0, it can be called
}
MS_VOICESERVICE_CAN_CALL:PAnsiChar = 'VoiceService/CanCall';
{
Request a voice call to hContact.
wParam: (HANDLE) hContact
lParam: (char *) Voice provider or NULL to use any provider avaiable
return: 0 on success
}
MS_VOICESERVICE_CALL:PAnsiChar = 'VoiceService/Call';
{$ENDIF}
|