~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to NEWS

  • Committer: Martin Pool
  • Date: 2006-06-05 18:00:36 UTC
  • mto: This revision was merged to the branch mainline in revision 1752.
  • Revision ID: mbp@sourcefrog.net-20060605180036-04f5d0cea94ed999
clean up test kipple

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
DEVELOPMENT HEAD
 
1
bzr 0.8  2006-05-08
 
2
 
 
3
  NOTES WHEN UPGRADING:
 
4
 
 
5
    Release 0.8 of bzr introduces a new format for history storage, called
 
6
    'knit', as an evolution of to the 'weave' format used in 0.7.  Local 
 
7
    and remote operations are faster using knits than weaves.  Several
 
8
    operations including 'init', 'init-repo', and 'upgrade' take a 
 
9
    --format option that controls this.  Branching from an existing branch
 
10
    will keep the same format.
 
11
 
 
12
    It is possible to merge, pull and push between branches of different
 
13
    formats but this is slower than moving data between homogenous
 
14
    branches.  It is therefore recommended (but not required) that you
 
15
    upgrade all branches for a project at the same time.  Information on
 
16
    formats is shown by 'bzr info'.
 
17
 
 
18
    bzr 0.8 now allows creation of 'repositories', which hold the history 
 
19
    of files and revisions for several branches.  Previously bzr kept all
 
20
    the history for a branch within the .bzr directory at the root of the
 
21
    branch, and this is still the default.  To create a repository, use
 
22
    the new 'bzr init-repo' command.  Branches exist as directories under
 
23
    the repository and contain just a small amount of information
 
24
    indicating the current revision of the branch.
 
25
 
 
26
    bzr 0.8 also supports 'checkouts', which are similar to in cvs and
 
27
    subversion.  Checkouts are associated with a branch (optionally in a
 
28
    repository), which contains all the historical information.  The
 
29
    result is that a checkout can be deleted without losing any
 
30
    already-committed revisions.  A new 'update' command is also available. 
 
31
 
 
32
    Repositories and checkouts are not supported with the 0.7 storage
 
33
    format.  To use them you must upgrad to either knits, or to the
 
34
    'metaweave' format, which uses weaves but changes the .bzr directory
 
35
    arrangement.
 
36
    
 
37
 
 
38
  IMPROVEMENTS:
 
39
 
 
40
    * Sftp paths can now be relative, or local, according to the lftp
 
41
      convention. Paths now take the form:
 
42
      sftp://user:pass@host:port/~/relative/path
 
43
      or
 
44
      sftp://user:pass@host:port/absolute/path
 
45
 
 
46
    * The FTP transport now tries to reconnect after a temporary
 
47
      failure. ftp put is made atomic. (Matthieu Moy)
 
48
 
 
49
    * The FTP transport now maintains a pool of connections, and
 
50
      reuses them to avoid multiple connections to the same host (like
 
51
      sftp did). (Daniel Silverstone)
 
52
 
 
53
    * The bzr_man.py file has been removed. To create the man page now,
 
54
      use ./generate_docs.py man. The new program can also create other files.
 
55
      Run "python generate_docs.py --help" for usage information. (Hans
 
56
      Ulrich Niedermann & James Blackwell).
 
57
 
 
58
    * Man Page now gives full help (James Blackwell). Help also updated to 
 
59
      reflect user config now being stored in .bazaar (Hans Ulrich
 
60
      Niedermann)
 
61
 
 
62
    * It's now possible to set aliases in bazaar.conf (Erik Bågfors)
 
63
 
 
64
    * Pull now accepts a --revision argument (Erik Bågfors)
 
65
 
 
66
    * 'bzr re-sign' now allows multiple revisions to be supplied on the command
 
67
      line. You can now use the following command to sign all of your old commits.
 
68
        find .bzr/revision-store// -name my@email-* \
 
69
          | sed 's/.*\/\/..\///' \
 
70
          | xargs bzr re-sign
 
71
 
 
72
    * Upgrade can now upgrade over the network. (Robert Collins)
 
73
 
 
74
    * Two new commands 'bzr checkout' and 'bzr update' allow for CVS/SVN-alike
 
75
      behaviour.  By default they will cache history in the checkout, but
 
76
      with --lightweight almost all data is kept in the master branch.
 
77
      (Robert Collins)
 
78
 
 
79
    * 'revert' unversions newly-versioned files, instead of deleting them.
 
80
 
 
81
    * 'merge' is more robust.  Conflict messages have changed.
 
82
 
 
83
    * 'merge' and 'revert' no longer clobber existing files that end in '~' or
 
84
      '.moved'.
 
85
 
 
86
    * Default log format can be set in configuration and plugins can register
 
87
      their own formatters. (Erik Bågfors)
 
88
 
 
89
    * New 'reconcile' command will check branch consistency and repair indexes
 
90
      that can become out of sync in pre 0.8 formats. (Robert Collins,
 
91
      Daniel Silverstone)
 
92
 
 
93
    * New 'bzr init --format' and 'bzr upgrade --format' option to control 
 
94
      what storage format is created or produced.  (Robert Collins, 
 
95
      Martin Pool)
 
96
 
 
97
    * Add parent location to 'bzr info', if there is one.  (Olaf Conradi)
 
98
 
 
99
    * New developer commands 'weave-list' and 'weave-join'.  (Martin Pool)
 
100
 
 
101
    * New 'init-repository' command, plus support for repositories in 'init'
 
102
      and 'branch' (Aaron Bentley, Erik Bågfors, Robert Collins)
 
103
 
 
104
    * Improve output of 'info' command. Show all relevant locations related to
 
105
      working tree, branch and repository. Use kibibytes for binary quantities.
 
106
      Fix off-by-one error in missing revisions of working tree.  Make 'info'
 
107
      work on branches, repositories and remote locations.  Show locations
 
108
      relative to the shared repository, if applicable.  Show locking status
 
109
      of locations.  (Olaf Conradi)
 
110
 
 
111
    * Diff and merge now safely handle binary files. (Aaron Bentley)
 
112
 
 
113
    * 'pull' and 'push' now normalise the revision history, so that any two
 
114
      branches with the same tip revision will have the same output from 'log'.
 
115
      (Robert Collins)
 
116
 
 
117
    * 'merge' accepts --remember option to store parent location, like 'push'
 
118
      and 'pull'. (Olaf Conradi)
 
119
 
 
120
    * bzr status and diff when files given as arguments do not exist
 
121
      in the relevant trees.  (Martin Pool, #3619)
 
122
 
 
123
    * Add '.hg' to the default ignore list.  (Martin Pool)
 
124
 
 
125
    * 'knit' is now the default disk format. This improves disk performance and
 
126
      utilization, increases incremental pull performance, robustness with SFTP
 
127
      and allows checkouts over SFTP to perform acceptably. 
 
128
      The initial Knit code was contributed by Johan Rydberg based on a
 
129
      specification by Martin Pool.
 
130
      (Robert Collins, Aaron Bentley, John Rydberg, Martin Pool).
 
131
 
 
132
    * New tool to generate all-in-one html version of the manual.  (Alexander
 
133
      Belchenko)
 
134
 
 
135
    * Hitting CTRL-C while doing an SFTP push will no longer cause stale locks
 
136
      to be left in the SFTP repository. (Robert Collins, Martin Pool).
 
137
 
 
138
    * New option 'diff --prefix' to control how files are named in diff
 
139
      output, with shortcuts '-p0' and '-p1' corresponding to the options for 
 
140
      GNU patch.  (Alexander Belchenko, Goffredo Baroncelli, Martin Pool)
 
141
 
 
142
    * Add --revision option to 'annotate' command.  (Olaf Conradi)
 
143
 
 
144
    * Add --revision option to 'annotate' command.  (Olaf Conradi)
 
145
 
 
146
    * If bzr shows an unexpected revision-history after pulling (perhaps due
 
147
      to a reweave) it can now be corrected by 'bzr reconcile'.
 
148
      (Robert Collins)
 
149
 
 
150
  CHANGES:
 
151
 
 
152
    * Commit is now verbose by default, and shows changed filenames and the 
 
153
      new revision number.  (Robert Collins, Martin Pool)
 
154
 
 
155
    * Unify 'mv', 'move', 'rename'.  (#5379, Matthew Fuller)
 
156
 
 
157
    * 'bzr -h' shows help.  (#35940, Martin Pool, Ian Bicking)
 
158
 
 
159
    * Make 'pull' and 'push' remember location on failure using --remember.
 
160
      (Olaf Conradi)
 
161
 
 
162
    * For compatibility, make old format for using weaves inside metadir
 
163
      available as 'metaweave' format.  Rename format 'metadir' to 'default'.
 
164
      Clean up help for option --format in commands 'init', 'init-repo' and
 
165
      'upgrade'.  (Olaf Conradi)
 
166
 
 
167
  INTERNALS:
 
168
  
 
169
    * The internal storage of history, and logical branch identity have now
 
170
      been split into Branch, and Repository. The common locking and file 
 
171
      management routines are now in bzrlib.lockablefiles. 
 
172
      (Aaron Bentley, Robert Collins, Martin Pool)
 
173
 
 
174
    * Transports can now raise DependencyNotPresent if they need a library
 
175
      which is not installed, and then another implementation will be 
 
176
      tried.  (Martin Pool)
 
177
 
 
178
    * Remove obsolete (and no-op) `decode` parameter to `Transport.get`.  
 
179
      (Martin Pool)
 
180
 
 
181
    * Using Tree Transform for merge, revert, tree-building
 
182
 
 
183
    * WorkingTree.create, Branch.create, WorkingTree.create_standalone,
 
184
      Branch.initialize are now deprecated. Please see BzrDir.create_* for
 
185
      replacement API's. (Robert Collins)
 
186
 
 
187
    * New BzrDir class represents the .bzr control directory and manages
 
188
      formatting issues. (Robert Collins)
 
189
 
 
190
    * New repository.InterRepository class encapsulates Repository to 
 
191
      Repository actions and allows for clean selection of optimised code
 
192
      paths. (Robert Collins)
 
193
 
 
194
    * bzrlib.fetch.fetch and bzrlib.fetch.greedy_fetch are now deprecated,
 
195
      please use 'branch.fetch' or 'repository.fetch' depending on your
 
196
      needs. (Robert Collins)
 
197
 
 
198
    * deprecated methods now have a 'is_deprecated' flag on them that can
 
199
      be checked, if you need to determine whether a given callable is 
 
200
      deprecated at runtime. (Robert Collins)
 
201
 
 
202
    * Progress bars are now nested - see
 
203
      bzrlib.ui.ui_factory.nested_progress_bar. (Robert Collins, Robey Pointer)
 
204
 
 
205
    * New API call get_format_description() for each type of format.
 
206
      (Olaf Conradi)
 
207
 
 
208
    * Changed branch.set_parent() to accept None to remove parent.
 
209
      (Olaf Conradi)
 
210
 
 
211
    * Deprecated BzrError AmbiguousBase.  (Olaf Conradi)
 
212
 
 
213
    * WorkingTree.branch is now a read only property.  (Robert Collins)
 
214
 
 
215
    * bzrlib.ui.text.TextUIFactory now accepts a bar_type parameter which
 
216
      can be None or a factory that will create a progress bar. This is
 
217
      useful for testing or for overriding the bzrlib.progress heuristic.
 
218
      (Robert Collins)
 
219
 
 
220
    * New API method get_physical_lock_status() to query locks present on a
 
221
      transport.  (Olaf Conradi)
 
222
 
 
223
    * Repository.reconcile now takes a thorough keyword parameter to allow
 
224
      requesting an indepth reconciliation, rather than just a data-loss 
 
225
      check. (Robert Collins)
 
226
 
 
227
    * bzrlib.ui.ui_factory protocol now supports 'get_boolean' to prompt
 
228
      the user for yes/no style input. (Robert Collins)
 
229
 
 
230
  TESTING:
 
231
 
 
232
    * SFTP tests now shortcut the SSH negotiation, reducing test overhead
 
233
      for testing SFTP protocol support. (Robey Pointer)
 
234
 
 
235
    * Branch formats are now tested once per implementation (see bzrlib.
 
236
      tests.branch_implementations. This is analagous to the transport
 
237
      interface tests, and has been followed up with working tree,
 
238
      repository and BzrDir tests. (Robert Collins)
 
239
 
 
240
    * New test base class TestCaseWithTransport provides a transport aware
 
241
      test environment, useful for testing any transport-interface using
 
242
      code. The test suite option --transport controls the transport used
 
243
      by this class (when its not being used as part of implementation
 
244
      contract testing). (Robert Collins)
 
245
 
 
246
    * Close logging handler on disabling the test log. This will remove the
 
247
      handler from the internal list inside python's logging module,
 
248
      preventing shutdown from closing it twice.  (Olaf Conradi)
 
249
 
 
250
    * Move test case for uncommit to blackbox tests.  (Olaf Conradi)
 
251
 
 
252
    * run_bzr and run_bzr_captured now accept a 'stdin="foo"' parameter which
 
253
      will provide String("foo") to the command as its stdin.
 
254
 
 
255
bzr 0.7 2006-01-09
 
256
 
 
257
  CHANGES:
 
258
 
 
259
    * .bzrignore is excluded from exports, on the grounds that it's a bzr 
 
260
      internal-use file and may not be wanted.  (Jamie Wilkinson)
 
261
 
 
262
    * The "bzr directories" command were removed in favor of the new
 
263
      --kind option to the "bzr inventory" command.  To list all 
 
264
      versioned directories, now use "bzr inventory --kind directory".  
 
265
      (Johan Rydberg)
 
266
 
 
267
    * Under Windows configuration directory is now %APPDATA%\bazaar\2.0
 
268
      by default. (John Arbash Meinel)
 
269
 
 
270
    * The parent of Bzr configuration directory can be set by BZR_HOME
 
271
      environment variable. Now the path for it is searched in BZR_HOME, then
 
272
      in HOME. Under Windows the order is: BZR_HOME, APPDATA (usually
 
273
      points to C:\Documents and Settings\User Name\Application Data), HOME.
 
274
      (John Arbash Meinel)
 
275
 
 
276
    * Plugins with the same name in different directories in the bzr plugin
 
277
      path are no longer loaded: only the first successfully loaded one is
 
278
      used. (Robert Collins)
 
279
 
 
280
    * Use systems' external ssh command to open connections if possible.  
 
281
      This gives better integration with user settings such as ProxyCommand.
 
282
      (James Henstridge)
 
283
 
 
284
    * Permissions on files underneath .bzr/ are inherited from the .bzr 
 
285
      directory. So for a shared repository, simply doing 'chmod -R g+w .bzr/'
 
286
      will mean that future file will be created with group write permissions.
 
287
 
 
288
    * configure.in and config.guess are no longer in the builtin default 
 
289
      ignore list.
 
290
 
 
291
    * '.sw[nop]' pattern ignored, to ignore vim swap files for nameless
 
292
      files.  (John Arbash Meinel, Martin Pool)
 
293
 
 
294
  IMPROVEMENTS:
 
295
 
 
296
    * "bzr INIT dir" now initializes the specified directory, and creates 
 
297
      it if it does not exist.  (John Arbash Meinel)
 
298
 
 
299
    * New remerge command (Aaron Bentley)
 
300
 
 
301
    * Better zsh completion script.  (Steve Borho)
 
302
 
 
303
    * 'bzr diff' now returns 1 when there are changes in the working 
 
304
      tree. (Robert Collins)
 
305
 
 
306
    * 'bzr push' now exists and can push changes to a remote location. 
 
307
      This uses the transport infrastructure, and can store the remote
 
308
      location in the ~/.bazaar/branches.conf configuration file.
 
309
      (Robert Collins)
 
310
 
 
311
    * Test directories are only kept if the test fails and the user requests
 
312
      that they be kept.
 
313
 
 
314
    * Tweaks to short log printing
 
315
 
 
316
    * Added branch nicks, new nick command, printing them in log output. 
 
317
      (Aaron Bentley)
 
318
 
 
319
    * If $BZR_PDB is set, pop into the debugger when an uncaught exception 
 
320
      occurs.  (Martin Pool)
 
321
 
 
322
    * Accept 'bzr resolved' (an alias for 'bzr resolve'), as this is
 
323
      the same as Subversion.  (Martin Pool)
 
324
 
 
325
    * New ftp transport support (on ftplib), for ftp:// and aftp:// 
 
326
      URLs.  (Daniel Silverstone)
 
327
 
 
328
    * Commit editor temporary files now start with 'bzr_log.', to allow 
 
329
      text editors to match the file name and set up appropriate modes or 
 
330
      settings.  (Magnus Therning)
 
331
 
 
332
    * Improved performance when integrating changes from a remote weave.  
 
333
      (Goffredo Baroncelli)
 
334
 
 
335
    * Sftp will attempt to cache the connection, so it is more likely that
 
336
      a connection will be reused, rather than requiring multiple password
 
337
      requests.
 
338
 
 
339
    * bzr revno now takes an optional argument indicating the branch whose
 
340
      revno should be printed.  (Michael Ellerman)
 
341
 
 
342
    * bzr cat defaults to printing the last version of the file.  
 
343
      (#3632, Matthieu Moy)
 
344
 
 
345
    * New global option 'bzr --lsprof COMMAND' runs bzr under the lsprof 
 
346
      profiler.  (Denys Duchier)
 
347
 
 
348
    * Faster commits by reading only the headers of affected weave files. 
 
349
      (Denys Duchier)
 
350
 
 
351
    * 'bzr add' now takes a --dry-run parameter which shows you what would be
 
352
      added, but doesn't actually add anything. (Michael Ellerman)
 
353
 
 
354
    * 'bzr add' now lists how many files were ignored per glob.  add --verbose
 
355
      lists the specific files.  (Aaron Bentley)
 
356
 
 
357
    * 'bzr missing' now supports displaying changes in diverged trees and can
 
358
      be limited to show what either end of the comparison is missing.
 
359
      (Aaron Bently, with a little prompting from Daniel Silverstone)
 
360
 
 
361
  BUG FIXES:
 
362
 
 
363
    * SFTP can walk up to the root path without index errors. (Robert Collins)
 
364
 
 
365
    * Fix bugs in running bzr with 'python -O'.  (Martin Pool)
 
366
 
 
367
    * Error when run with -OO
 
368
 
 
369
    * Fix bug in reporting http errors that don't have an http error code.
 
370
      (Martin Pool)
 
371
 
 
372
    * Handle more cases of pipe errors in display commands
 
373
 
 
374
    * Change status to 3 for all errors
 
375
 
 
376
    * Files that are added and unlinked before committing are completely
 
377
      ignored by diff and status
 
378
 
 
379
    * Stores with some compressed texts and some uncompressed texts are now
 
380
      able to be used. (John A Meinel)
 
381
 
 
382
    * Fix for bzr pull failing sometimes under windows
 
383
 
 
384
    * Fix for sftp transport under windows when using interactive auth
 
385
 
 
386
    * Show files which are both renamed and modified as such in 'bzr 
 
387
      status' output.  (#4503, Daniel Silverstone)
 
388
 
 
389
    * Make annotate cope better with revisions committed without a valid 
 
390
      email address.  (Marien Zwart)
 
391
 
 
392
    * Fix representation of tab characters in commit messages.  (Harald 
 
393
      Meland)
 
394
 
 
395
    * List of plugin directories in BZR_PLUGIN_PATH environment variable is
 
396
      now parsed properly under Windows. (Alexander Belchenko)
 
397
 
 
398
    * Show number of revisions pushed/pulled/merged. (Robey Pointer)
 
399
 
 
400
    * Keep a cached copy of the basis inventory to speed up operations 
 
401
      that need to refer to it.  (Johan Rydberg, Martin Pool)
 
402
 
 
403
    * Fix bugs in bzr status display of non-ascii characters.  (Martin 
 
404
      Pool)
 
405
 
 
406
    * Remove Makefile.in from default ignore list.  (#6413, Tollef Fog 
 
407
      Heen, Martin Pool)
 
408
 
 
409
    * Fix failure in 'bzr added'.  (Nathan McCallum, Martin Pool)
 
410
 
 
411
  TESTING:
 
412
 
 
413
    * Fix selftest asking for passwords when there are no SFTP keys.  
 
414
      (Robey Pointer, Jelmer Vernooij) 
 
415
 
 
416
    * Fix selftest run with 'python -O'.  (Martin Pool)
 
417
 
 
418
    * Fix HTTP tests under Windows. (John Arbash Meinel)
 
419
 
 
420
    * Make tests work even if HOME is not set (Aaron Bentley)
 
421
 
 
422
    * Updated build_tree to use fixed line-endings for tests which read 
 
423
      the file cotents and compare. Make some tests use this to pass under
 
424
      Windows. (John Arbash Meinel)
 
425
 
 
426
    * Skip stat and symlink tests under Windows. (Alexander Belchenko)
 
427
 
 
428
    * Delay in selftest/testhashcash is now issued under win32 and Cygwin.
 
429
      (John Arbash Meinel)
 
430
 
 
431
    * Use terminal width to align verbose test output.  (Martin Pool)
 
432
 
 
433
    * Blackbox tests are maintained within the bzrlib.tests.blackbox directory.
 
434
      If adding a new test script please add that to
 
435
      bzrlib.tests.blackbox.__init__. (Robert Collins)
 
436
 
 
437
    * Much better error message if one of the test suites can't be 
 
438
      imported.  (Martin Pool)
 
439
 
 
440
    * Make check now runs the test suite twice - once with the default locale,
 
441
      and once with all locales forced to C, to expose bugs. This is not 
 
442
      trivially done within python, so for now its only triggered by running
 
443
      Make check. Integrators and packagers who wish to check for full 
 
444
      platform support should run 'make check' to test the source.
 
445
      (Robert Collins)
 
446
 
 
447
    * Tests can now run TestSkipped if they can't execute for any reason.
 
448
      (Martin Pool) (NB: TestSkipped should only be raised for correctable
 
449
      reasons - see the wiki spec ImprovingBzrTestSuite).
 
450
 
 
451
    * Test sftp with relative, absolute-in-homedir and absolute-not-in-homedir
 
452
      paths for the transport tests. Introduce blackbox remote sftp tests that
 
453
      test the same permutations. (Robert Collins, Robey Pointer)
 
454
 
 
455
    * Transport implementation tests are now independent of the local file
 
456
      system, which allows tests for esoteric transports, and for features
 
457
      not available in the local file system. They also repeat for variations
 
458
      on the URL scheme that can introduce issues in the transport code,
 
459
      see bzrlib.transport.TransportTestProviderAdapter() for this.
 
460
      (Robert Collins).
 
461
 
 
462
    * TestCase.build_tree uses the transport interface to build trees, pass
 
463
      in a transport parameter to give it an existing connection.
 
464
      (Robert Collins).
 
465
 
 
466
  INTERNALS:
 
467
 
 
468
    * WorkingTree.pull has been split across Branch and WorkingTree,
 
469
      to allow Branch only pulls. (Robert Collins)
 
470
 
 
471
    * commands.display_command now returns the result of the decorated 
 
472
      function. (Robert Collins)
 
473
 
 
474
    * LocationConfig now has a set_user_option(key, value) call to save
 
475
      a setting in its matching location section (a new one is created
 
476
      if needed). (Robert Collins)
 
477
 
 
478
    * Branch has two new methods, get_push_location and set_push_location
 
479
      to respectively, get and set the push location. (Robert Collins)
 
480
 
 
481
    * commands.register_command now takes an optional flag to signal that
 
482
      the registrant is planning to decorate an existing command. When 
 
483
      given multiple plugins registering a command is not an error, and
 
484
      the original command class (whether built in or a plugin based one) is
 
485
      returned to the caller. There is a new error 'MustUseDecorated' for
 
486
      signalling when a wrapping command should switch to the original
 
487
      version. (Robert Collins)
 
488
 
 
489
    * Some option parsing errors will raise 'BzrOptionError', allowing 
 
490
      granular detection for decorating commands. (Robert Collins).
 
491
 
 
492
    * Branch.read_working_inventory has moved to
 
493
      WorkingTree.read_working_inventory. This necessitated changes to
 
494
      Branch.get_root_id, and a move of Branch.set_inventory to WorkingTree
 
495
      as well. To make it clear that a WorkingTree cannot always be obtained
 
496
      Branch.working_tree() will raise 'errors.NoWorkingTree' if one cannot
 
497
      be obtained. (Robert Collins)
 
498
 
 
499
    * All pending merges operations from Branch are now on WorkingTree.
 
500
      (Robert Collins)
 
501
 
 
502
    * The follow operations from Branch have moved to WorkingTree:
 
503
      add()
 
504
      commit()
 
505
      move()
 
506
      rename_one()
 
507
      unknowns()
 
508
      (Robert Collins)
 
509
 
 
510
    * bzrlib.add.smart_add_branch is now smart_add_tree. (Robert Collins)
 
511
 
 
512
    * New "rio" serialization format, similar to rfc-822. (Martin Pool)
 
513
 
 
514
    * Rename selftests to `bzrlib.tests.test_foo`.  (John A Meinel, Martin 
 
515
      Pool)
 
516
 
 
517
    * bzrlib.plugin.all_plugins has been changed from an attribute to a 
 
518
      query method. (Robert Collins)
 
519
 
 
520
    * New options to read only the table-of-contents of a weave.  
 
521
      (Denys Duchier)
 
522
 
 
523
    * Raise NoSuchFile when someone tries to add a non-existant file.
 
524
      (Michael Ellerman)
 
525
 
 
526
    * Simplify handling of DivergedBranches in cmd_pull().
 
527
      (Michael Ellerman)
 
528
                   
 
529
   
 
530
    * Branch.controlfile* logic has moved to lockablefiles.LockableFiles, which
 
531
      is exposed as Branch().control_files. Also this has been altered with the
 
532
      controlfile pre/suffix replaced by simple method names like 'get' and
 
533
      'put'. (Aaron Bentley, Robert Collins).
 
534
 
 
535
    * Deprecated functions and methods can now be marked as such using the 
 
536
      bzrlib.symbol_versioning module. Marked method have their docstring
 
537
      updated and will issue a DeprecationWarning using the warnings module
 
538
      when they are used. (Robert Collins)
 
539
 
 
540
    * bzrlib.osutils.safe_unicode now exists to provide parameter coercion
 
541
      for functions that need unicode strings. (Robert Collins)
 
542
 
 
543
bzr 0.6 2005-10-28
 
544
 
 
545
  IMPROVEMENTS:
 
546
  
 
547
    * pull now takes --verbose to show you what revisions are added or removed
 
548
      (John A Meinel)
 
549
 
 
550
    * merge now takes a --show-base option to include the base text in
 
551
      conflicts.
 
552
      (Aaron Bentley)
 
553
 
 
554
    * The config files are now read using ConfigObj, so '=' should be used as
 
555
      a separator, not ':'.
 
556
      (Aaron Bentley)
 
557
 
 
558
    * New 'bzr commit --strict' option refuses to commit if there are 
 
559
      any unknown files in the tree.  To commit, make sure all files are 
 
560
      either ignored, added, or deleted.  (Michael Ellerman)
 
561
 
 
562
    * The config directory is now ~/.bazaar, and there is a single file 
 
563
      ~/.bazaar/bazaar.conf storing email, editor and other preferences.
 
564
      (Robert Collins)
 
565
 
 
566
    * 'bzr add' no longer takes a --verbose option, and a --quiet option
 
567
      has been added that suppresses all output.
 
568
 
 
569
    * Improved zsh completion support in contrib/zsh, from Clint
 
570
      Adams.
 
571
 
 
572
    * Builtin 'bzr annotate' command, by Martin Pool with improvements from 
 
573
      Goffredo Baroncelli.
 
574
    
 
575
    * 'bzr check' now accepts -v for verbose reporting, and checks for
 
576
      ghosts in the branch. (Robert Collins)
 
577
 
 
578
    * New command 're-sign' which will regenerate the gpg signature for 
 
579
      a revision. (Robert Collins)
 
580
 
 
581
    * If you set check_signatures=require for a path in 
 
582
      ~/.bazaar/branches.conf then bzr will invoke your
 
583
      gpg_signing_command (defaults to gpg) and record a digital signature
 
584
      of your commit. (Robert Collins)
 
585
 
 
586
    * New sftp transport, based on Paramiko.  (Robey Pointer)
 
587
 
 
588
    * 'bzr pull' now accepts '--clobber' which will discard local changes
 
589
      and make this branch identical to the source branch. (Robert Collins)
 
590
 
 
591
    * Just give a quieter warning if a plugin can't be loaded, and 
 
592
      put the details in .bzr.log.  (Martin Pool)
 
593
 
 
594
    * 'bzr branch' will now set the branch-name to the last component of the
 
595
      output directory, if one was supplied.
 
596
 
 
597
    * If the option 'post_commit' is set to one (or more) python function
 
598
      names (must be in the bzrlib namespace), then they will be invoked
 
599
      after the commit has completed, with the branch and revision_id as
 
600
      parameters. (Robert Collins)
 
601
 
 
602
    * Merge now has a retcode of 1 when conflicts occur. (Robert Collins)
 
603
 
 
604
    * --merge-type weave is now supported for file contents.  Tree-shape
 
605
      changes are still three-way based.  (Martin Pool, Aaron Bentley)
 
606
 
 
607
    * 'bzr check' allows the first revision on revision-history to have
 
608
      parents - something that is expected for cheap checkouts, and occurs
 
609
      when conversions from baz do not have all history.  (Robert Collins).
 
610
 
 
611
   * 'bzr merge' can now graft unrelated trees together, if your specify
 
612
     0 as a base. (Aaron Bentley)
 
613
 
 
614
   * 'bzr commit branch' and 'bzr commit branch/file1 branch/file2' now work
 
615
     (Aaron Bentley)
 
616
 
 
617
    * Add '.sconsign*' to default ignore list.  (Alexander Belchenko)
 
618
 
 
619
   * 'bzr merge --reprocess' minimizes conflicts
 
620
 
 
621
  TESTING:
 
622
 
 
623
    * The 'bzr selftest --pattern' option for has been removed, now 
 
624
      test specifiers on the command line can be simple strings, or 
 
625
      regexps, or both. (Robert Collins)
 
626
 
 
627
    * Passing -v to selftest will now show the time each test took to 
 
628
      complete, which will aid in analysing performance regressions and
 
629
      related questions. (Robert Collins)
 
630
 
 
631
    * 'bzr selftest' runs all tests, even if one fails, unless '--one'
 
632
      is given. (Martin Pool)
 
633
 
 
634
    * There is a new method for TestCaseInTempDir, assertFileEqual, which
 
635
      will check that a given content is equal to the content of the named
 
636
      file. (Robert Collins)
 
637
 
 
638
    * Fix test suite's habit of leaving many temporary log files in $TMPDIR.
 
639
      (Martin Pool)
 
640
 
 
641
  INTERNALS:
 
642
 
 
643
    * New 'testament' command and concept for making gpg-signatures 
 
644
      of revisions that are not tied to a particular internal
 
645
      representation.  (Martin Pool).
 
646
 
 
647
    * Per-revision properties ('revprops') as key-value associated 
 
648
      strings on each revision created when the revision is committed.
 
649
      Intended mainly for the use of external tools.  (Martin Pool).
 
650
 
 
651
    * Config options have moved from bzrlib.osutils to bzrlib.config.
 
652
      (Robert Collins)
 
653
 
 
654
    * Improved command line option definitions allowing explanations
 
655
      for individual options, among other things.  Contributed by 
 
656
      Magnus Therning.
 
657
 
 
658
    * Config options have moved from bzrlib.osutils to bzrlib.config.
 
659
      Configuration is now done via the config.Config interface:
 
660
      Depending on whether you have a Branch, a Location or no information
 
661
      available, construct a *Config, and use its signature_checking,
 
662
      username and user_email methods. (Robert Collins)
 
663
 
 
664
    * Plugins are now loaded under bzrlib.plugins, not bzrlib.plugin, and
 
665
      they are made available for other plugins to use. You should not 
 
666
      import other plugins during the __init__ of your plugin though, as 
 
667
      no ordering is guaranteed, and the plugins directory is not on the
 
668
      python path. (Robert Collins)
 
669
 
 
670
    * Branch.relpath has been moved to WorkingTree.relpath. WorkingTree no
 
671
      no longer takes an inventory, rather it takes an option branch
 
672
      parameter, and if None is given will open the branch at basedir 
 
673
      implicitly. (Robert Collins)
 
674
 
 
675
    * Cleaner exception structure and error reporting.  Suggested by 
 
676
      Scott James Remnant.  (Martin Pool)
 
677
 
 
678
    * Branch.remove has been moved to WorkingTree, which has also gained
 
679
      lock_read, lock_write and unlock methods for convenience. (Robert
 
680
      Collins)
 
681
 
 
682
    * Two decorators, needs_read_lock and needs_write_lock have been added
 
683
      to the branch module. Use these to cause a function to run in a
 
684
      read or write lock respectively. (Robert Collins)
 
685
 
 
686
    * Branch.open_containing now returns a tuple (Branch, relative-path),
 
687
      which allows direct access to the common case of 'get me this file
 
688
      from its branch'. (Robert Collins)
 
689
 
 
690
    * Transports can register using register_lazy_transport, and they 
 
691
      will be loaded when first used.  (Martin Pool)
 
692
 
 
693
    * 'pull' has been factored out of the command as WorkingTree.pull().
 
694
      A new option to WorkingTree.pull has been added, clobber, which will
 
695
      ignore diverged history and pull anyway.
 
696
      (Robert Collins)
 
697
 
 
698
    * config.Config has a 'get_user_option' call that accepts an option name.
 
699
      This will be looked up in branches.conf and bazaar.conf as normal.
 
700
      It is intended that this be used by plugins to support options - 
 
701
      options of built in programs should have specific methods on the config.
 
702
      (Robert Collins)
 
703
 
 
704
    * merge.merge_inner now has tempdir as an optional parameter. (Robert
 
705
      Collins)
 
706
 
 
707
    * Tree.kind is not recorded at the top level of the hierarchy, as it was
 
708
      missing on EmptyTree, leading to a bug with merge on EmptyTrees.
 
709
      (Robert Collins)
 
710
 
 
711
    * WorkingTree.__del__ has been removed, it was non deterministic and not 
 
712
      doing what it was intended to. See WorkingTree.__init__ for a comment
 
713
      about future directions. (Robert Collins/Martin Pool)
 
714
 
 
715
    * bzrlib.transport.http has been modified so that only 404 urllib errors
 
716
      are returned as NoSuchFile. Other exceptions will propogate as normal.
 
717
      This allows debuging of actual errors. (Robert Collins)
 
718
 
 
719
    * bzrlib.transport.Transport now accepts *ONLY* url escaped relative paths
 
720
      to apis like 'put', 'get' and 'has'. This is to provide consistent
 
721
      behaviour - it operates on url's only. (Robert Collins)
 
722
 
 
723
    * Transports can register using register_lazy_transport, and they 
 
724
      will be loaded when first used.  (Martin Pool)
 
725
 
 
726
    * 'merge_flex' no longer calls conflict_handler.finalize(), instead that
 
727
      is called by merge_inner. This is so that the conflict count can be 
 
728
      retrieved (and potentially manipulated) before returning to the caller
 
729
      of merge_inner. Likewise 'merge' now returns the conflict count to the
 
730
      caller. (Robert Collins)
 
731
 
 
732
    * 'revision.revision_graph can handle having only partial history for
 
733
      a revision - that is no revisions in the graph with no parents.
 
734
      (Robert Collins).
 
735
 
 
736
    * New builtins.branch_files uses the standard file_list rules to produce
 
737
      a branch and a list of paths, relative to that branch (Aaron Bentley)
 
738
 
 
739
    * New TestCase.addCleanup facility.
 
740
 
 
741
    * New bzrlib.version_info tuple (similar to sys.version_info), which can
 
742
      be used by programs importing bzrlib.
 
743
 
 
744
  BUG FIXES:
 
745
 
 
746
    * Better handling of branches in directories with non-ascii names. 
 
747
      (Joel Rosdahl, Panagiotis Papadakos)
 
748
 
 
749
    * Upgrades of trees with no commits will not fail due to accessing
 
750
      [-1] in the revision-history. (Andres Salomon)
 
751
 
 
752
 
 
753
bzr 0.1.1 2005-10-12
 
754
 
 
755
  BUG FIXES:
 
756
 
 
757
    * Fix problem in pulling over http from machines that do not 
 
758
      allow directories to be listed.
 
759
 
 
760
    * Avoid harmless warning about invalid hash cache after 
 
761
      upgrading branch format.
 
762
 
 
763
  PERFORMANCE: 
 
764
  
 
765
    * Avoid some unnecessary http operations in branch and pull.
 
766
 
 
767
 
 
768
bzr 0.1 2005-10-11
 
769
 
 
770
  NOTES:
 
771
 
 
772
    * 'bzr branch' over http initially gives a very high estimate
 
773
      of completion time but it should fall as the first few 
 
774
      revisions are pulled in.  branch is still slow on 
 
775
      high-latency connections.
 
776
 
 
777
  BUG FIXES:
 
778
  
 
779
    * bzr-man.py has been updated to work again. Contributed by
 
780
      Rob Weir.
 
781
 
 
782
    * Locking is now done with fcntl.lockf which works with NFS
 
783
      file systems. Contributed by Harald Meland.
 
784
 
 
785
    * When a merge encounters a file that has been deleted on
 
786
      one side and modified on the other, the old contents are
 
787
      written out to foo.BASE and foo.SIDE, where SIDE is this
 
788
      or OTHER. Contributed by Aaron Bentley.
 
789
 
 
790
    * Export was choosing incorrect file paths for the content of
 
791
      the tarball, this has been fixed by Aaron Bentley.
 
792
 
 
793
    * Commit will no longer commit without a log message, an 
 
794
      error is returned instead. Contributed by Jelmer Vernooij.
 
795
 
 
796
    * If you commit a specific file in a sub directory, any of its
 
797
      parent directories that are added but not listed will be 
 
798
      automatically included. Suggested by Michael Ellerman.
 
799
 
 
800
    * bzr commit and upgrade did not correctly record new revisions
 
801
      for files with only a change to their executable status.
 
802
      bzr will correct this when it encounters it. Fixed by
 
803
      Robert Collins
 
804
 
 
805
    * HTTP tests now force off the use of http_proxy for the duration.
 
806
      Contributed by Gustavo Niemeyer.
 
807
 
 
808
    * Fix problems in merging weave-based branches that have 
 
809
      different partial views of history.
 
810
 
 
811
    * Symlink support: working with symlinks when not in the root of a 
 
812
      bzr tree was broken, patch from Scott James Remnant.
 
813
 
 
814
 
 
815
  IMPROVEMENTS:
 
816
 
 
817
    * 'branch' now accepts a --basis parameter which will take advantage
 
818
      of local history when making a new branch. This allows faster 
 
819
      branching of remote branches. Contributed by Aaron Bentley.
 
820
 
 
821
    * New tree format based on weave files, called version 5.
 
822
      Existing branches can be upgraded to this format using 
 
823
      'bzr upgrade'.
 
824
 
 
825
    * Symlinks are now versionable. Initial patch by 
 
826
      Erik Toubro Nielsen, updated to head by Robert Collins.
 
827
 
 
828
    * Executable bits are tracked on files. Patch from Gustavo
 
829
      Niemeyer.
 
830
 
 
831
    * 'bzr status' now shows unknown files inside a selected directory.
 
832
      Patch from Heikki Paajanen.
 
833
 
 
834
    * Merge conflicts are recorded in .bzr. Two new commands 'conflicts'
 
835
      and 'resolve' have needed added, which list and remove those 
 
836
      merge conflicts respectively. A conflicted tree cannot be committed
 
837
      in. Contributed by Aaron Bentley.
 
838
 
 
839
    * 'rm' is now an alias for 'remove'.
 
840
 
 
841
    * Stores now split out their content in a single byte prefixed hash,
 
842
      dropping the density of files per directory by 256. Contributed by
 
843
      Gustavo Niemeyer.
 
844
 
 
845
    * 'bzr diff -r branch:URL' will now perform a diff between two branches.
 
846
      Contributed by Robert Collins.
 
847
 
 
848
    * 'bzr log' with the default formatter will show merged revisions,
 
849
      indented to the right. Initial implementation contributed by Gustavo
 
850
      Niemeyer, made incremental by Robert Collins.
 
851
 
 
852
 
 
853
  INTERNALS:
 
854
 
 
855
    * Test case failures have the exception printed after the log 
 
856
      for your viewing pleasure.
 
857
 
 
858
    * InventoryEntry is now an abstract base class, use one of the
 
859
      concrete InventoryDirectory etc classes instead.
 
860
 
 
861
    * Branch raises an UnsupportedFormatError when it detects a 
 
862
      bzr branch it cannot understand. This allows for precise
 
863
      handling of such circumstances.
 
864
 
 
865
 
 
866
  TESTING:
 
867
 
 
868
    * Removed testsweet module so that tests can be run after 
 
869
      bzr installed by 'bzr selftest'.
 
870
 
 
871
    * 'bzr selftest' command-line arguments can now be partial ids
 
872
      of tests to run, e.g. 'bzr selftest test_weave'
 
873
 
 
874
      
 
875
bzr 0.0.9 2005-09-23
 
876
 
 
877
  BUG FIXES:
 
878
 
 
879
    * Fixed "branch -r" option.
 
880
 
 
881
    * Fix remote access to branches containing non-compressed history.
 
882
      (Robert Collins).
 
883
 
 
884
    * Better reliability of http server tests.  (John Arbash-Meinel)
 
885
 
 
886
    * Merge graph maximum distance calculation fix.  (Aaron Bentley)
 
887
   
 
888
    * Various minor bug in windows support have been fixed, largely in the
 
889
      test suite. Contributed by Alexander Belchenko.
 
890
 
 
891
  IMPROVEMENTS:
 
892
 
 
893
    * Status now accepts a -r argument to give status between chosen
 
894
      revisions. Contributed by Heikki Paajanen.
 
895
 
 
896
    * Revision arguments no longer use +/-/= to control ranges, instead
 
897
      there is a 'before' namespace, which limits the successive namespace.
 
898
      For example '$ bzr log -r date:yesterday..before:date:today' will
 
899
      select everything from yesterday and before today. Contributed by
 
900
      Robey Pointer
 
901
 
 
902
    * There is now a bzr.bat file created by distutils when building on 
 
903
      Windows. Contributed by Alexander Belchenko.
 
904
 
 
905
  INTERNALS:
 
906
 
 
907
    * Removed uuid() as it was unused.
 
908
 
 
909
    * Improved 'fetch' code for pulling revisions from one branch into
 
910
      another (used by pull, merged, etc.)
 
911
 
 
912
 
 
913
bzr 0.0.8 2005-09-20
 
914
 
 
915
  IMPROVEMENTS:
 
916
 
 
917
    * Adding a file whose parent directory is not versioned will
 
918
      implicitly add the parent, and so on up to the root. This means
 
919
      you should never need to explictly add a directory, they'll just
 
920
      get added when you add a file in the directory.  Contributed by
 
921
      Michael Ellerman.
 
922
 
 
923
    * Ignore .DS_Store (contains Mac metadata) by default.  Patch from
 
924
      Nir Soffer.
 
925
 
 
926
    * If you set BZR_EDITOR in the environment, it is checked in
 
927
      preference to EDITOR and the config file for the interactive commit
 
928
      editing program. Related to this is a bugfix where a missing program
 
929
      set in EDITOR would cause editing to fail, now the fallback program
 
930
      for the operating system is still tried.
 
931
 
 
932
    * Files that are not directories/symlinks/regular files will no longer
 
933
      cause bzr to fail, it will just ignore them by default. You cannot add
 
934
      them to the tree though - they are not versionable.
 
935
 
 
936
 
 
937
  INTERNALS:
 
938
 
 
939
    * Refactor xml packing/unpacking.
 
940
 
 
941
  BUG FIXES: 
 
942
 
 
943
    * Fixed 'bzr mv' by Ollie Rutherfurd.
 
944
 
 
945
    * Fixed strange error when trying to access a nonexistent http
 
946
      branch.
 
947
 
 
948
    * Make sure that the hashcache gets written out if it can't be
 
949
      read.
 
950
 
 
951
 
 
952
  PORTABILITY:
 
953
 
 
954
    * Various Windows fixes from Ollie Rutherfurd.
 
955
 
 
956
    * Quieten warnings about locking; patch from Matt Lavin.
 
957
 
 
958
 
 
959
bzr-0.0.7 2005-09-02
 
960
 
 
961
  NEW FEATURES:
 
962
 
 
963
    * ``bzr shell-complete`` command contributed by Clint Adams to
 
964
      help with intelligent shell completion.
 
965
 
 
966
    * New expert command ``bzr find-merge-base`` for debugging merges.
 
967
 
 
968
 
 
969
  ENHANCEMENTS:
 
970
 
 
971
    * Much better merge support.
 
972
 
 
973
    * merge3 conflicts are now reported with markers like '<<<<<<<'
 
974
      (seven characters) which is the same as CVS and pleases things
 
975
      like emacs smerge.
 
976
 
 
977
 
 
978
  BUG FIXES:
 
979
 
 
980
    * ``bzr upgrade`` no longer fails when trying to fix trees that
 
981
      mention revisions that are not present.
 
982
 
 
983
    * Fixed bugs in listing plugins from ``bzr plugins``.
 
984
 
 
985
    * Fix case of $EDITOR containing options for the editor.
 
986
 
 
987
    * Fix log -r refusing to show the last revision.
 
988
      (Patch from Goffredo Baroncelli.)
 
989
 
 
990
 
 
991
  CHANGES:
 
992
 
 
993
    * ``bzr log --show-ids`` shows the revision ids of all parents.
 
994
 
 
995
    * Externally provided commands on your $BZRPATH no longer need
 
996
      to recognize --bzr-usage to work properly, and can just handle
 
997
      --help themselves.
 
998
 
 
999
 
 
1000
  LIBRARY:
 
1001
 
 
1002
    * Changed trace messages to go through the standard logging
 
1003
      framework, so that they can more easily be redirected by
 
1004
      libraries.
 
1005
 
 
1006
 
 
1007
 
 
1008
bzr-0.0.6 2005-08-18
2
1009
 
3
1010
  NEW FEATURES:
4
1011
 
14
1021
      FOO.
15
1022
      
16
1023
    * ``bzr add`` with no arguments adds everything under the current directory.
17
 
    
 
1024
 
 
1025
    * ``bzr mv`` does move or rename depending on its arguments, like
 
1026
      the Unix command.
 
1027
 
 
1028
    * ``bzr missing`` command shows a summary of the differences
 
1029
      between two trees.  (Merged from John Arbash-Meinel.)
 
1030
 
 
1031
    * An email address for commits to a particular tree can be
 
1032
      specified by putting it into .bzr/email within a branch.  (Based
 
1033
      on a patch from Heikki Paajanen.)
 
1034
 
 
1035
 
18
1036
  ENHANCEMENTS:
19
1037
 
20
1038
    * Faster working tree operations.
21
1039
 
 
1040
 
22
1041
  CHANGES:
23
1042
 
 
1043
    * 3rd-party modules shipped with bzr are copied within the bzrlib
 
1044
      python package, so that they can be installed by the setup
 
1045
      script without clashing with anything already existing on the
 
1046
      system.  (Contributed by Gustavo Niemeyer.)
 
1047
 
 
1048
    * Moved plugins directory to bzrlib/, so that there's a standard
 
1049
      plugin directory which is not only installed with bzr itself but
 
1050
      is also available when using bzr from the development tree.
 
1051
      BZR_PLUGIN_PATH and DEFAULT_PLUGIN_PATH are then added to the
 
1052
      standard plugins directory.
 
1053
 
24
1054
    * When exporting to a tarball with ``bzr export --format tgz``, put 
25
1055
      everything under a top directory rather than dumping it into the
26
1056
      current directory.   This can be overridden with the ``--root`` 
39
1069
    * By default the commit command refuses to record a revision with
40
1070
      no changes unless the ``--unchanged`` option is given.
41
1071
 
 
1072
    * The ``--no-plugins``, ``--profile`` and ``--builtin`` command
 
1073
      line options must come before the command name because they 
 
1074
      affect what commands are available; all other options must come 
 
1075
      after the command name because their interpretation depends on
 
1076
      it.
 
1077
 
 
1078
    * ``branch`` and ``clone`` added as aliases for ``branch``.
 
1079
 
 
1080
    * Default log format is back to the long format; the compact one
 
1081
      is available with ``--short``.
 
1082
      
 
1083
      
 
1084
  BUG FIXES:
 
1085
  
 
1086
    * Fix bugs in committing only selected files or within a subdirectory.
 
1087
 
42
1088
 
43
1089
bzr-0.0.5  2005-06-15
44
1090