From ce06e09b3031fcd9a0a40b5a0297368407c19269 Mon Sep 17 00:00:00 2001 From: Richard Brooksby Date: Wed, 13 Nov 2024 13:17:13 +0000 Subject: [PATCH] Adding justification for rule.code.minimal based on Hyrum's Law. --- procedure/rule.code.rst | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/procedure/rule.code.rst b/procedure/rule.code.rst index 78460b0ae4..afd8f43d71 100644 --- a/procedure/rule.code.rst +++ b/procedure/rule.code.rst @@ -149,7 +149,16 @@ can be understood. _`.justification-limits`: [Nothing written yet. RB 1998-07-01] -_`.justification-minimal`: [Nothing written yet. RB 1998-07-01] +_`.justification-minimal`: The minimal rule avoids software entropy +and atrophy caused by Hyrum's Law [Hyrum-2020]_ : + + With a sufficient number of users of an API, + it does not matter what you promise in the contract: + all observable behaviors of your system + will be depended on by somebody. + +Enforcing minimal functionality enforces abstractions and prevents +dependency on unintended behaviour. _`.justification-req`: This is a restatement of the generic/achieve rule. The difference here is that the purpose of code is more often @@ -224,6 +233,13 @@ A. References 1995; ISBN 0-201-63181-4. +.. [Hyrum-2020] + "Software engineering at Google: lessons learned from programming over time"; + Titus Winters, Tom Manshreck, Hyrum Wright, eds. (2020).; + O'Reilly Media, 2020; + ISBN 9781492082798; + . + .. [RB-1998-06-30a] "General Code Ruleset"; `Richard Brooksby`_;