~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to HACKING

  • Committer: John Arbash Meinel
  • Date: 2006-10-11 00:23:23 UTC
  • mfrom: (2070 +trunk)
  • mto: This revision was merged to the branch mainline in revision 2071.
  • Revision ID: john@arbash-meinel.com-20061011002323-82ba88c293d7caff
[merge] bzr.dev 2070

Show diffs side-by-side

added added

removed removed

Lines of Context:
78
78
There are some common requirements in the library: some parameters need to be
79
79
unicode safe, some need byte strings, and so on. At the moment we have
80
80
only codified one specific pattern: Parameters that need to be unicode
81
 
should be checked via ``bzrlib.osutils.safe_unicode``. This will coerce the
 
81
should be checked via 'bzrlib.osutils.safe_unicode'. This will coerce the
82
82
input into unicode in a consistent fashion, allowing trivial strings to be
83
83
used for programmer convenience, but not performing unpredictably in the
84
84
presence of different locales.
85
85
 
86
 
 
87
 
Copyright
88
 
---------
89
 
 
90
 
The copyright policy for bzr was recently made clear in this email (edited
91
 
for grammatical correctness)::
92
 
 
93
 
    The attached patch cleans up the copyright and license statements in
94
 
    the bzr source. It also adds tests to help us remember to add them
95
 
    with the correct text.
96
 
 
97
 
    We had the problem that lots of our files were "Copyright Canonical
98
 
    Development Ltd" which is not a real company, and some other variations
99
 
    on this theme. Also, some files were missing the GPL statements.
100
 
    
101
 
    I want to be clear about the intent of this patch, since copyright can
102
 
    be a little controversial.
103
 
    
104
 
    1) The big motivation for this is not to shut out the community, but
105
 
    just to clean up all of the invalid copyright statements.
106
 
    
107
 
    2) It has been the general policy for bzr that we want a single
108
 
    copyright holder for all of the core code. This is following the model
109
 
    set by the FSF, which makes it easier to update the code to a new
110
 
    license in case problems are encountered. (For example, if we want to
111
 
    upgrade the project universally to GPL v3 it is much simpler if there is
112
 
    a single copyright holder). It also makes it clearer if copyright is
113
 
    ever debated, there is a single holder, which makes it easier to defend
114
 
    in court, etc. (I think the FSF position is that if you assign them
115
 
    copyright, they can defend it in court rather than you needing to, and
116
 
    I'm sure Canonical would do the same).
117
 
    As such, Canonical has requested copyright assignments from all of the
118
 
    major contributers.
119
 
    
120
 
    3) If someone wants to add code and not attribute it to Canonical, there
121
 
    is a specific list of files that are excluded from this check. And the
122
 
    test failure indicates where that is, and how to update it.
123
 
    
124
 
    4) If anyone feels that I changed a copyright statement incorrectly, just
125
 
    let me know, and I'll be happy to correct it. Whenever you have large
126
 
    mechanical changes like this, it is possible to make some mistakes.
127
 
    
128
 
    Just to reiterate, this is a community project, and it is meant to stay
129
 
    that way. Core bzr code is copyright Canonical for legal reasons, and
130
 
    the tests are just there to help us maintain that.
131
 
 
132
 
 
133
86
Documentation
134
87
=============
135
88
 
209
162
 
210
163
Consider naming classes as nouns and functions/methods as verbs.
211
164
 
212
 
Try to avoid using abbreviations in names, because there can be
213
 
inconsistency if other people use the full name.
214
 
 
215
165
 
216
166
Standard names
217
167
--------------
259
209
> factory, then yes, foo_factory is what I would use.
260
210
 
261
211
 
262
 
Registries
263
 
----------
264
 
 
265
 
Several places in Bazaar use (or will use) a registry, which is a 
266
 
mapping from names to objects or classes.  The registry allows for 
267
 
loading in registered code only when it's needed, and keeping
268
 
associated information such as a help string or description.
269
 
 
270
 
 
271
212
Lazy Imports
272
213
------------
273
214
 
286
227
  from bzrlib import (
287
228
     errors,
288
229
     transport,
289
 
     revision as _mod_revision,
 
230
     foo as bar,
290
231
     )
291
232
  import bzrlib.transport
292
233
  import bzrlib.xml5
293
234
  """)
294
235
 
295
236
At this point, all of these exist as a ``ImportReplacer`` object, ready to
296
 
be imported once a member is accessed. Also, when importing a module into
297
 
the local namespace, which is likely to clash with variable names, it is
298
 
recommended to prefix it as ``_mod_<module>``. This makes it clean that
299
 
the variable is a module, and these object should be hidden anyway, since
300
 
they shouldn't be imported into other namespaces.
 
237
be imported once a member is accessed.
301
238
 
302
239
 
303
240
Modules versus Members
370
307
 
371
308
Writing tests
372
309
=============
373
 
 
374
310
In general tests should be placed in a file named test_FOO.py where 
375
311
FOO is the logical thing under test. That file should be placed in the
376
312
tests subdirectory under the package being tested.
405
341
    command changes its name or signature. Ideally only the tests for a
406
342
    given command are affected when a given command is changed.
407
343
 
408
 
 4. If you have a test which does actually require running bzr in a
409
 
    subprocess you can use ``run_bzr_subprocess``. By default the spawned
410
 
    process will not load plugins unless ``--allow-plugins`` is supplied.
411
 
 
412
 
 
413
344
Doctests
414
345
--------
415
346
 
440
371
Errors and exceptions
441
372
=====================
442
373
 
443
 
Errors are handled through Python exceptions.
444
 
 
445
 
We broadly classify errors as either being either internal or not,
446
 
depending on whether ``user_error`` is set or not.  If we think it's our
447
 
fault, we show a backtrace, an invitation to report the bug, and possibly
448
 
other details.  This is the default for errors that aren't specifically
449
 
recognized as being caused by a user error.  Otherwise we show a briefer
450
 
message, unless -Derror was given.
451
 
 
452
 
Many errors originate as "environmental errors" which are raised by Python
453
 
or builtin libraries -- for example IOError.  These are treated as being
454
 
our fault, unless they're caught in a particular tight scope where we know
455
 
that they indicate a user errors.  For example if the repository format
456
 
is not found, the user probably gave the wrong path or URL.  But if one of
457
 
the files inside the repository is not found, then it's our fault --
458
 
either there's a bug in bzr, or something complicated has gone wrong in
459
 
the environment that means one internal file was deleted.
460
 
 
461
 
Many errors are defined in ``bzrlib/errors.py`` but it's OK for new errors
462
 
to be added near the place where they are used.
463
 
 
464
 
Exceptions are formatted for the user by conversion to a string
465
 
(eventually calling their ``__str__`` method.)  As a convenience the
466
 
``._fmt`` member can be used as a template which will be mapped to the
467
 
error's instance dict.
468
 
 
469
 
New exception classes should be defined when callers might want to catch
470
 
that exception specifically, or when it needs a substantially different
471
 
format string.
472
 
 
473
 
Exception strings should start with a capital letter and should not have a
474
 
final fullstop.  If long, they may contain newlines to break the text.
475
 
 
 
374
Errors are handled through Python exceptions.  They can represent user
 
375
errors, environmental errors or program bugs.  Sometimes we can't be sure
 
376
at the time it's raised which case applies.  See bzrlib/errors.py for 
 
377
details on the error-handling practices.
476
378
 
477
379
 
478
380
Jargon
593
495
====================
594
496
 
595
497
If you'd like to propose a change, please post to the
596
 
bazaar@lists.canonical.com list with a patch, bzr changeset, or link to a
 
498
bazaar-ng@lists.canonical.com list with a patch, bzr changeset, or link to a
597
499
branch.  Please put '[patch]' in the subject so we can pick them out, and
598
500
include some text explaining the change.  Remember to put an update to the NEWS
599
501
file in your diff, if it makes any changes visible to users or plugin