ole: Remove __CLSIDFromStringA.
Move the ANSI implementation of CLSIDFromString to ole16.c and change CLSIDFromString to only deal with Unicode strings.
This commit is contained in:
parent
1926b6da63
commit
cc4669cc5f
|
@ -795,31 +795,23 @@ HRESULT WINAPI CoCreateGuid(GUID *pguid)
|
||||||
* S_OK on success
|
* S_OK on success
|
||||||
* CO_E_CLASSSTRING if idstr is not a valid CLSID
|
* CO_E_CLASSSTRING if idstr is not a valid CLSID
|
||||||
*
|
*
|
||||||
* BUGS
|
|
||||||
*
|
|
||||||
* In Windows, if idstr is not a valid CLSID string then it gets
|
|
||||||
* treated as a ProgID. Wine currently doesn't do this. If idstr is
|
|
||||||
* NULL it's treated as an all-zero GUID.
|
|
||||||
*
|
|
||||||
* SEE ALSO
|
* SEE ALSO
|
||||||
* StringFromCLSID
|
* StringFromCLSID
|
||||||
*/
|
*/
|
||||||
HRESULT WINAPI __CLSIDFromStringA(LPCSTR idstr, CLSID *id)
|
static HRESULT WINAPI __CLSIDFromString(LPCWSTR s, CLSID *id)
|
||||||
{
|
{
|
||||||
const BYTE *s;
|
|
||||||
int i;
|
int i;
|
||||||
BYTE table[256];
|
BYTE table[256];
|
||||||
|
|
||||||
if (!idstr) {
|
if (!s) {
|
||||||
memset( id, 0, sizeof (CLSID) );
|
memset( id, 0, sizeof (CLSID) );
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* validate the CLSID string */
|
/* validate the CLSID string */
|
||||||
if (strlen(idstr) != 38)
|
if (strlenW(s) != 38)
|
||||||
return CO_E_CLASSSTRING;
|
return CO_E_CLASSSTRING;
|
||||||
|
|
||||||
s = (const BYTE *) idstr;
|
|
||||||
if ((s[0]!='{') || (s[9]!='-') || (s[14]!='-') || (s[19]!='-') || (s[24]!='-') || (s[37]!='}'))
|
if ((s[0]!='{') || (s[9]!='-') || (s[14]!='-') || (s[19]!='-') || (s[24]!='-') || (s[37]!='}'))
|
||||||
return CO_E_CLASSSTRING;
|
return CO_E_CLASSSTRING;
|
||||||
|
|
||||||
|
@ -831,7 +823,7 @@ HRESULT WINAPI __CLSIDFromStringA(LPCSTR idstr, CLSID *id)
|
||||||
return CO_E_CLASSSTRING;
|
return CO_E_CLASSSTRING;
|
||||||
}
|
}
|
||||||
|
|
||||||
TRACE("%s -> %p\n", s, id);
|
TRACE("%s -> %p\n", debugstr_w(s), id);
|
||||||
|
|
||||||
/* quick lookup table */
|
/* quick lookup table */
|
||||||
memset(table, 0, 256);
|
memset(table, 0, 256);
|
||||||
|
@ -868,14 +860,9 @@ HRESULT WINAPI __CLSIDFromStringA(LPCSTR idstr, CLSID *id)
|
||||||
|
|
||||||
HRESULT WINAPI CLSIDFromString(LPOLESTR idstr, CLSID *id )
|
HRESULT WINAPI CLSIDFromString(LPOLESTR idstr, CLSID *id )
|
||||||
{
|
{
|
||||||
char xid[40];
|
|
||||||
HRESULT ret;
|
HRESULT ret;
|
||||||
|
|
||||||
if (!WideCharToMultiByte( CP_ACP, 0, idstr, -1, xid, sizeof(xid), NULL, NULL ))
|
ret = __CLSIDFromString(idstr, id);
|
||||||
return CO_E_CLASSSTRING;
|
|
||||||
|
|
||||||
|
|
||||||
ret = __CLSIDFromStringA(xid,id);
|
|
||||||
if(ret != S_OK) { /* It appears a ProgID is also valid */
|
if(ret != S_OK) { /* It appears a ProgID is also valid */
|
||||||
ret = CLSIDFromProgID(idstr, id);
|
ret = CLSIDFromProgID(idstr, id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,7 +169,6 @@ extern void* StdGlobalInterfaceTableInstance;
|
||||||
|
|
||||||
/* FIXME: these shouldn't be needed, except for 16-bit functions */
|
/* FIXME: these shouldn't be needed, except for 16-bit functions */
|
||||||
extern HRESULT WINE_StringFromCLSID(const CLSID *id,LPSTR idstr);
|
extern HRESULT WINE_StringFromCLSID(const CLSID *id,LPSTR idstr);
|
||||||
HRESULT WINAPI __CLSIDFromStringA(LPCSTR idstr, CLSID *id);
|
|
||||||
|
|
||||||
HRESULT COM_OpenKeyForCLSID(REFCLSID clsid, LPCWSTR keyname, REGSAM access, HKEY *key);
|
HRESULT COM_OpenKeyForCLSID(REFCLSID clsid, LPCWSTR keyname, REGSAM access, HKEY *key);
|
||||||
HRESULT MARSHAL_GetStandardMarshalCF(LPVOID *ppv);
|
HRESULT MARSHAL_GetStandardMarshalCF(LPVOID *ppv);
|
||||||
|
|
|
@ -284,8 +284,62 @@ HRESULT WINAPI CLSIDFromString16(
|
||||||
LPCOLESTR16 idstr, /* [in] string representation of guid */
|
LPCOLESTR16 idstr, /* [in] string representation of guid */
|
||||||
CLSID *id) /* [out] GUID converted from string */
|
CLSID *id) /* [out] GUID converted from string */
|
||||||
{
|
{
|
||||||
|
const BYTE *s;
|
||||||
|
int i;
|
||||||
|
BYTE table[256];
|
||||||
|
|
||||||
return __CLSIDFromStringA(idstr,id);
|
if (!idstr) {
|
||||||
|
memset( id, 0, sizeof (CLSID) );
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* validate the CLSID string */
|
||||||
|
if (strlen(idstr) != 38)
|
||||||
|
return CO_E_CLASSSTRING;
|
||||||
|
|
||||||
|
s = (const BYTE *) idstr;
|
||||||
|
if ((s[0]!='{') || (s[9]!='-') || (s[14]!='-') || (s[19]!='-') || (s[24]!='-') || (s[37]!='}'))
|
||||||
|
return CO_E_CLASSSTRING;
|
||||||
|
|
||||||
|
for (i=1; i<37; i++) {
|
||||||
|
if ((i == 9)||(i == 14)||(i == 19)||(i == 24)) continue;
|
||||||
|
if (!(((s[i] >= '0') && (s[i] <= '9')) ||
|
||||||
|
((s[i] >= 'a') && (s[i] <= 'f')) ||
|
||||||
|
((s[i] >= 'A') && (s[i] <= 'F'))))
|
||||||
|
return CO_E_CLASSSTRING;
|
||||||
|
}
|
||||||
|
|
||||||
|
TRACE("%s -> %p\n", s, id);
|
||||||
|
|
||||||
|
/* quick lookup table */
|
||||||
|
memset(table, 0, 256);
|
||||||
|
|
||||||
|
for (i = 0; i < 10; i++) {
|
||||||
|
table['0' + i] = i;
|
||||||
|
}
|
||||||
|
for (i = 0; i < 6; i++) {
|
||||||
|
table['A' + i] = i+10;
|
||||||
|
table['a' + i] = i+10;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* in form {XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX} */
|
||||||
|
|
||||||
|
id->Data1 = (table[s[1]] << 28 | table[s[2]] << 24 | table[s[3]] << 20 | table[s[4]] << 16 |
|
||||||
|
table[s[5]] << 12 | table[s[6]] << 8 | table[s[7]] << 4 | table[s[8]]);
|
||||||
|
id->Data2 = table[s[10]] << 12 | table[s[11]] << 8 | table[s[12]] << 4 | table[s[13]];
|
||||||
|
id->Data3 = table[s[15]] << 12 | table[s[16]] << 8 | table[s[17]] << 4 | table[s[18]];
|
||||||
|
|
||||||
|
/* these are just sequential bytes */
|
||||||
|
id->Data4[0] = table[s[20]] << 4 | table[s[21]];
|
||||||
|
id->Data4[1] = table[s[22]] << 4 | table[s[23]];
|
||||||
|
id->Data4[2] = table[s[25]] << 4 | table[s[26]];
|
||||||
|
id->Data4[3] = table[s[27]] << 4 | table[s[28]];
|
||||||
|
id->Data4[4] = table[s[29]] << 4 | table[s[30]];
|
||||||
|
id->Data4[5] = table[s[31]] << 4 | table[s[32]];
|
||||||
|
id->Data4[6] = table[s[33]] << 4 | table[s[34]];
|
||||||
|
id->Data4[7] = table[s[35]] << 4 | table[s[36]];
|
||||||
|
|
||||||
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
|
@ -556,7 +610,7 @@ HRESULT WINAPI CLSIDFromProgID16(LPCOLESTR16 progid, LPCLSID riid)
|
||||||
return CO_E_CLASSSTRING;
|
return CO_E_CLASSSTRING;
|
||||||
}
|
}
|
||||||
RegCloseKey(xhkey);
|
RegCloseKey(xhkey);
|
||||||
return __CLSIDFromStringA(buf2,riid);
|
return CLSIDFromString16(buf2,riid);
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
|
|
Loading…
Reference in New Issue