X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=TODO;h=c52751c771f8c363e5357feddac351d3a914dcb9;hb=refs%2Fheads%2Fchannels;hp=a7d96da6b848bcec34fa26d0665f2bd2674c14a0;hpb=f882e43ac21968705598e67db7cd2d79511b3466;p=meshlink diff --git a/TODO b/TODO index a7d96da6..c52751c7 100644 --- a/TODO +++ b/TODO @@ -1,13 +1,16 @@ TODO list for MeshLink ---------------------- -* Write meshlink_sign() and meshlink_verify(). These should just call - ecdsa_sign() and _verify(), with mesh->self->connection->ecdsa as the key for - _sign(), and node->ecdsa for _verify()? +* Speed up start: immediately do outgoing connections instead of waiting 5 seconds. * meshlink_join(): - add checks that we only join another mesh if we did not connect to any other node before. - only allow meshlink_join() when the library thread is not running. + - remove old host config file if the invitation gave the node a different name. + - how to handle nodes that are part of one mesh and want to join another? + +* meshlink_leave()? + - leaving a mesh is basically starting all over again, with new private keys? * Allow meshlink_open() to be called with a NULL name, in anticipation of meshlink_join(). - Do not allow meshlink_start() if no Name is set. @@ -21,8 +24,6 @@ TODO list for MeshLink * Add autoconf/automake stuff to call Doxygen. -* Write a test suite for the library. - * Write a manual - Document API - Explain what MeshLink does and how it should be used in the application @@ -36,26 +37,15 @@ TODO list for MeshLink * Add a "channel" library to MeshLink. - Support multiple TCP- and UDP-like streams between two nodes. -Mostly done: ------------- - -* Check for remaining global variables and get rid of them. +* Move queue code to its own source file. -* Write code for all the functions in meshlink.c (some can be moved from libmeshlink.c) - Current stubs that need implementation: - - meshlink_export() - - meshlink_import() - - meshlink_blacklist() - -* Implement a simple single producer, single consumer queue for communication - between the application and library threads. It is possible to do this without locks. +Not finished but being worked on: +--------------------------------- * Provide thread-safety to functions that return pointers to meshlink_node_t. - The mesh->nodes tree can be updated by the library thread at any time, so it must be protected by a mutex or rwlock. - Individial node_t's must never be freed or moved except in meshlink_close(). + - Check all public API functions. -* Make the headers work correctly in a C++ environment. - -* Add a header-only C++ wrapper API. - +* Write a test suite for the library.