Commit 688ba6ae authored by Alistair Leslie-Hughes's avatar Alistair Leslie-Hughes Committed by Alexandre Julliard

sapi: Implement ISpObjectToken GetId.

parent 01b4286f
...@@ -185,11 +185,11 @@ static void test_object_token(void) ...@@ -185,11 +185,11 @@ static void test_object_token(void)
ok( hr == S_OK, "got %08lx\n", hr ); ok( hr == S_OK, "got %08lx\n", hr );
hr = ISpObjectToken_GetId( token, NULL ); hr = ISpObjectToken_GetId( token, NULL );
todo_wine ok( hr == SPERR_UNINITIALIZED, "got %08lx\n", hr ); ok( hr == SPERR_UNINITIALIZED, "got %08lx\n", hr );
tempW = (LPWSTR)0xdeadbeef; tempW = (LPWSTR)0xdeadbeef;
hr = ISpObjectToken_GetId( token, &tempW ); hr = ISpObjectToken_GetId( token, &tempW );
todo_wine ok( hr == SPERR_UNINITIALIZED, "got %08lx\n", hr ); ok( hr == SPERR_UNINITIALIZED, "got %08lx\n", hr );
ok( tempW == (LPWSTR)0xdeadbeef, "got %s\n", wine_dbgstr_w(tempW) ); ok( tempW == (LPWSTR)0xdeadbeef, "got %s\n", wine_dbgstr_w(tempW) );
hr = ISpObjectToken_GetCategory( token, NULL ); hr = ISpObjectToken_GetCategory( token, NULL );
...@@ -220,15 +220,15 @@ static void test_object_token(void) ...@@ -220,15 +220,15 @@ static void test_object_token(void)
ok( hr == SPERR_ALREADY_INITIALIZED, "got %08lx\n", hr ); ok( hr == SPERR_ALREADY_INITIALIZED, "got %08lx\n", hr );
hr = ISpObjectToken_GetId( token, NULL ); hr = ISpObjectToken_GetId( token, NULL );
todo_wine ok( hr == E_POINTER, "got %08lx\n", hr ); ok( hr == E_POINTER, "got %08lx\n", hr );
hr = ISpObjectToken_GetCategory( token, NULL ); hr = ISpObjectToken_GetCategory( token, NULL );
todo_wine ok( hr == E_POINTER, "got %08lx\n", hr ); todo_wine ok( hr == E_POINTER, "got %08lx\n", hr );
tempW = NULL; tempW = NULL;
hr = ISpObjectToken_GetId( token, &tempW ); hr = ISpObjectToken_GetId( token, &tempW );
todo_wine ok( hr == S_OK, "got %08lx\n", hr ); ok( hr == S_OK, "got %08lx\n", hr );
todo_wine ok( tempW != NULL, "got %p\n", tempW ); ok( tempW != NULL, "got %p\n", tempW );
if (tempW) { if (tempW) {
ok( !wcscmp(tempW, L"HKEY_LOCAL_MACHINE\\SOFTWARE"), "got %s\n", ok( !wcscmp(tempW, L"HKEY_LOCAL_MACHINE\\SOFTWARE"), "got %s\n",
wine_dbgstr_w(tempW) ); wine_dbgstr_w(tempW) );
...@@ -268,8 +268,8 @@ static void test_object_token(void) ...@@ -268,8 +268,8 @@ static void test_object_token(void)
tempW = NULL; tempW = NULL;
hr = ISpObjectToken_GetId( token, &tempW ); hr = ISpObjectToken_GetId( token, &tempW );
todo_wine ok( hr == S_OK, "got %08lx\n", hr ); ok( hr == S_OK, "got %08lx\n", hr );
todo_wine ok( tempW != NULL, "got %p\n", tempW ); ok( tempW != NULL, "got %p\n", tempW );
if (tempW) { if (tempW) {
ok( !wcsncmp(tempW, token_id, wcslen(token_id)), ok( !wcsncmp(tempW, token_id, wcslen(token_id)),
"got %s (expected %s)\n", wine_dbgstr_w(tempW), wine_dbgstr_w(token_id) ); "got %s (expected %s)\n", wine_dbgstr_w(tempW), wine_dbgstr_w(token_id) );
......
...@@ -960,8 +960,28 @@ static HRESULT WINAPI token_SetId( ISpObjectToken *iface, ...@@ -960,8 +960,28 @@ static HRESULT WINAPI token_SetId( ISpObjectToken *iface,
static HRESULT WINAPI token_GetId( ISpObjectToken *iface, static HRESULT WINAPI token_GetId( ISpObjectToken *iface,
LPWSTR *token_id ) LPWSTR *token_id )
{ {
FIXME( "stub\n" ); struct object_token *This = impl_from_ISpObjectToken( iface );
return E_NOTIMPL;
TRACE( "%p, %p\n", This, token_id);
if (!This->token_key)
return SPERR_UNINITIALIZED;
if (!token_id)
return E_POINTER;
if (!This->token_id)
{
FIXME("Loading default category not supported.\n");
return E_POINTER;
}
*token_id = CoTaskMemAlloc( (wcslen(This->token_id) + 1) * sizeof(WCHAR));
if (!*token_id)
return E_OUTOFMEMORY;
wcscpy(*token_id, This->token_id);
return S_OK;
} }
static HRESULT WINAPI token_GetCategory( ISpObjectToken *iface, static HRESULT WINAPI token_GetCategory( ISpObjectToken *iface,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment