This file is indexed.

/usr/share/help/C/programming-guidelines/writing-good-code.page is in gnome-devel-docs 3.18.1-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
<page xmlns="http://projectmallard.org/1.0/"
      xmlns:its="http://www.w3.org/2005/11/its"
      type="topic"
      id="writing-good-code">

  <info>
    <link type="guide" xref="index#general-guidelines"/>
    
    <credit type="author copyright">
      <name>Federico Mena-Quintero</name>
      <email its:translate="no">federico@gnome.org</email>
      <years>2013</years>
    </credit>
    <credit type="author copyright">
      <name>Miguel de Icaza</name>
      <email its:translate="no">miguel@gnome.org</email>
    </credit>
    <credit type="author copyright">
      <name>Morten Welinder</name>
      <email its:translate="no">mortenw@gnome.org</email>
    </credit>

    <include href="cc-by-sa-3-0.xml" xmlns="http://www.w3.org/2001/XInclude"/>

    <desc>Good, readable code keeps the project maintainable</desc>
  </info>

  <title>The Importance of Writing Good Code</title>

  <p>
    GNOME is a very ambitious free software project, and it is
    composed of many software packages that are more or less
    independent of each other.  A lot of the work in GNOME is done by
    volunteers:  although there are many people working on GNOME
    full-time or part-time for here, volunteers still make up a large
    percentage of our contributors.  Programmers may come and go at
    any time and they will be able to dedicate different amounts of
    time to the GNOME project.  People's "real world" responsibilities
    may change, and this will be reflected in the amount of time that
    they can devote to GNOME.
  </p>

  <p>
    Software development takes long amounts of time and painstaking
    effort.  This is why most part-time volunteers cannot start big
    projects by themselves; it is much easier and more rewarding to
    contribute to existing projects, as this yields results that are
    immediately visible and usable.
  </p>

  <p>
    Thus, we conclude that it is very important for existing projects
    to make it as easy as possible for people to contribute to them.
    One way of doing this is by making sure that programs are easy to
    read, understand, modify, and maintain.
  </p>

  <p>
    Messy code is hard to read, and people may lose interest if they
    cannot decipher what the code tries to do.  Also, it is important
    that programmers be able to understand the code quickly so that
    they can start contributing with bug fixes and enhancements in a
    short amount of time.  Source code is a form of
    <em>communication</em>, and it is more for people than for
    computers.  Just as someone would not like to read a novel with
    spelling errors, bad grammar, and sloppy punctuation, programmers
    should strive to write good code that is easy to understand and
    modify by others.
  </p>

  <p>
    The following are some important qualities of good code:
  </p>

  <terms>
    <item>
      <title>Cleanliness</title>
      <p>
	Clean code is easy to read with minimum effort.  This lets
	people start to understand it easily.  This includes the
	coding style itself (brace placement, indentation, variable
	names), and the actual control flow of the code.
      </p>
    </item>

    <item>
      <title>Consistency</title>
      <p>
	Consistent code makes it easy for people to understand how a
	program works.  When reading consistent code, one
	subconsciously forms a number of assumptions and expectations
	about how the code works, so it is easier and safer to make
	modifications to it.  Code that <em>looks</em> the same in two
	places should <em>work</em> the same, too.
      </p>
    </item>

    <item>
      <title>Extensibility</title>
      <p>
	General-purpose code is easier to reuse and modify than very
	specific code with lots of hardcoded assumptions.  When
	someone wants to add a new feature to a program, it will
	obviously be easier to do so if the code was designed to be
	extensible from the beginning.  Code that was not written this
	way may lead people into having to implement ugly hacks to add
	features.
      </p>
    </item>

    <item>
      <title>Correctness</title>
      <p>
	Finally, code that is designed to be correct lets people spend
	less time worrying about bugs, and more time enhancing the
	features of a program.  Users also appreciate correct code,
	since nobody likes software that crashes.  Code that is
	written for correctness and safety (i.e. code that explicitly
	tries to ensure that the program remains in a consistent
	state) prevents many kinds of silly bugs.
      </p>
    </item>
  </terms>

  <section id="book-references">
    <title>Book References</title>

    <list>
      <item><p>
        <link href="http://www.cc2e.com">Code Complete</link>, by Steve McConnell.
      </p></item>
      <item><p>
        <link href="http://martinfowler.com/books/refactoring.html">
          Refactoring: Improving the Design of Existing Code
        </link>, by Martin Fowler.
      </p></item>
      <item><p>
        <link href="http://en.wikipedia.org/wiki/Design_Patterns">
          Design Patterns: Elements of Reusable Object-Oriented Software
        </link>, by Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides.
      </p></item>
      <item><p>
        <link href="http://astore.amazon.com/gnomestore-20/detail/020163385X">
          Object-Oriented Design Heuristics
        </link>, by Arthur Riel.
      </p></item>
    </list>
  </section>
</page>