winex11: The XIM callback is called with the X11 lock held.
[wine.git] / dlls / ntdsapi / ntdsapi.c
blob01acda05e5600e34aed5fc75693c007195f6cc61
1 /*
2 * Copyright (C) 2006 Dmitry Timoshkov
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #include <stdarg.h>
21 #include "windef.h"
22 #include "winbase.h"
23 #include "winerror.h"
24 #include "winuser.h"
25 #include "ntdsapi.h"
26 #include "wine/debug.h"
27 #include "wine/unicode.h"
29 WINE_DEFAULT_DEBUG_CHANNEL(ntdsapi);
31 /*****************************************************
32 * DllMain
34 BOOL WINAPI DllMain(HINSTANCE hinst, DWORD reason, LPVOID reserved)
36 TRACE("(%p, %d, %p)\n", hinst, reason, reserved);
38 switch(reason)
40 case DLL_WINE_PREATTACH:
41 return FALSE; /* prefer native version */
43 case DLL_PROCESS_ATTACH:
44 DisableThreadLibraryCalls( hinst );
45 break;
47 return TRUE;
50 /***********************************************************************
51 * DsMakeSpnW (NTDSAPI.@)
53 DWORD WINAPI DsMakeSpnW(LPCWSTR svc_class, LPCWSTR svc_name,
54 LPCWSTR inst_name, USHORT inst_port,
55 LPCWSTR ref, DWORD *spn_length, LPWSTR spn)
57 DWORD new_spn_length;
58 INT len;
59 LPWSTR p;
61 TRACE("(%s,%s,%s,%d,%s,%p,%p)\n", debugstr_w(svc_class),
62 debugstr_w(svc_name), debugstr_w(inst_name), inst_port,
63 debugstr_w(ref), spn_length, spn);
65 if (!svc_class || !svc_name)
66 return ERROR_INVALID_PARAMETER;
68 new_spn_length = strlenW(svc_class) + 1 /* for '/' */ + 1 /* for terminating '\0' */;
69 if (inst_name)
70 new_spn_length += strlenW(inst_name);
71 else
72 new_spn_length += strlenW(svc_name);
73 if (inst_port)
75 USHORT n = inst_port;
76 new_spn_length += 1 /* for ':' */;
79 n /= 10;
80 new_spn_length++;
81 } while (n != 0);
83 if (inst_name)
84 new_spn_length += 1 /* for '/' */ + strlenW(svc_name);
86 if (*spn_length < new_spn_length)
88 *spn_length = new_spn_length;
89 return ERROR_BUFFER_OVERFLOW;
91 *spn_length = new_spn_length;
93 p = spn;
94 len = strlenW(svc_class);
95 memcpy(p, svc_class, len * sizeof(WCHAR));
96 p += len;
97 *p = '/';
98 p++;
99 if (inst_name)
101 len = strlenW(inst_name);
102 memcpy(p, inst_name, len * sizeof(WCHAR));
103 p += len;
104 *p = '\0';
106 else
108 len = strlenW(svc_name);
109 memcpy(p, svc_name, len * sizeof(WCHAR));
110 p += len;
111 *p = '\0';
114 if (inst_port)
116 static const WCHAR percentU[] = {'%','u',0};
117 *p = ':';
118 p++;
119 wsprintfW(p, percentU, inst_port);
120 p += strlenW(p);
123 if (inst_name)
125 *p = '/';
126 p++;
127 len = strlenW(svc_name);
128 memcpy(p, svc_name, len * sizeof(WCHAR));
129 p += len;
130 *p = '\0';
133 TRACE("spn = %s\n", debugstr_w(spn));
135 return ERROR_SUCCESS;
138 /***********************************************************************
139 * DsMakeSpnA (NTDSAPI.@)
141 * See DsMakeSpnW.
143 DWORD WINAPI DsMakeSpnA(LPCSTR svc_class, LPCSTR svc_name,
144 LPCSTR inst_name, USHORT inst_port,
145 LPCSTR ref, DWORD *spn_length, LPSTR spn)
147 FIXME("(%s,%s,%s,%d,%s,%p,%p): stub!\n", debugstr_a(svc_class),
148 debugstr_a(svc_name), debugstr_a(inst_name), inst_port,
149 debugstr_a(ref), spn_length, spn);
151 return ERROR_CALL_NOT_IMPLEMENTED;