updates.
authorPekka Riikonen <priikone@silcnet.org>
Sat, 23 Dec 2006 17:57:47 +0000 (17:57 +0000)
committerPekka Riikonen <priikone@silcnet.org>
Sat, 23 Dec 2006 17:57:47 +0000 (17:57 +0000)
CHANGES
TODO
apps/irssi/src/silc/core/silc-core.c
configure.ad

diff --git a/CHANGES b/CHANGES
index 96ae6d2c43e2a0d5ec53f4b5bfbec4568a686156..96f924c471ca7f9abcc0acf3e08dfa4dbf770d5f 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -1,3 +1,23 @@
+Thu Dec 21 18:01:51 EET 2006  Pekka Riikonen <priikone@silcnet.org>
+
+       * Changed SILC_FSM_[CONTINUE|YIELD|WAIT|FINISH] enums to
+         macros.  SILC_FSM_CONTINUE macro now immediately calls the
+         next state instead of first returning back to FSM.  Helps
+         in debugging crashes etc.
+
+          Removed FSM Semaphores.  Introduced FSM Event which is
+         asynchronous event.   Affected files are in lib/.
+
+       * Added epoll(7) support to SILC Scheduler.  It is used by default
+         if it is available.  Affected files are
+         lib/silcutil/silcschedule.[ch],
+         lib/silcutil/unix/silcunixschedule.c.
+
+Tue Dec 19 20:39:35 EET 2006  Pekka Riikonen <priikone@silcnet.org>
+
+       * Added CTR mode to AES.  Simplified cipher implementation API
+         more.  Affected files are in lib/silccrypt/.
+
 Sun Dec 17 16:46:55 EET 2006  Pekka Riikonen <priikone@silcnet.org>
 
        * Removed `detach' client operation.  The detachment data is
diff --git a/TODO b/TODO
index d8ce78c2765b907ffab27eca3e4d9bd6fee9ac52..9a8d4881008303b76dad8f1c112d717014c9784c 100644 (file)
--- a/TODO
+++ b/TODO
@@ -6,7 +6,7 @@ NOTE: Any item that doesn't have (***DONE) in it, isn't done yet.  The
 tested.
 
 
-SILC Client
+SILC Client    ****PARTLY DONE****
 ===========
 
  o Porting to new Toolkit API and new Client Library API
@@ -14,7 +14,7 @@ SILC Client
  o Improve help files, especially /cmode, /cumode and /key.
 
 
-lib/silcclient, The Client Library
+lib/silcclient, The Client Library     ***PARTLY DONE****
 ==================================
 
  o silcclient.h clean up and API rewrites.
@@ -23,21 +23,22 @@ lib/silcclient, The Client Library
 
  o SilcChannelEntry, SilcServerEntry, SilcChannelUser, allocating, 
    freeing, finding, etc. rewrite.  Also making them reference counted for 
-   multi threads use.
+   multi threads use. (***DONE)
 
  o Finish all the missing SILC packet processings, rewrites.
 
- o The client_notify.c rewrite.
+ o The client_notify.c rewrite. (***TESTING NEEDED)
 
  o Resuming to client_register.c (remove client_resume.c)
+   (***TESTING NEEDED)
 
- o Rekey rewrite.
+ o Rekey rewrite. (***DONE)
 
- o Remove protocol.[ch].
+ o Remove protocol.[ch]. (***DONE)
 
  o File transfer rewrite.
 
- o Starting key exchange directly, rewrite.
+ o Starting key exchange directly, rewrite. (***DONE)
 
  o Channel messages, channel private keys, channel entires, channel 
    search, etc. rewrite.
@@ -48,23 +49,23 @@ lib/silcclient, The Client Library
 
  o Password auth test, public key auth test.
 
- o Key agreement rewrite.
+ o Key agreement rewrite. (***TESTING NEEDED)
 
- o Connecting to remote client, peer-to-peer private messages
+ o Connecting to remote client (***DONE)
+
+ o peer-to-peer private messages
 
  o Private message waiting API (in threads)
 
- o client_attrs.c, attributes rewrite.
+ o client_attrs.c, attributes rewrite. (***TESTING NEEDED)
 
  o No SilcBuffer lists back to application in command_reply operations.
    Convert them all to real lists and/or structures for easier use.
+   (***DONE)
 
- o Nickname formatting rewrite.
-
- o UDP connections.
+ o Nickname formatting rewrite. (***TESTING NEEDED)
 
- o Remove silc_client_run and silc_client_run_one from calling SilcSchedule.
-   Leave the scheduling entirely to application.
+ o UDP connections. (***TESTING NEEDED)
 
  o in /cmode and /cumode with +r, maybe the public key and private key
    could be just some "string", which would then match to "string.pub" and
@@ -73,6 +74,12 @@ lib/silcclient, The Client Library
  o All packet waiting timeout tests and error condition tests.
 
 
+lib/silcsftp
+============
+
+ o Porting to use the new util library.
+
+
 lib/silccore/silcpacket.[ch]   ****DONE****
 ============================
 
@@ -112,13 +119,13 @@ lib/silcskr
    be.
 
 
-lib/silcske/silcske.[ch]
+lib/silcske/silcske.[ch] ****PARTLY DONE****
 ========================
 
- o IV Included flag support in SKE (***TESTING NEEDED)
+ o IV Included flag support in SKE (***DONE)
 
  o UDP transport changes; retransmission support by using exponential
-   backoff algorithm.
+   backoff algorithm. (***DONE)
 
  o SilcConnAuth header file documentation.
 
@@ -146,8 +153,7 @@ lib/silccrypt                       ****PARTLY DONE****
 
  o Add DSS support.
 
- o Cipher optimizations (asm, that this) at least for i386 would be nice.
-   Take Gladman's AES ASM.
+ o Assembler AES (***DONE)
 
  o ECDSA and ECDH.
 
@@ -169,7 +175,6 @@ lib/silcutil                        ****PARTLY DONE****
 
  o Silc FD Stream to WIN32 (lib/silcutil/silcfdstream.h)
 
-
 lib/silcutil/silcbuffer.h      ****DONE****
 =========================
 
@@ -182,7 +187,7 @@ lib/silcutil/silcbuffer.h   ****DONE****
    totally 8 bytes of memory per buffer. (***DONE)
 
 
-lib/silcutil/silcbuffmt.[ch]   ****PARTLY DONE****
+lib/silcutil/silcbuffmt.[ch]   ****DONE****
 ============================
 
  o SilcStack aware silc_buffer_unformat (***DONE)
@@ -218,7 +223,7 @@ lib/silcutil/silcsocketstream.[ch]  ****PARTY DONE****
  o Test QoS after the changes made to socket stream
 
 
-lib/silcutil/silcschedule*.[ch]                ****DONE****
+lib/silcutil/silcschedule*.[ch]                ****PARTLY DONE****
 ===============================
 
  o Scheduler can be optimized for FD tasks by changing the fd_queue
@@ -281,25 +286,6 @@ lib/silcutil/silcnet*, lib/silcutil/*/silc*net*            ****PARTLY DONE****
  o New network interfaces (***DONE)
 
 
-lib/silcsftp
-============
-
- o Porting to use the new util library.
-
-
-lib/silcutil/epoc/*
-===================
-
-  o lib/silcutil/epoc routines missing or not completed.
-
-  o The PKCS#1 also calls global RNG (even though it is not used
-    currently in SILC, the interface allows its use).
-
-  o Something needs to be thought to the logging globals as well,
-    like silc_debug etc.  They won't work on EPOC.  Perhaps logging
-    and debugging is to be disabled on EPOC.
-
-
 lib/silcmath
 ============
 
@@ -324,6 +310,19 @@ lib/silcmath
  o All utility functions should be made non-allocating ones.
 
 
+lib/silcutil/epoc/*
+===================
+
+  o lib/silcutil/epoc routines missing or not completed.
+
+  o The PKCS#1 also calls global RNG (even though it is not used
+    currently in SILC, the interface allows its use).
+
+  o Something needs to be thought to the logging globals as well,
+    like silc_debug etc.  They won't work on EPOC.  Perhaps logging
+    and debugging is to be disabled on EPOC.
+
+
 lib/silcasn1                   ****PARTLY DONE****
 ============
 
index 26c6f379d338f99dec8e1cc9a8e1f39bc35c1039..5566ace2212d936df6f1872e65dfcb651a2ad31a 100644 (file)
@@ -216,14 +216,6 @@ static bool silc_log_stderr(SilcLogType type, char *message, void *context)
   return TRUE;
 }
 
-static void silc_nickname_format_parse(const char *nickname,
-                                      char **ret_nickname)
-{
-  char nick[128 + 1];
-  silc_parse_userfqdn(nickname, nick, sizeof(nick), NULL, 0);
-  *ret_nickname = strdup(nick);
-}
-
 static void silc_register_cipher(SilcClient client, const char *cipher)
 {
   int i;
@@ -521,7 +513,6 @@ void silc_core_init(void)
   /* Initialize client parameters */
   memset(&params, 0, sizeof(params));
   strcat(params.nickname_format, "%n@%h%a");
-  params.nickname_parse = silc_nickname_format_parse;
   params.connauth_request_secs = settings_get_int("connauth_request_secs");
 
   /* Allocate SILC client */
index 09d7652e6c6e4859f7da3b1d38f139ed9e2f109e..90c55578620cb88cc25988ab15659cf0f00cc8f7 100644 (file)
@@ -177,7 +177,7 @@ AC_CHECK_FUNCS(poll select listen bind shutdown close connect setsockopt)
 AC_CHECK_FUNCS(setrlimit time ctime utime gettimeofday getrusage)
 AC_CHECK_FUNCS(chmod fcntl stat fstat getenv putenv strerror)
 AC_CHECK_FUNCS(getpid getgid getsid getpgid getpgrp getuid)
-AC_CHECK_FUNCS(setgroups initgroups nl_langinfo)
+AC_CHECK_FUNCS(setgroups initgroups nl_langinfo epoll_wait)
 AC_CHECK_FUNCS(strchr strstr strcpy strncpy memcpy memset memmove)
 
 #ifdef SILC_DIST_SIM