diff options
author | Nick Mathewson <nickm@torproject.org> | 2019-12-17 09:39:50 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2019-12-17 09:39:50 -0500 |
commit | 5f9808d1d799c39f014ce3175779123aabc6058b (patch) | |
tree | 8e90bd5d4910d5367c68ef2a147a3721b5902df9 /src | |
parent | 47d69d981e63200c519e9bd9d358da9887c3c7ae (diff) | |
parent | 0fd49c6663e3950092ec7436a43dc4154740df68 (diff) | |
download | tor-5f9808d1d799c39f014ce3175779123aabc6058b.tar.gz tor-5f9808d1d799c39f014ce3175779123aabc6058b.zip |
Merge remote-tracking branch 'tor-github/pr/1596'
Diffstat (limited to 'src')
-rw-r--r-- | src/arch_goals.md | 31 | ||||
-rw-r--r-- | src/mainpage.md | 2 |
2 files changed, 33 insertions, 0 deletions
diff --git a/src/arch_goals.md b/src/arch_goals.md new file mode 100644 index 0000000000..92c86d9df8 --- /dev/null +++ b/src/arch_goals.md @@ -0,0 +1,31 @@ +@page arch_goals High level code design practices + +This page describes the high level design practices for Tor's code. +This design is a long-term goal of what we want our code to look like, +rather than a description of how it currently is. + +Overall, we want various parts of tor's code to interact with each +other through a small number of interfaces. + +We want to avoid having "god objects" or "god modules". These are +objects or modules that know far too much about other parts of the +code. God objects/modules are generally recognized to be an +antipattern of software design. + +Historically, there have been modules in tor that have tended toward +becoming god modules. These include modules that help more +specialized code communicate with the outside world: the configuration +and control modules, for example. Others are modules that deal with +global state, initialization, or shutdown. + +If a centralized module needs to invoke code in almost every other +module in the system, it is better if it exports a small, general +interface that other modules call. The centralized module should not +explicitly call out to all the modules that interact with it. + +Instead, modules that interact with the centralized module should call +registration interfaces. These interfaces allow modules to register +handlers for things like configuration parsing and control command +execution. (The config and control modules are examples of this.) +Alternatively, registration can happen through statically initialized +data structures. (The subsystem mechanism is an example of this.) diff --git a/src/mainpage.md b/src/mainpage.md index 3901e79559..8a73578819 100644 --- a/src/mainpage.md +++ b/src/mainpage.md @@ -29,6 +29,8 @@ Tor repository. @subpage intro +@subpage arch_goals + @subpage initialization @subpage dataflow |