diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-11-01 13:19:12 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-11-01 13:22:09 -0400 |
commit | 8c491945057fae9b22823ace92acdf997ff28a28 (patch) | |
tree | 082f7c00b47695da399edde3069c9378f48ffe6c /src/or/tor_api.h | |
parent | 8b313bd4adac122bb01c52af3e616c5c69fd9414 (diff) | |
download | tor-8c491945057fae9b22823ace92acdf997ff28a28.tar.gz tor-8c491945057fae9b22823ace92acdf997ff28a28.zip |
Add more usage notes on tor_api.h
Diffstat (limited to 'src/or/tor_api.h')
-rw-r--r-- | src/or/tor_api.h | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/or/tor_api.h b/src/or/tor_api.h index 1699d5c68c..1abe6d1145 100644 --- a/src/or/tor_api.h +++ b/src/or/tor_api.h @@ -12,6 +12,19 @@ * a library, and launch it in a separate thread. If you have the ability * to run Tor as a separate executable, you should probably do that instead * of embedding it as a library. + * + * To use this API, first construct a tor_main_configuration_t object using + * tor_main_configuration_new(). Then, you use one or more other function + * calls (such as tor_main_configuration_set_command_line() to configure how + * Tor should be run. Finally, you pass the configuration object to + * tor_run_main(). + * + * At this point, tor_run_main() will block its thread to run a Tor daemon; + * when the Tor daemon exits, it will return. See notes on bugs and + * limitations below. + * + * There is no other public C API to Tor: calling any C Tor function not + * documented in this file is not guaranteed to be stable. **/ #ifndef TOR_API_H @@ -35,6 +48,7 @@ tor_main_configuration_t *tor_main_configuration_new(void); */ int tor_main_configuration_set_command_line(tor_main_configuration_t *cfg, int argc, char *argv[]); + /** * Release all storage held in <b>cfg</b>. * @@ -63,6 +77,12 @@ void tor_main_configuration_free(tor_main_configuration_t *cfg); * LIMITATION: You cannot run more than one instance of Tor in the same * process at the same time. Concurrent calls will cause undefined behavior. * We do not currently have plans to change this. + * + * LIMITATION: While we will try to fix any problems found here, you + * should be aware that Tor was originally written to run as its own + * process, and that the functionality of this file was added later. If + * you find any bugs or strange behavior, please report them, and we'll + * try to straighten them out. */ int tor_run_main(const tor_main_configuration_t *); |