summaryrefslogtreecommitdiff
path: root/doc/spec/proposals/001-process.txt
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-02-10 03:43:00 +0000
committerNick Mathewson <nickm@torproject.org>2007-02-10 03:43:00 +0000
commitc9f43d68c9c4a2920615a7b8e9751a04ad0b2314 (patch)
tree968f3801cafad1194942d8a61362182062a9aa7a /doc/spec/proposals/001-process.txt
parentb3ac3acefcdb632ed84facaf4f59118d54d53df4 (diff)
downloadtor-c9f43d68c9c4a2920615a7b8e9751a04ad0b2314.tar.gz
tor-c9f43d68c9c4a2920615a7b8e9751a04ad0b2314.zip
r12202@Kushana: nickm | 2007-02-09 12:05:53 -0500
Mark 100 dead; write more about what should go in a proposal; add status tags to index. svn:r9543
Diffstat (limited to 'doc/spec/proposals/001-process.txt')
-rw-r--r--doc/spec/proposals/001-process.txt56
1 files changed, 52 insertions, 4 deletions
diff --git a/doc/spec/proposals/001-process.txt b/doc/spec/proposals/001-process.txt
index 882a679246..418a5b853a 100644
--- a/doc/spec/proposals/001-process.txt
+++ b/doc/spec/proposals/001-process.txt
@@ -82,7 +82,8 @@ Proposal status:
See comments in the document for details.
Dead: The proposal hasn't been touched in a long time, and it doesn't look
- like anybody is going to complete it soon.
+ like anybody is going to complete it soon. It can become "Open" again
+ if it gets a new proponent.
Needs-Research: There are research problems that need to be solved before
it's clear whether the proposal is a good idea.
@@ -96,7 +97,54 @@ Proposal numbering:
What should go in a proposal:
- WRITE MORE.
+ Every proposal should have a header containing these fields:
+ Filename, Title, Version, Last-Modified, Author, Created, Status.
+ The Version and Last-Modified fields should use the SVN Revision and Date
+ tags respectively.
+
+ The body of the proposal should start with an Overview section explaining
+ what the proposal's about, what it does, and about what state it's in.
+
+ After the Overview, the proposal becomes more free-form. Depending its
+ the length and complexity, the proposal can break into sections as
+ appropriate, or follow a short discursive format. Every proposal should
+ contain at least the following information before it can be "ACCEPTED",
+ thought the information does not need to be in sections with these names.
+
+ Motivation: What problem is the proposal trying to solve? Why does
+ this problem matter? If several approaches are possible, why take this
+ one?
+
+ Design: A high-level view of what the new or modified features are, how
+ the new or modified features work, how they interoperate with each
+ other, and how they interact with the rest of Tor. This is the main
+ body of the proposal. Some proposals will start out with only a
+ Motivation and a Design, and wait for a specification until the
+ Design seems approximately right.
+
+ Security implications: What effects might the proposed changes have on
+ anonymity, how well understood these effects are, and so on.
+
+ Specification: A detailed description of what needs to be added to the
+ Tor specifications in order to implement the proposal. This should
+ be in about as much detail as the specifications will eventually
+ contain: it should be possible for independent programmers to write
+ mutually compatible implementations of the proposal based on its
+ specifications.
+
+ Compatibility: Will versions of Tor that follow the proposal be
+ compatible with versions that do not? If so, how will compatibility
+ me achieved? Generally, we try to not to drop compatibility if at
+ all possible; we haven't made a "flag day" change since 2003 or
+ earlier, and we don't want to do another one. [XXX is this true?]
+
+ Implementation: If the proposal will be tricky to implement in Tor's
+ current architecture, the document can contain some discussion of how
+ to go about making it work.
+
+ Performance and scalability notes: If the feature will have an effect
+ on performance (in RAM, CPU, bandwidth) or scalability, there should
+ be some analysis on how significant this effect will be, so that we
+ can avoid really expensive performance regressions, and so we can
+ avoid wasting time on insignificant gains.
- Before a proposal is "ACCEPTED", it should have about as much detail as
- the specs would for the proposed feature.