Fixed silc_client_get_clients_local to parse nick@server string
authorPekka Riikonen <priikone@silcnet.org>
Tue, 5 Jun 2007 19:03:45 +0000 (19:03 +0000)
committerPekka Riikonen <priikone@silcnet.org>
Tue, 5 Jun 2007 19:03:45 +0000 (19:03 +0000)
in addition to formatted nickname strings.

CHANGES
lib/silcclient/client_entry.c

diff --git a/CHANGES b/CHANGES
index 74873f58c890005d791f7962012caa998995fc00..9c0b3f31fc254581738328042db1034e091f8abe 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -1,3 +1,13 @@
+Tue Jun  5 20:48:40 EEST 2007  Pekka Riikonen <priikone@silcnet.org>
+
+       * Fixed silc_packet_get_ids to decode the IDs correctly.
+         Affected file is lib/silccore/silcpacket.c.
+
+       * Fixed silc_client_get_clients_local to parse correctly nickname
+         string that may have server name in it (nick@server) regardless
+         whether it was formatted nickname or not.  Affected file is
+         lib/silcclient/client_entry.c.
+
 Mon Jun  4 22:02:53 CEST 2007  Jochen Eisinger <jochen@penguin-breeder.org>
 
        * Only destroy sendbuffers, if they still exist (they cease to
index 27e78e341d427ec51136387f01f56e15f7369401..705e1cd1a74d088581be2f03b6d0ecfe8672eaff 100644 (file)
@@ -72,19 +72,22 @@ SilcDList silc_client_get_clients_local_ext(SilcClient client,
   SilcList list;
   SilcDList clients;
   SilcClientEntry entry;
-  char *nicknamec, *parsed = NULL, *format = NULL;
+  char nick[128 + 1], *nicknamec, *parsed = NULL, *format = NULL;
 
   if (!client || !conn || !nickname)
     return NULL;
 
+  /* Get nickname from nickname@server string */
+  silc_parse_userfqdn(nickname, nick, sizeof(nick), NULL, 0);
+
   /* Parse nickname in case it is formatted */
-  if (!silc_client_nickname_parse(client, conn, (char *)nickname, &parsed))
+  if (!silc_client_nickname_parse(client, conn, (char *)nick, &parsed))
     return NULL;
 
   if (!get_all && parsed)
-    format = (char *)nickname;
+    format = (char *)nick;
   if (!parsed) {
-    parsed = silc_memdup(nickname, strlen(nickname));
+    parsed = silc_memdup(nick, strlen(nick));
     if (!parsed)
       return NULL;
   }