order | parent | |
---|---|---|
1 |
|
A Request for Comments (RFC) is a record of discussion on an open-ended topic related to the design and implementation of Tendermint Core, for which no immediate decision is required.
The purpose of an RFC is to serve as a historical record of a high-level discussion that might otherwise only be recorded in an ad hoc way (for example, via gists or Google docs) that are difficult to discover for someone after the fact. An RFC may give rise to more specific architectural decisions for Tendermint, but those decisions must be recorded separately in Architecture Decision Records (ADR).
As a rule of thumb, if you can articulate a specific question that needs to be answered, write an ADR. If you need to explore the topic and get input from others to know what questions need to be answered, an RFC may be appropriate.
An RFC should provide:
- A changelog, documenting when and how the RFC has changed.
- An abstract, briefly summarizing the topic so the reader can quickly tell whether it is relevant to their interest.
- Any background a reader will need to understand and participate in the substance of the discussion (links to other documents are fine here).
- The discussion, the primary content of the document.
The rfc-template.md file includes placeholders for these sections.
- RFC-000: P2P Roadmap
- RFC-001: Storage Engines
- RFC-002: Interprocess Communication
- RFC-003: Performance Taxonomy
- RFC-004: E2E Test Framework Enhancements
- RFC-005: Event System
- RFC-006: Event Subscription
- RFC-007: Deterministic Proto Byte Serialization
- RFC-008: Don't Panic
- RFC-009: Consensus Parameter Upgrades
- RFC-010: P2P Light Client
- RFC-011: Delete Gas
- RFC-012: Event Indexing Revisited
- RFC-013: ABCI++
- RFC-014: Semantic Versioning
- RFC-015: ABCI++ Tx Mutation
- RFC-016: Node Architecture
- RFC-017: ABCI++ Vote Extension Propagation
- RFC-018: BLS Signature Aggregation Exploration
- RFC-019: Configuration File Versioning
- RFC-020: Onboarding Projects