mirror of
https://github.com/isocpp/CppCoreGuidelines.git
synced 2024-03-22 13:30:58 +08:00
Fix a few more typos
F.22: Fix typos C.128: Update the title in the ToC, to match the new title from commit f0e29f0 Con.1: Fix typo T.84: Fix typo NR.2: Remove duplicated word from title (single single)
This commit is contained in:
parent
9987d835b9
commit
6fb7ad6bb5
@ -2821,7 +2821,7 @@ In traditional C and C++ code, plain `T*` is used for many weakly-related purpos
|
|||||||
* Identify an array with a length specified separately
|
* Identify an array with a length specified separately
|
||||||
* Identify a location in an array
|
* Identify a location in an array
|
||||||
|
|
||||||
The makes it hard to understand what code does and is supposed to do.
|
This makes it hard to understand what the code does and is supposed to do.
|
||||||
It complicates checking and tool support.
|
It complicates checking and tool support.
|
||||||
|
|
||||||
##### Example
|
##### Example
|
||||||
@ -5894,7 +5894,7 @@ Designing rules for classes in a hierarchy summary:
|
|||||||
|
|
||||||
* [C.126: An abstract class typically doesn't need a constructor](#Rh-abstract-ctor)
|
* [C.126: An abstract class typically doesn't need a constructor](#Rh-abstract-ctor)
|
||||||
* [C.127: A class with a virtual function should have a virtual or protected destructor](#Rh-dtor)
|
* [C.127: A class with a virtual function should have a virtual or protected destructor](#Rh-dtor)
|
||||||
* [C.128: Use `override` to make overriding explicit in large class hierarchies](#Rh-override)
|
* [C.128: Virtual functions should specify exactly one of `virtual`, `override`, or `final`](#Rh-override)
|
||||||
* [C.129: When designing a class hierarchy, distinguish between implementation inheritance and interface inheritance](#Rh-kind)
|
* [C.129: When designing a class hierarchy, distinguish between implementation inheritance and interface inheritance](#Rh-kind)
|
||||||
* [C.130: Redefine or prohibit copying for a base class; prefer a virtual `clone` function instead](#Rh-copy)
|
* [C.130: Redefine or prohibit copying for a base class; prefer a virtual `clone` function instead](#Rh-copy)
|
||||||
* [C.131: Avoid trivial getters and setters](#Rh-get)
|
* [C.131: Avoid trivial getters and setters](#Rh-get)
|
||||||
@ -13713,7 +13713,7 @@ Constant rule summary:
|
|||||||
|
|
||||||
##### Reason
|
##### Reason
|
||||||
|
|
||||||
Immutable objects are easier to reason about, so make object non-`const` only when there is a need to change their value.
|
Immutable objects are easier to reason about, so make objects non-`const` only when there is a need to change their value.
|
||||||
Prevents accidental or hard-to-notice change of value.
|
Prevents accidental or hard-to-notice change of value.
|
||||||
|
|
||||||
##### Example
|
##### Example
|
||||||
@ -15547,7 +15547,7 @@ It could be a base class:
|
|||||||
List<string> ls;
|
List<string> ls;
|
||||||
|
|
||||||
Now there is only one copy of the operations linking and unlinking elements of a `List`.
|
Now there is only one copy of the operations linking and unlinking elements of a `List`.
|
||||||
The `Link` and `List` classes does nothing but type manipulation.
|
The `Link` and `List` classes do nothing but type manipulation.
|
||||||
|
|
||||||
Instead of using a separate "base" type, another common technique is to specialize for `void` or `void*` and have the general template for `T` be just the safely-encapsulated casts to and from the core `void` implementation.
|
Instead of using a separate "base" type, another common technique is to specialize for `void` or `void*` and have the general template for `T` be just the safely-encapsulated casts to and from the core `void` implementation.
|
||||||
|
|
||||||
@ -16620,7 +16620,7 @@ The positive arguments for alternatives to these non-rules are listed in the rul
|
|||||||
Non-rule summary:
|
Non-rule summary:
|
||||||
|
|
||||||
* [NR.1: Don't: All declarations should be at the top of a function](#Rnr-top)
|
* [NR.1: Don't: All declarations should be at the top of a function](#Rnr-top)
|
||||||
* [NR.2: Don't: Have only a single single `return`-statement in a function](#Rnr-single-return)
|
* [NR.2: Don't: Have only a single `return`-statement in a function](#Rnr-single-return)
|
||||||
* [NR.3: Don't: Don't use exceptions](#Rnr-no-exceptions)
|
* [NR.3: Don't: Don't use exceptions](#Rnr-no-exceptions)
|
||||||
* [NR.4: Don't: Place each class declaration in its own source file](#Rnr-lots-of-files)
|
* [NR.4: Don't: Place each class declaration in its own source file](#Rnr-lots-of-files)
|
||||||
* [NR.5: Don't: Don't do substantive work in a constructor; instead use two-phase initialization](#Rnr-two-phase-init)
|
* [NR.5: Don't: Don't do substantive work in a constructor; instead use two-phase initialization](#Rnr-two-phase-init)
|
||||||
@ -16648,7 +16648,7 @@ Fortunately, compilers catch many "used before set" errors.
|
|||||||
* [Always initialize an object](#Res-always)
|
* [Always initialize an object](#Res-always)
|
||||||
* [ES.21: Don't introduce a variable (or constant) before you need to use it](#Res-introduce)
|
* [ES.21: Don't introduce a variable (or constant) before you need to use it](#Res-introduce)
|
||||||
|
|
||||||
### <a name="Rnr-single-return"></a>NR.2: Don't: Have only a single single `return`-statement in a function
|
### <a name="Rnr-single-return"></a>NR.2: Don't: Have only a single `return`-statement in a function
|
||||||
|
|
||||||
##### Reason (not to follow this rule)
|
##### Reason (not to follow this rule)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user