Commit 110c8dc5 authored by Alexandre Julliard's avatar Alexandre Julliard

Fixed a number of atom test failures.

parent 7e4af0f6
...@@ -54,7 +54,7 @@ static NTSTATUS is_integral_atom( LPCWSTR atomstr, size_t len, RTL_ATOM* pAtom ) ...@@ -54,7 +54,7 @@ static NTSTATUS is_integral_atom( LPCWSTR atomstr, size_t len, RTL_ATOM* pAtom )
if (HIWORD( atomstr )) if (HIWORD( atomstr ))
{ {
const WCHAR* ptr = atomstr; const WCHAR* ptr = atomstr;
if (!len) return STATUS_INVALID_PARAMETER; if (!len) return STATUS_OBJECT_NAME_INVALID;
if (*ptr++ == '#') if (*ptr++ == '#')
{ {
...@@ -70,7 +70,7 @@ static NTSTATUS is_integral_atom( LPCWSTR atomstr, size_t len, RTL_ATOM* pAtom ) ...@@ -70,7 +70,7 @@ static NTSTATUS is_integral_atom( LPCWSTR atomstr, size_t len, RTL_ATOM* pAtom )
} }
else atom = LOWORD( atomstr ); else atom = LOWORD( atomstr );
done: done:
if (atom >= MAXINTATOM) return STATUS_INVALID_PARAMETER; if (!atom || atom >= MAXINTATOM) return STATUS_INVALID_PARAMETER;
*pAtom = atom; *pAtom = atom;
return STATUS_SUCCESS; return STATUS_SUCCESS;
} }
...@@ -140,11 +140,11 @@ NTSTATUS WINAPI RtlQueryAtomInAtomTable( RTL_ATOM_TABLE table, RTL_ATOM atom, UL ...@@ -140,11 +140,11 @@ NTSTATUS WINAPI RtlQueryAtomInAtomTable( RTL_ATOM_TABLE table, RTL_ATOM atom, UL
{ {
if (*len > wlen) if (*len > wlen)
{ {
*len = wlen;
memcpy( name, full_name, wlen ); memcpy( name, full_name, wlen );
name[wlen / sizeof(WCHAR)] = 0; name[wlen / sizeof(WCHAR)] = 0;
} }
else status = STATUS_BUFFER_TOO_SMALL; else status = STATUS_BUFFER_TOO_SMALL;
*len = wlen;
} }
TRACE( "%p %x -> %s (%lu)\n", TRACE( "%p %x -> %s (%lu)\n",
...@@ -196,7 +196,7 @@ NTSTATUS WINAPI RtlAddAtomToAtomTable( RTL_ATOM_TABLE table, const WCHAR* name, ...@@ -196,7 +196,7 @@ NTSTATUS WINAPI RtlAddAtomToAtomTable( RTL_ATOM_TABLE table, const WCHAR* name,
if (!table) status = STATUS_INVALID_PARAMETER; if (!table) status = STATUS_INVALID_PARAMETER;
else else
{ {
size_t len = strlenW(name); size_t len = HIWORD(name) ? strlenW(name) : 0;
status = is_integral_atom( name, len, atom ); status = is_integral_atom( name, len, atom );
if (status == STATUS_MORE_ENTRIES) if (status == STATUS_MORE_ENTRIES)
{ {
...@@ -226,7 +226,7 @@ NTSTATUS WINAPI RtlLookupAtomInAtomTable( RTL_ATOM_TABLE table, const WCHAR* nam ...@@ -226,7 +226,7 @@ NTSTATUS WINAPI RtlLookupAtomInAtomTable( RTL_ATOM_TABLE table, const WCHAR* nam
if (!table) status = STATUS_INVALID_PARAMETER; if (!table) status = STATUS_INVALID_PARAMETER;
else else
{ {
size_t len = strlenW(name); size_t len = HIWORD(name) ? strlenW(name) : 0;
status = is_integral_atom( name, len, atom ); status = is_integral_atom( name, len, atom );
if (status == STATUS_MORE_ENTRIES) if (status == STATUS_MORE_ENTRIES)
{ {
...@@ -271,19 +271,19 @@ NTSTATUS WINAPI RtlEmptyAtomTable( RTL_ATOM_TABLE table, BOOLEAN delete_pinned ) ...@@ -271,19 +271,19 @@ NTSTATUS WINAPI RtlEmptyAtomTable( RTL_ATOM_TABLE table, BOOLEAN delete_pinned )
*/ */
NTSTATUS WINAPI RtlPinAtomInAtomTable( RTL_ATOM_TABLE table, RTL_ATOM atom ) NTSTATUS WINAPI RtlPinAtomInAtomTable( RTL_ATOM_TABLE table, RTL_ATOM atom )
{ {
NTSTATUS status = STATUS_INVALID_PARAMETER; NTSTATUS status;
if (!table) return STATUS_INVALID_PARAMETER;
if (atom < MAXINTATOM) return STATUS_SUCCESS;
if (table && atom >= MAXINTATOM) SERVER_START_REQ( set_atom_information )
{ {
SERVER_START_REQ( set_atom_information ) req->table = table;
{ req->atom = atom;
req->table = table; req->pinned = TRUE;
req->atom = atom; status = wine_server_call( req );
req->pinned = TRUE;
status = wine_server_call( req );
}
SERVER_END_REQ;
} }
SERVER_END_REQ;
return status; return status;
} }
......
...@@ -253,10 +253,12 @@ static atom_t add_atom( struct atom_table *table, const WCHAR *str, size_t len ) ...@@ -253,10 +253,12 @@ static atom_t add_atom( struct atom_table *table, const WCHAR *str, size_t len )
} }
/* delete an atom from the table */ /* delete an atom from the table */
static void delete_atom( struct atom_table *table, atom_t atom ) static void delete_atom( struct atom_table *table, atom_t atom, int if_pinned )
{ {
struct atom_entry *entry = get_atom_entry( table, atom ); struct atom_entry *entry = get_atom_entry( table, atom );
if (entry && !--entry->count) if (!entry) return;
if (entry->pinned && !if_pinned) set_error( STATUS_WAS_LOCKED );
else if (!--entry->count)
{ {
if (entry->next) entry->next->prev = entry->prev; if (entry->next) entry->next->prev = entry->prev;
if (entry->prev) entry->prev->next = entry->next; if (entry->prev) entry->prev->next = entry->next;
...@@ -328,7 +330,7 @@ int grab_global_atom( atom_t atom ) ...@@ -328,7 +330,7 @@ int grab_global_atom( atom_t atom )
/* decrement the ref count of a global atom; used for window properties */ /* decrement the ref count of a global atom; used for window properties */
void release_global_atom( atom_t atom ) void release_global_atom( atom_t atom )
{ {
if (atom >= MIN_STR_ATOM) delete_atom( global_table, atom ); if (atom >= MIN_STR_ATOM) delete_atom( global_table, atom, 1 );
} }
/* add a global atom */ /* add a global atom */
...@@ -348,7 +350,7 @@ DECL_HANDLER(delete_atom) ...@@ -348,7 +350,7 @@ DECL_HANDLER(delete_atom)
struct atom_table *table = get_table( req->table ); struct atom_table *table = get_table( req->table );
if (table) if (table)
{ {
delete_atom( table, req->atom ); delete_atom( table, req->atom, 0 );
release_object( table ); release_object( table );
} }
} }
...@@ -376,7 +378,7 @@ DECL_HANDLER(get_atom_information) ...@@ -376,7 +378,7 @@ DECL_HANDLER(get_atom_information)
{ {
size_t len = entry->len * sizeof(WCHAR); size_t len = entry->len * sizeof(WCHAR);
if (len <= get_reply_max_size()) set_reply_data( entry->str, len ); if (len <= get_reply_max_size()) set_reply_data( entry->str, len );
else set_error( STATUS_BUFFER_OVERFLOW ); else if (get_reply_max_size()) set_error( STATUS_BUFFER_OVERFLOW );
reply->count = entry->count; reply->count = entry->count;
reply->pinned = entry->pinned; reply->pinned = entry->pinned;
} }
......
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