~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to NEWS

  • Committer: Robert Collins
  • Date: 2007-03-08 04:06:06 UTC
  • mfrom: (2323.1.1 integration)
  • mto: This revision was merged to the branch mainline in revision 2442.
  • Revision ID: robertc@robertcollins.net-20070308040606-84gsniv56huiyjt4
Merge bzr.dev.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
IN DEVELOPMENT
2
 
 
3
 
  IMPROVEMENTS:
 
2
 
 
3
bzr 0.15rc1  2007-03-07
 
4
 
 
5
  SURPRISES:
 
6
 
 
7
    * The default disk format has changed. Please run 'bzr upgrade' in your
 
8
      working trees to upgrade. This new default is compatible for network
 
9
      operations, but not for local operations. That is, if you have two
 
10
      versions of bzr installed locally, after upgrading you can only use the
 
11
      bzr 0.15 version. This new default does not enable tags or nested-trees
 
12
      as they are incompatible with bzr versions before 0.15 over the network.
 
13
 
 
14
    * For users of bzrlib: Two major changes have been made to the working tree
 
15
      api in bzrlib. The first is that many methods and attributes, including
 
16
      the inventory attribute, are no longer valid for use until one of
 
17
      lock_read/lock_write/lock_tree_write has been called, and become invalid
 
18
      again after unlock is called. This has been done to improve performance
 
19
      and correctness as part of the dirstate development. (Robert Collins,
 
20
      John A Meinel, Martin Pool, and others).
 
21
 
 
22
    * For users of bzrlib: The attribute 'tree.inventory' should be considered
 
23
      readonly. Previously it was possible to directly alter this attribute, or
 
24
      its contents, and have the tree notice this. This has been made
 
25
      unsupported - it may work in some tree formats, but in the newer dirstate
 
26
      format such actions will have no effect and will be ignored, or even
 
27
      cause assertions. All operations possible can still be carried out by a
 
28
      combination of the tree API, and the bzrlib.transform API. (Robert
 
29
      Collins, John A Meinel, Martin Pool, and others).
 
30
 
 
31
  IMPROVEMENTS:
 
32
 
 
33
    * Support for OS Windows 98. Also .bzr.log on any windows system
 
34
      saved in My Documents folder. (Alexander Belchenko)
 
35
 
 
36
    * ``bzr mv`` enhanced to support already moved files.
 
37
      In the past the mv command would have failed if the source file doesn't
 
38
      exist. In this situation ``bzr mv`` would now detect that the file has
 
39
      already moved and update the repository accordingly, if the target file
 
40
      does exist.
 
41
      A new option ``--after`` has been added so that if two files already
 
42
      exist, you could notify Bazaar that you have moved a (versioned) file
 
43
      and replaced it with another. Thus in this case ``bzr move --after``
 
44
      will only update the Bazaar identifier.
 
45
      (Steffen Eichenberg, Marius Kruger)
 
46
 
 
47
    * ``ls`` now works on treeless branches and remote branches.
 
48
      (Aaron Bentley)
 
49
 
 
50
    * ``bzr help global-options`` describes the global options.
 
51
      (Aaron Bentley)
 
52
 
 
53
    * ``bzr pull --overwrite`` will now correctly overwrite checkouts.
 
54
      (Robert Collins)
 
55
 
 
56
    * Files are now allowed to change kind (e.g. from file to symlink).
 
57
      Supported by ``commit``, ``revert`` and ``status``
 
58
      (Aaron Bentley)
 
59
 
 
60
    * ``inventory`` and ``unknowns`` hidden in favour of ``ls``
 
61
      (Aaron Bentley)
 
62
 
 
63
    * ``bzr help checkouts`` descibes what checkouts are and some possible
 
64
      uses of them. (James Westby, Aaron Bentley)
 
65
 
 
66
    * A new ``-d`` option to push, pull and merge overrides the default 
 
67
      directory.  (Martin Pool)
 
68
 
 
69
    * Branch format 6: smaller, and potentially faster than format 5.  Supports
 
70
      "append_history_only" mode, where the log view and revnos do not change,
 
71
      except by being added to.  Stores policy settings in
 
72
      ".bzr/branch/branch.conf".
 
73
 
 
74
    * append_only branches:  Format 6 branches may be configured so that log
 
75
      view and revnos are always consistent.  Either create the branch using
 
76
      "bzr init --append-revisions-only" or edit the config file as descriped
 
77
      in docs/configuration.txt.
 
78
 
 
79
    * rebind: Format 6 branches retain the last-used bind location, so if you
 
80
      "bzr unbind", you can "bzr bind" to bind to the previously-selected
 
81
      bind location.
 
82
 
 
83
    * Builtin tags support, created and deleted by the ``tag`` command and
 
84
      stored in the branch.  Tags can be accessed with the revisionspec
 
85
      ``-rtag:``, and listed with ``bzr tags``.  Tags are not versioned 
 
86
      at present. Tags require a network incompatible upgrade. To perform this
 
87
      upgrade, run ``bzr upgrade --dirstate-with-subtree`` in your branch and
 
88
      repositories. (Martin Pool)
 
89
 
 
90
    * The bzr:// transport now has a well-known port number, 4155, which it will
 
91
      use by default.  (Andrew Bennetts, Martin Pool)
 
92
 
 
93
    * Bazaar now looks for user-installed plugins before looking for site-wide
 
94
      plugins. (Jonathan Lange)
 
95
 
 
96
    * ``bzr resolve`` now detects and marks resolved text conflicts.
 
97
      (Aaron Bentley)
 
98
 
 
99
    * There is now initial support for managing a forest of trees in bzr,
 
100
      and splitting up existing trees into smaller subtrees, and finally
 
101
      joining trees to make a larger tree. This is the first iteration
 
102
      of this support. To enable the new ``join`` and ``split`` commands,
 
103
      please run ``bzr upgrade --dirstate-with-subtree`` in your working
 
104
      trees and repositories. (Aaron Bentley, Martin Pool, Robert Collins).
 
105
 
 
106
  INTERNALS:
 
107
 
 
108
    * Internally revision ids and file ids are now passed around as utf-8
 
109
      bytestrings, rather than treating them as Unicode strings. This has
 
110
      performance benefits for Knits, since we no longer need to decode the
 
111
      revision id for each line of content, nor for each entry in the index.
 
112
      This will also help with the future dirstate format.
 
113
      (John Arbash Meinel)
 
114
 
 
115
    * Reserved ids (any revision-id ending in a colon) are rejected by
 
116
      versionedfiles, repositories, branches, and working trees
 
117
      (Aaron Bentley)
 
118
 
 
119
    * Minor performance improvement by not creating a ProgressBar for
 
120
      every KnitIndex we create. (about 90ms for a bzr.dev tree)
 
121
      (John Arbash Meinel)
 
122
 
 
123
    * New easier to use Branch hooks facility. There are five initial hooks,
 
124
      all documented in bzrlib.branch.BranchHooks.__init__ - 'set_rh',
 
125
      'post_push', 'post_pull', 'post_commit', 'post_uncommit'. These hooks
 
126
      fire after the matching operation on a branch has taken place, and were
 
127
      originally added for the branchrss plugin. (Robert Collins)
 
128
 
 
129
    * New method ``Branch.push()`` which should be used when pushing from a
 
130
      branch as it makes performance and policy decisions to match the UI
 
131
      level command ``push``. (Robert Collins).
 
132
 
 
133
    * Add a new method ``Tree.revision_tree`` which allows access to cached
 
134
      trees for arbitrary revisions. This allows the in development dirstate
 
135
      tree format to provide access to the callers to cached copies of 
 
136
      inventory data which are cheaper to access than inventories from the
 
137
      repository.
 
138
      (Robert Collins, Martin Pool)
 
139
 
 
140
    * New Branch.last_revision_info method, this is being done to allow
 
141
      optimization of requests for both the number of revisions and the last
 
142
      revision of a branch with smartservers and potentially future branch
 
143
      formats. (Wouter van Heyst, Robert Collins)
 
144
 
 
145
    * Allow 'import bzrlib.plugins.NAME' to work when the plugin NAME has not
 
146
      yet been loaded by load_plugins(). This allows plugins to depend on each
 
147
      other for code reuse without requiring users to perform file-renaming
 
148
      gymnastics. (Robert Collins)
 
149
 
 
150
    * New Repository method 'gather_stats' for statistic data collection.
 
151
      This is expected to grow to cover a number of related uses mainly
 
152
      related to bzr info. (Robert Collins)
 
153
 
 
154
    * Log formatters are now managed with a registry.
 
155
      ``log.register_formatter`` continues to work, but callers accessing
 
156
      the FORMATTERS dictionary directly will not.
 
157
 
 
158
    * Allow a start message to be passed to the ``edit_commit_message``
 
159
      function.  This will be placed in the message offered to the user
 
160
      for editing above the separator. It allows a template commit message
 
161
      to be used more easily. (James Westby)
 
162
 
 
163
    * ``GPGStrategy.sign()`` will now raise ``BzrBadParameterUnicode`` if
 
164
      you pass a Unicode string rather than an 8-bit string. Callers need
 
165
      to be updated to encode first. (John Arbash Meinel)
 
166
 
 
167
    * Branch.push, pull, merge now return Result objects with information
 
168
      about what happened, rather than a scattering of various methods.  These
 
169
      are also passed to the post hooks.  (Martin Pool)
 
170
 
 
171
  BUGFIXES:
 
172
 
 
173
    * ``bzr annotate`` now uses dotted revnos from the viewpoint of the
 
174
      branch, rather than the last changed revision of the file.
 
175
      (John Arbash Meinel, #82158)
 
176
 
 
177
    * Lock operations no longer hang if they encounter a permission problem.
 
178
      (Aaron Bentley)
 
179
 
 
180
    * ``bzr push`` can resume a push that was canceled before it finished.
 
181
      Also, it can push even if the target directory exists if you supply
 
182
      the ``--use-existing-dir`` flag.
 
183
      (John Arbash Meinel, #30576, #45504)
 
184
 
 
185
    * Fix http proxy authentication when user and an optional
 
186
      password appears in the ``*_proxy`` vars. (Vincent Ladeuil,
 
187
      #83954).
 
188
 
 
189
    * ``bzr log branch/file`` works for local treeless branches
 
190
      (Aaron Bentley, #84247)
 
191
 
 
192
    * Fix problem with UNC paths on Windows 98. (Alexander Belchenko, #84728)
 
193
 
 
194
    * Searching location of CA bundle for PyCurl in env variable (CURL_CA_BUNDLE),
 
195
      and on win32 along the PATH. (Alexander Belchenko, #82086)
 
196
 
 
197
    * ``bzr init`` works with unicode argument LOCATION.
 
198
      (Alexander Belchenko, #85599)
 
199
 
 
200
    * Raise DependencyNotPresent if pycurl do not support https. (Vincent
 
201
      Ladeuil, #85305)
 
202
 
 
203
    * Invalid proxy env variables should not cause a traceback.
 
204
      (Vincent Ladeuil, #87765)
 
205
 
 
206
    * Ignore patterns normalised to use '/' path separator.
 
207
      (Kent Gibson, #86451)
 
208
 
 
209
  TESTING:
 
210
 
 
211
    * New ``--first`` option to ``bzr selftest`` to run specified tests
 
212
      before the rest of the suite.  (Martin Pool)
 
213
 
 
214
 
 
215
    * Fix bzrtools shelve command for removed lines beginning with "--"
 
216
      (Johan Dahlberg, #75577)
 
217
 
 
218
bzr 0.14  2007-01-23
 
219
 
 
220
  IMPROVEMENTS:
 
221
 
 
222
    * ``bzr help global-options`` describes the global options. (Aaron Bentley)
 
223
 
 
224
  BUG FIXES:
 
225
    
 
226
    * Skip documentation generation tests if the tools to do so are not
 
227
      available. Fixes running selftest for installled copies of bzr. 
 
228
      (John Arbash Meinel, #80330)
 
229
 
 
230
    * Fix the code that discovers whether bzr is being run from it's
 
231
      working tree to handle the case when it isn't but the directory
 
232
      it is in is below a repository. (James Westby, #77306)
 
233
 
 
234
 
 
235
bzr 0.14rc1  2007-01-16
 
236
 
 
237
  IMPROVEMENTS:
 
238
 
 
239
    * New connection: ``bzr+http://`` which supports tunnelling the smart
 
240
      protocol over an HTTP connection. If writing is enabled on the bzr
 
241
      server, then you can write over the http connection.
 
242
      (Andrew Bennetts, John Arbash Meinel)
 
243
 
 
244
    * Aliases now support quotation marks, so they can contain whitespace
 
245
      (Marius Kruger)
 
246
 
 
247
    * PyCurlTransport now use a single curl object. By specifying explicitly
 
248
      the 'Range' header, we avoid the need to use two different curl objects
 
249
      (and two connections to the same server). (Vincent Ladeuil)
 
250
 
 
251
    * ``bzr commit`` does not prompt for a message until it is very likely to
 
252
      succeed.  (Aaron Bentley)
 
253
 
 
254
    * ``bzr conflicts`` now takes --text to list pathnames of text conflicts
 
255
      (Aaron Bentley)
 
256
 
 
257
    * Fix ``iter_lines_added_or_present_in_versions`` to use a set instead
 
258
      of a list while checking if a revision id was requested. Takes 10s
 
259
      off of the ``fileids_affected_by_revision_ids`` time, which is 10s
 
260
      of the ``bzr branch`` time. Also improve ``fileids_...`` time by
 
261
      filtering lines with a regex rather than multiple ``str.find()``
 
262
      calls. (saves another 300ms) (John Arbash Meinel)
 
263
 
 
264
    * Policy can be set for each configuration key. This allows keys to be
 
265
      inherited properly across configuration entries. For example, this
 
266
      should enable you to do::
 
267
        
 
268
        [/home/user/project]
 
269
        push_location = sftp://host/srv/project/
 
270
        push_location:policy = appendpath
 
271
 
 
272
      And then a branch like ``/home/user/project/mybranch`` should get an
 
273
      automatic push location of ``sftp://host/srv/project/mybranch``.
 
274
      (James Henstridge)
 
275
 
 
276
    * Added ``bzr status --short`` to make status report svn style flags
 
277
      for each file.  For example::
 
278
 
 
279
        $ bzr status --short
 
280
        A  foo
 
281
        A  bar
 
282
        D  baz
 
283
        ?  wooley
 
284
 
 
285
    * 'bzr selftest --clean-output' allows easily clean temporary tests 
 
286
      directories without running tests. (Alexander Belchenko)
 
287
 
 
288
    * ``bzr help hidden-commands`` lists all hidden commands. (Aaron Bentley)
 
289
 
 
290
    * ``bzr merge`` now has an option ``--pull`` to fall back to pull if
 
291
      local is fully merged into remote. (Jan Hudec)
 
292
 
 
293
    * ``bzr help formats`` describes available directory formats. (Aaron Bentley)
 
294
 
 
295
  INTERNALS:
 
296
 
 
297
    * A few tweaks directly to ``fileids_affected_by_revision_ids`` to
 
298
      help speed up processing, as well allowing to extract unannotated
 
299
      lines. Between the two ``fileids_affected_by_revision_ids`` is
 
300
      improved by approx 10%. (John Arbash Meinel)
 
301
 
 
302
    * Change Revision serialization to only write out millisecond
 
303
      resolution. Rather than expecting floating point serialization to
 
304
      preserve more resolution than we need. (Henri Weichers, Martin Pool)
 
305
 
 
306
    * Test suite ends cleanly on Windows.  (Vincent Ladeuil)
 
307
 
 
308
    * When 'encoding_type' attribute of class Command is equal to 'exact', 
 
309
      force sys.stdout to be a binary stream on Windows, and therefore
 
310
      keep exact line-endings (without LF -> CRLF conversion).
 
311
      (Alexander Belchenko)
 
312
 
 
313
    * Single-letter short options are no longer globally declared.  (Martin
 
314
      Pool)
 
315
 
 
316
    * Before using detected user/terminal encoding bzr should check
 
317
      that Python has corresponding codec. (Alexander Belchenko)
 
318
 
 
319
    * Formats for end-user selection are provided via a FormatRegistry (Aaron Bentley)
 
320
 
 
321
  BUG FIXES:
 
322
 
 
323
    * ``bzr missing --verbose`` was showing adds/removals in the wrong
 
324
      direction. (John Arbash Meinel)
 
325
 
 
326
    * ``bzr annotate`` now defaults to showing dotted revnos for merged
 
327
      revisions. It cuts them off at a depth of 12 characters, but you can
 
328
      supply ``--long`` to see the full number. You can also use
 
329
      ``--show-ids`` to display the original revision ids, rather than
 
330
      revision numbers and committer names. (John Arbash Meinel, #75637)
 
331
 
 
332
    * bzr now supports Win32 UNC path (e.g. \\HOST\path). 
 
333
      (Alexander Belchenko, #57869)
 
334
 
 
335
    * Win32-specific: output of cat, bundle and diff commands don't mangle
 
336
      line-endings (Alexander Belchenko, #55276)
 
337
 
 
338
    * Replace broken fnmatch based ignore pattern matching with custom pattern
 
339
      matcher.
 
340
      (Kent Gibson, Jan Hudec #57637)
 
341
 
 
342
    * pycurl and urllib can detect short reads at different places. Update
 
343
      the test suite to test more cases. Also detect http error code 416
 
344
      which was raised for that specific bug. Also enhance the urllib
 
345
      robustness by detecting invalid ranges (and pycurl's one by detecting
 
346
      short reads during the initial GET). (Vincent Ladeuil, #73948)
 
347
 
 
348
    * The urllib connection sharing interacts badly with urllib2
 
349
      proxy setting (the connections didn't go thru the proxy
 
350
      anymore). Defining a proper ProxyHandler solves the
 
351
      problem.  (Vincent Ladeuil, #74759)
 
352
 
 
353
    * Use urlutils to generate relative URLs, not osutils 
 
354
      (Aaron Bentley, #76229)
 
355
 
 
356
    * ``bzr status`` in a readonly directory should work without giving
 
357
      lots of errors. (John Arbash Meinel, #76299)
 
358
 
 
359
    * Mention the revisionspec topic for the revision option help.
 
360
      (Wouter van Heyst, #31663)
 
361
 
 
362
    * Allow plugins import from zip archives.
 
363
      (Alexander Belchenko, #68124)
 
364
 
 
365
    * bzr rocks. It sure does! Fix case. (Vincent Ladeuil, #78026)
 
366
 
 
367
 
 
368
bzr 0.13  2006-12-05
 
369
    
 
370
  No changes from 0.13rc1
 
371
    
 
372
bzr 0.13rc1  2006-11-27
 
373
 
 
374
  IMPROVEMENTS:
 
375
 
 
376
    * New command ``bzr remove-tree`` allows the removal of the working
 
377
      tree from a branch.
 
378
      (Daniel Silverstone)
 
379
 
 
380
    * urllib uses shared keep-alive connections, so http 
 
381
      operations are substantially faster.
 
382
      (Vincent Ladeuil, #53654)
 
383
 
 
384
    * ``bzr export`` allows an optional branch parameter, to export a bzr
 
385
      tree from some other url. For example:
 
386
      ``bzr export bzr.tar.gz http://bazaar-vcs.org/bzr/bzr.dev``
 
387
      (Daniel Silverstone)
 
388
 
 
389
    * Added ``bzr help topics`` to the bzr help system. This gives a
 
390
      location for general information, outside of a specific command.
 
391
      This includes updates for ``bzr help revisionspec`` the first topic
 
392
      included. (Goffredo Baroncelli, John Arbash Meinel, #42714)
 
393
 
 
394
    * WSGI-compatible HTTP smart server.  See ``doc/http_smart_server.txt``.
 
395
      (Andrew Bennetts)
 
396
 
 
397
    * Knit files will now cache full texts only when the size of the
 
398
      deltas is as large as the size of the fulltext. (Or after 200
 
399
      deltas, whichever comes first). This has the most benefit on large
 
400
      files with small changes, such as the inventory for a large project.
 
401
      (eg For a project with 2500 files, and 7500 revisions, it changes
 
402
      the size of inventory.knit from 11MB to 5.4MB) (John Arbash Meinel)
 
403
 
 
404
  INTERNALS:
 
405
 
 
406
    * New -D option given before the command line turns on debugging output
 
407
      for particular areas.  -Derror shows tracebacks on all errors.
 
408
      (Martin Pool)
 
409
 
 
410
    * Clean up ``bzr selftest --benchmark bundle`` to correct an import,
 
411
      and remove benchmarks that take longer than 10min to run.
 
412
      (John Arbash Meinel)
 
413
 
 
414
    * Use ``time.time()`` instead of ``time.clock()`` to decide on
 
415
      progress throttling. Because ``time.clock()`` is actually CPU time,
 
416
      so over a high-latency connection, too many updates get throttled.
 
417
      (John Arbash Meinel)
 
418
 
 
419
    * ``MemoryTransport.list_dir()`` would strip the first character for
 
420
      files or directories in root directory. (John Arbash Meinel)
 
421
  
 
422
    * New ``ChrootTransportDecorator``, accessible via the ``chroot+`` url
 
423
      prefix.  It disallows any access to locations above a set URL.  (Andrew
 
424
      Bennetts)
 
425
 
 
426
  BUG FIXES:
 
427
 
 
428
    * Now _KnitIndex properly decode revision ids when loading index data.
 
429
      And optimize the knit index parsing code.  (Dmitry Vasiliev, John
 
430
      Arbash Meinel)
 
431
 
 
432
    * ``bzrlib/bzrdir.py`` was directly referencing ``bzrlib.workingtree``,
 
433
      without importing it. This prevented ``bzr upgrade`` from working
 
434
      unless a plugin already imported ``bzrlib.workingtree``
 
435
      (John Arbash Meinel, #70716)
 
436
 
 
437
    * Suppress the traceback on invalid URLs (Vincent Ladeuil, #70803).
 
438
 
 
439
    * Give nicer error message when an http server returns a 403
 
440
      error code. (Vincent Ladeuil, #57644).
 
441
 
 
442
    * When a multi-range http GET request fails, try a single
 
443
      range one. If it fails too, forget about ranges. Remember that until 
 
444
      the death of the transport and propagates that to the clones.
 
445
      (Vincent Ladeuil, #62276, #62029).
 
446
 
 
447
    * Handles user/passwords supplied in url from command
 
448
      line (for the urllib implementation). Don't request already
 
449
      known passwords (Vincent Ladeuil, #42383, #44647, #48527)
 
450
 
 
451
    * _KnitIndex.add_versions() dictionary compresses revision ids as they
 
452
      are added. This fixes bug where fetching remote revisions records
 
453
      them as full references rather than integers. (John Arbash Meinel,
 
454
      #64789)
 
455
 
 
456
    * ``bzr ignore`` strips trailing slashes in patterns.
 
457
      Also ``bzr ignore`` rejects absolute paths. (Kent Gibson, #4559)
 
458
 
 
459
    * ``bzr ignore`` takes multiple arguments. (Cheuksan Edward Wang, #29488)
 
460
 
 
461
    * mv correctly handles paths that traverse symlinks. 
 
462
      (Aaron Bentley, #66964)
 
463
 
 
464
    * Give nicer looking error messages when failing to connect over ssh.
 
465
      (John Arbash Meinel, #49172)
 
466
 
 
467
    * Pushing to a remote branch does not currently update the remote working
 
468
      tree. After a remote push, ``bzr status`` and ``bzr diff`` on the remote
 
469
      machine now show that the working tree is out of date.
 
470
      (Cheuksan Edward Wang #48136)
 
471
 
 
472
    * Use patiencediff instead of difflib for determining deltas to insert
 
473
      into knits. This avoids the O(N^3) behavior of difflib. Patience
 
474
      diff should be O(N^2). (Cheuksan Edward Wang, #65714)
 
475
 
 
476
    * Running ``bzr log`` on nonexistent file gives an error instead of the
 
477
      entire log history. (Cheuksan Edward Wang #50793)
 
478
 
 
479
    * ``bzr cat`` can look up contents of removed or renamed files. If the
 
480
      pathname is ambiguous, i.e. the files in the old and new trees have
 
481
      different id's, the default is the file in the new tree. The user can
 
482
      use "--name-from-revision" to select the file in the old tree.
 
483
      (Cheuksan Edward Wang, #30190)
 
484
 
 
485
  TESTING:
 
486
 
 
487
    * TestingHTTPRequestHandler really handles the Range header
 
488
      (previously it was ignoring it and returning the whole file,).
 
489
 
 
490
bzr 0.12  2006-10-30
 
491
 
 
492
  INTERNALS:
 
493
 
 
494
    * Clean up ``bzr selftest --benchmark bundle`` to correct an import,
 
495
      and remove benchmarks that take longer than 10min to run.
 
496
      (John Arbash Meinel)
 
497
  
 
498
bzr 0.12rc1  2006-10-23
 
499
 
 
500
  IMPROVEMENTS:
 
501
 
 
502
    * ``bzr log`` now shows dotted-decimal revision numbers for all revisions,
 
503
      rather than just showing a decimal revision number for revisions on the
 
504
      mainline. These revision numbers are not yet accepted as input into bzr
 
505
      commands such as log, diff etc. (Robert Collins)
 
506
 
 
507
    * revisions can now be specified using dotted-decimal revision numbers.
 
508
      For instance, ``bzr diff -r 1.2.1..1.2.3``. (Robert Collins)
 
509
 
 
510
    * ``bzr help commands`` output is now shorter (Aaron Bentley)
 
511
 
 
512
    * ``bzr`` now uses lazy importing to reduce the startup time. This has
 
513
      a moderate effect on lots of actions, especially ones that have
 
514
      little to do. For example ``bzr rocks`` time is down to 116ms from
 
515
      283ms. (John Arbash Meinel)
 
516
 
 
517
    * New Registry class to provide name-to-object registry-like support,
 
518
      for example for schemes where plugins can register new classes to
 
519
      do certain tasks (e.g. log formatters). Also provides lazy registration
 
520
      to allow modules to be loaded on request. (John Arbash Meinel, Adeodato
 
521
      Simó)
 
522
 
 
523
  API INCOMPATABILITY:
 
524
  
 
525
    * LogFormatter subclasses show now expect the 'revno' parameter to 
 
526
      show() to be a string rather than an int. (Robert Collins)
 
527
 
 
528
  INTERNALS:
 
529
 
 
530
    * ``TestCase.run_bzr``, ``run_bzr_captured``, and ``run_bzr_subprocess``
 
531
      can take a ``working_dir='foo'`` parameter, which will change directory 
 
532
      for the command. (John Arbash Meinel)
 
533
 
 
534
    * ``bzrlib.lazy_regex.lazy_compile`` can be used to create a proxy
 
535
      around a regex, which defers compilation until first use. 
 
536
      (John Arbash Meinel)
 
537
 
 
538
    * ``TestCase.run_bzr_subprocess`` defaults to supplying the
 
539
      ``--no-plugins`` parameter to ensure test reproducability, and avoid
 
540
      problems with system-wide installed plugins. (John Arbash Meinel)
 
541
 
 
542
    * Unique tree root ids are now supported. Newly created trees still
 
543
      use the common root id for compatibility with bzr versions before 0.12.
 
544
      (Aaron Bentley)
 
545
 
 
546
    * ``WorkingTree.set_root_id(None)`` is now deprecated. Please
 
547
      pass in inventory.ROOT_ID if you want the default root id value.
 
548
      (Robert Collins, John Arbash Meinel)
 
549
 
 
550
    * New method ``WorkingTree.flush()`` which will write the current memory
 
551
      inventory out to disk. At the same time, read_working_inventory will
 
552
      no longer trash the current tree inventory if it has been modified within
 
553
      the current lock, and the tree will now ``flush()`` automatically on
 
554
      ``unlock()``. ``WorkingTree.set_root_id()`` has been updated to take
 
555
      advantage of this functionality. (Robert Collins, John Arbash Meinel)
 
556
 
 
557
    * ``bzrlib.tsort.merge_sorted`` now accepts ``generate_revnos``. This
 
558
      parameter will cause it to add another column to its output, which
 
559
      contains the dotted-decimal revno for each revision, as a tuple.
 
560
      (Robert Collins)
 
561
 
 
562
    * ``LogFormatter.show_merge`` is deprecated in favour of
 
563
      ``LogFormatter.show_merge_revno``. (Robert Collins)
 
564
 
 
565
  BUG FIXES:
 
566
 
 
567
    * Avoid circular imports by creating a deprecated function for
 
568
      ``bzrlib.tree.RevisionTree``. Callers should have been using
 
569
      ``bzrlib.revisontree.RevisionTree`` anyway. (John Arbash Meinel,
 
570
      #63360, #66349)
 
571
 
 
572
    * Don't use ``socket.MSG_WAITALL`` as it doesn't exist on all
 
573
      platforms. (Martin Pool, #66356)
 
574
 
 
575
    * Don't require ``Content-Type`` in range responses. Assume they are a
 
576
      single range if ``Content-Type`` does not exist.
 
577
      (John Arbash Meinel, #62473)
 
578
 
 
579
    * bzr branch/pull no longer complain about progress bar cleanup when
 
580
      interrupted during fetch.  (Aaron Bentley, #54000)
 
581
 
 
582
    * ``WorkingTree.set_parent_trees()`` uses the trees to directly write
 
583
      the basis inventory, rather than going through the repository. This
 
584
      allows us to have 1 inventory read, and 2 inventory writes when
 
585
      committing a new tree. (John Arbash Meinel)
 
586
 
 
587
    * When reverting, files that are not locally modified that do not exist
 
588
      in the target are deleted, not just unversioned (Aaron Bentley)
 
589
 
 
590
    * When trying to acquire a lock, don't fail immediately. Instead, try
 
591
      a few times (up to 1 hour) before timing out. Also, report why the
 
592
      lock is unavailable (John Arbash Meinel, #43521, #49556)
 
593
 
 
594
    * Leave HttpTransportBase daughter classes decides how they
 
595
      implement cloning. (Vincent Ladeuil, #61606)
 
596
 
 
597
    * diff3 does not indicate conflicts on clean merge. (Aaron Bentley)
 
598
 
 
599
    * If a commit fails, the commit message is stored in a file at the root of
 
600
      the tree for later commit. (Cheuksan Edward Wang, Stefan Metzmacher,
 
601
      #32054)
 
602
 
 
603
  TESTING:
 
604
 
 
605
    * New test base class TestCaseWithMemoryTransport offers memory-only
 
606
      testing facilities: its not suitable for tests that need to mutate disk
 
607
      state, but most tests should not need that and should be converted to
 
608
      TestCaseWithMemoryTransport. (Robert Collins)
 
609
 
 
610
    * ``TestCase.make_branch_and_memory_tree`` now takes a format
 
611
      option to set the BzrDir, Repository and Branch formats of the
 
612
      created objects. (Robert Collins, John Arbash Meinel)
 
613
 
 
614
bzr 0.11  2006-10-02
 
615
 
 
616
    * Smart server transport test failures on windows fixed. (Lukáš Lalinský).
 
617
 
 
618
bzr 0.11rc2  2006-09-27
 
619
 
 
620
  BUG FIXES:
 
621
 
 
622
    * Test suite hangs on windows fixed. (Andrew Bennets, Alexander Belchenko).
 
623
    
 
624
    * Commit performance regression fixed. (Aaron Bentley, Robert Collins, John
 
625
      Arbash Meinel).
 
626
 
 
627
bzr 0.11rc1  2006-09-25
 
628
 
 
629
  IMPROVEMENTS:
 
630
 
 
631
    * Knit files now wait to create their contents until the first data is
 
632
      added. The old code used to create an empty .knit and a .kndx with just
 
633
      the header. However, this caused a lot of extra round trips over sftp.
 
634
      This can change the time for ``bzr push`` to create a new remote branch
 
635
      from 160s down to 100s. This also affects ``bzr commit`` performance when
 
636
      adding new files, ``bzr commit`` on a new kernel-like tree drops from 50s
 
637
      down to 40s (John Arbash Meinel, #44692)
 
638
 
 
639
    * When an entire subtree has been deleted, commit will now report that
 
640
      just the top of the subtree has been deleted, rather than reporting
 
641
      all the individual items. (Robert Collins)
 
642
 
 
643
    * Commit performs one less XML parse. (Robert Collins)
 
644
 
 
645
    * ``bzr checkout`` now operates on readonly branches as well
 
646
      as readwrite branches. This fixes bug #39542. (Robert Collins)
 
647
 
 
648
    * ``bzr bind`` no longer synchronises history with the master branch.
 
649
      Binding should be followed by an update or push to synchronise the 
 
650
      two branches. This is closely related to the fix for bug #39542.
 
651
      (Robert Collins)
 
652
 
 
653
    * ``bzrlib.lazy_import.lazy_import`` function to create on-demand 
 
654
      objects.  This allows all imports to stay at the global scope, but
 
655
      modules will not actually be imported if they are not used.
 
656
      (John Arbash Meinel)
 
657
 
 
658
    * Support bzr:// and bzr+ssh:// urls to work with the new RPC-based
 
659
      transport which will be used with the upcoming high-performance smart
 
660
      server. The new command ``bzr serve`` will invoke bzr in server mode,
 
661
      which processes these requests. (Andrew Bennetts, Robert Collins, Martin
 
662
      Pool)
 
663
 
 
664
    * New command ``bzr version-info`` which can be used to get a summary
 
665
      of the current state of the tree. This is especially useful as part
 
666
      of a build commands. See ``doc/version_info.txt`` for more information 
 
667
      (John Arbash Meinel)
 
668
 
 
669
  BUG FIXES:
 
670
 
 
671
    * 'bzr inventory [FILE...]' allows restricting the file list to a
 
672
      specific set of files. (John Arbash Meinel, #3631)
 
673
 
 
674
    * Don't abort when annotating empty files (John Arbash Meinel, #56814)
 
675
 
 
676
    * Add ``Stanza.to_unicode()`` which can be passed to another Stanza
 
677
      when nesting stanzas. Also, add ``read_stanza_unicode`` to handle when
 
678
      reading a nested Stanza. (John Arbash Meinel)
 
679
 
 
680
    * Transform._set_mode() needs to stat the right file. 
 
681
      (John Arbash Meinel, #56549)
 
682
 
 
683
    * Raise WeaveFormatError rather than StopIteration when trying to read
 
684
      an empty Weave file. (John Arbash Meinel, #46871)
 
685
 
 
686
    * Don't access e.code for generic URLErrors, only HTTPErrors have .code.
 
687
      (Vincent Ladeuil, #59835)
 
688
 
 
689
    * Handle boundary="" lines properly to allow access through a Squid proxy.
 
690
      (John Arbash Meinel, #57723)
 
691
 
 
692
    * revert now removes newly-added directories (Aaron Bentley, #54172)
 
693
 
 
694
    * ``bzr upgrade sftp://`` shouldn't fail to upgrade v6 branches if there 
 
695
      isn't a working tree. (David Allouche, #40679)
 
696
 
 
697
    * Give nicer error messages when a user supplies an invalid --revision
 
698
      parameter. (John Arbash Meinel, #55420)
 
699
 
 
700
    * Handle when LANG is not recognized by python. Emit a warning, but
 
701
      just revert to using 'ascii'. (John Arbash Meinel, #35392)
 
702
 
 
703
    * Don't use preexec_fn on win32, as it is not supported by subprocess.
 
704
      (John Arbash Meinel)
 
705
 
 
706
    * Skip specific tests when the dependencies aren't met. This includes
 
707
      some ``setup.py`` tests when ``python-dev`` is not available, and
 
708
      some tests that depend on paramiko. (John Arbash Meinel, Mattheiu Moy)
 
709
 
 
710
    * Fallback to Paramiko properly, if no ``ssh`` executable exists on
 
711
      the system. (Andrew Bennetts, John Arbash Meinel)
 
712
 
 
713
    * ``Branch.bind(other_branch)`` no longer takes a write lock on the
 
714
      other branch, and will not push or pull between the two branches.
 
715
      API users will need to perform a push or pull or update operation if they
 
716
      require branch synchronisation to take place. (Robert Collins, #47344)
 
717
 
 
718
    * When creating a tarball or zipfile export, export unicode names as utf-8
 
719
      paths. This may not work perfectly on all platforms, but has the best
 
720
      chance of working in the common case. (John Arbash Meinel, #56816)
 
721
 
 
722
    * When committing, only files that exist in working tree or basis tree
 
723
      may be specified (Aaron Bentley, #50793)
 
724
 
 
725
  PORTABILITY:
 
726
 
 
727
    * Fixes to run on Python 2.5 (Brian M. Carlson, Martin Pool, Marien Zwart)
 
728
 
 
729
  INTERNALS:
 
730
 
 
731
    * TestCaseInTempDir now creates a separate directory for HOME, rather
 
732
      than having HOME set to the same location as the working directory.
 
733
      (John Arbash Meinel)
 
734
 
 
735
    * run_bzr_subprocess() can take an optional 'env_changes={}' parameter,
 
736
      which will update os.environ inside the spawned child. It also can
 
737
      take a 'universal_newlines=True', which helps when checking the output
 
738
      of the command. (John Arbash Meinel)
 
739
 
 
740
    * Refactor SFTP vendors to allow easier re-use when ssh is used. 
 
741
      (Andrew Bennetts)
 
742
 
 
743
    * Transport.list_dir() and Transport.iter_files_recursive() should always
 
744
      return urlescaped paths. This is now tested (there were bugs in a few
 
745
      of the transports) (Andrew Bennetts, David Allouche, John Arbash Meinel)
 
746
 
 
747
    * New utility function symbol_versioning.deprecation_string. Returns the
 
748
      formatted string for a callable, deprecation format pair. (Robert Collins)
 
749
 
 
750
    * New TestCase helper applyDeprecated. This allows you to call a callable
 
751
      which is deprecated without it spewing to the screen, just by supplying
 
752
      the deprecation format string issued for it. (Robert Collins)
 
753
 
 
754
    * Transport.append and Transport.put have been deprecated in favor of
 
755
      .append_bytes, .append_file, .put_bytes, and .put_file. This removes the
 
756
      ambiguity in what type of object the functions take.
 
757
      Transport.non_atomic_put_{bytes,file} has also been added. Which works
 
758
      similarly to Transport.append() except for SFTP, it doesn't have a round
 
759
      trip when opening the file. Also, it provides functionality for creating
 
760
      a parent directory when trying to create a file, rather than raise
 
761
      NoSuchFile and forcing the caller to repeat their request.
 
762
      (John Arbash Meinel)
 
763
 
 
764
    * WorkingTree has a new api ``unversion`` which allow the unversioning of
 
765
      entries by their file id. (Robert Collins)
 
766
 
 
767
    * WorkingTree.pending_merges is deprecated.  Please use the get_parent_ids
 
768
      (introduced in 0.10) method instead. (Robert Collins)
 
769
 
 
770
    * WorkingTree has a new lock_tree_write method which locks the branch for
 
771
      read rather than write. This is appropriate for actions which only need
 
772
      the branch data for reference rather than mutation. A new decorator
 
773
      needs_tree_write_lock is provided in the workingtree module. Like the
 
774
      needs_read_lock and needs_write_lock decorators this allows static 
 
775
      declaration of the locking requirements of a function to ensure that
 
776
      a lock is taken out for casual scripts. (Robert Collins, #54107)
 
777
 
 
778
    * All WorkingTree methods which write to the tree, but not to the branch
 
779
      have been converted to use ``needs_tree_write_lock`` rather than 
 
780
      ``needs_write_lock``. Also converted is the revert, conflicts and tree
 
781
      transform modules. This provides a modest performance improvement on 
 
782
      metadir style trees, due to the reduce lock-acquisition, and a more
 
783
      significant performance improvement on lightweight checkouts from 
 
784
      remote branches, where trivial operations used to pay a significant 
 
785
      penalty. It also provides the basis for allowing readonly checkouts.
 
786
      (Robert Collins)
 
787
 
 
788
    * Special case importing the standard library 'copy' module. This shaves
 
789
      off 40ms of startup time, while retaining compatibility. See:
 
790
      ``bzrlib/inspect_for_copy.py`` for more details. (John Arbash Meinel)
 
791
 
 
792
    * WorkingTree has a new parent class MutableTree which represents the 
 
793
      specialisations of Tree which are able to be altered. (Robert Collins)
 
794
 
 
795
    * New methods mkdir and put_file_bytes_non_atomic on MutableTree that
 
796
      mutate the tree and its contents. (Robert Collins)
 
797
 
 
798
    * Transport behaviour at the root of the URL is now defined and tested.
 
799
      (Andrew Bennetts, Robert Collins)
 
800
 
 
801
  TESTING:
 
802
 
 
803
    * New test helper classs MemoryTree. This is typically accessed via
 
804
      ``self.make_branch_and_memory_tree()`` in test cases. (Robert Collins)
 
805
      
 
806
    * Add start_bzr_subprocess and stop_bzr_subprocess to allow test code to
 
807
      continue running concurrently with a subprocess of bzr. (Andrew Bennetts,
 
808
      Robert Collins)
 
809
 
 
810
    * Add a new method ``Transport.get_smart_client()``. This is provided to
 
811
      allow upgrades to a richer interface than the VFS one provided by
 
812
      Transport. (Andrew Bennetts, Martin Pool)
 
813
 
 
814
bzr 0.10  2006-08-29
 
815
  
 
816
  IMPROVEMENTS:
 
817
    * 'merge' now takes --uncommitted, to apply uncommitted changes from a
 
818
      tree.  (Aaron Bentley)
 
819
  
 
820
    * 'bzr add --file-ids-from' can be used to specify another path to use
 
821
      for creating file ids, rather than generating all new ones. Internally,
 
822
      the 'action' passed to smart_add_tree() can return file_ids that
 
823
      will be used, rather than having bzrlib generate new ones.
 
824
      (John Arbash Meinel, #55781)
 
825
 
 
826
    * ``bzr selftest --benchmark`` now allows a ``--cache-dir`` parameter.
 
827
      This will cache some of the intermediate trees, and decrease the
 
828
      setup time for benchmark tests. (John Arbash Meinel)
 
829
 
 
830
    * Inverse forms are provided for all boolean options.  For example,
 
831
      --strict has --no-strict, --no-recurse has --recurse (Aaron Bentley)
 
832
 
 
833
    * Serialize out Inventories directly, rather than using ElementTree.
 
834
      Writing out a kernel sized inventory drops from 2s down to ~350ms.
 
835
      (Robert Collins, John Arbash Meinel)
 
836
 
 
837
  BUG FIXES:
 
838
 
 
839
    * Help diffutils 2.8.4 get along with binary tests (Marien Zwart: #57614)
 
840
 
 
841
    * Change LockDir so that if the lock directory doesn't exist when
 
842
      lock_write() is called, an attempt will be made to create it.
 
843
      (John Arbash Meinel, #56974)
 
844
 
 
845
    * ``bzr uncommit`` preserves pending merges. (John Arbash Meinel, #57660)
 
846
 
 
847
    * Active FTP transport now works as intended. (ghozzy, #56472)
 
848
 
 
849
    * Really fix mutter() so that it won't ever raise a UnicodeError.
 
850
      It means it is possible for ~/.bzr.log to contain non UTF-8 characters.
 
851
      But it is a debugging log, not a real user file.
 
852
      (John Arbash Meinel, #56947, #53880)
 
853
 
 
854
    * Change Command handle to allow Unicode command and options.
 
855
      At present we cannot register Unicode command names, so we will get
 
856
      BzrCommandError('unknown command'), or BzrCommandError('unknown option')
 
857
      But that is better than a UnicodeError + a traceback.
 
858
      (John Arbash Meinel, #57123)
 
859
 
 
860
    * Handle TZ=UTC properly when reading/writing revisions.
 
861
      (John Arbash Meinel, #55783, #56290)
 
862
 
 
863
    * Use GPG_TTY to allow gpg --cl to work with gpg-agent in a pipeline,
 
864
      (passing text to sign in on stdin). (John Arbash Meinel, #54468)
 
865
 
 
866
    * External diff does the right thing for binaries even in foreign 
 
867
      languages. (John Arbash Meinel, #56307)
 
868
 
 
869
    * Testament handles more cases when content is unicode. Specific bug was
 
870
      in handling of revision properties. (John Arbash Meinel, Holger Krekel,
 
871
      #54723)
 
872
 
 
873
    * The bzr selftest was failing on installed versions due to a bug in a new
 
874
      test helper. (John Arbash Meinel, Robert Collins, #58057)
 
875
 
 
876
  INTERNALS:
 
877
 
 
878
    * ``bzrlib.cache_utf8`` contains ``encode()`` and ``decode()`` functions
 
879
      which can be used to cache the conversion between utf8 and Unicode.
 
880
      Especially helpful for some of the knit annotation code, which has to
 
881
      convert revision ids to utf8 to annotate lines in storage.
 
882
      (John Arbash Meinel)
 
883
 
 
884
    * ``setup.py`` now searches the filesystem to find all packages which
 
885
      need to be installed. This should help make the life of packagers
 
886
      easier. (John Arbash Meinel)
 
887
 
 
888
bzr 0.9.0  2006-08-11
 
889
 
 
890
  SURPRISES:
 
891
 
 
892
   * The hard-coded built-in ignore rules have been removed. There are
 
893
     now two rulesets which are enforced. A user global one in 
 
894
     ~/.bazaar/ignore which will apply to every tree, and the tree
 
895
     specific one '.bzrignore'.
 
896
     ~/.bazaar/ignore will be created if it does not exist, but with
 
897
     a more conservative list than the old default.
 
898
     This fixes bugs with default rules being enforced no matter what. 
 
899
     The old list of ignore rules from bzr is available by
 
900
     running 'bzr ignore --old-default-rules'.
 
901
     (Robert Collins, Martin Pool, John Arbash Meinel)
 
902
 
 
903
   * 'branches.conf' has been changed to 'locations.conf', since it can apply
 
904
     to more locations than just branch locations.
 
905
     (Aaron Bentley)
 
906
   
 
907
  IMPROVEMENTS:
 
908
 
 
909
   * The revision specifier "revno:" is extended to accept the syntax
 
910
     revno:N:branch. For example,
 
911
     revno:42:http://bazaar-vcs.org/bzr/bzr.dev/ means revision 42 in
 
912
     bzr.dev.  (Matthieu Moy)
 
913
 
 
914
   * Tests updates to ensure proper URL handling, UNICODE support, and
 
915
     proper printing when the user's terminal encoding cannot display 
 
916
     the path of a file that has been versioned.
 
917
     ``bzr branch`` can take a target URL rather than only a local directory.
 
918
     Branch.get_parent()/set_parent() now save a relative path if possible,
 
919
     and normalize the parent based on root, allowing access across
 
920
     different transports. (John Arbash Meinel, Wouter van Heyst, Martin Pool)
 
921
     (Malone #48906, #42699, #40675, #5281, #3980, #36363, #43689,
 
922
     #42517, #42514)
4
923
 
5
924
   * On Unix, detect terminal width using an ioctl not just $COLUMNS.
6
925
     Use terminal width for single-line logs from ``bzr log --line`` and
18
937
   * 'bzr selftest' now shows a progress bar with the number of tests, and 
19
938
     progress made. 'make check' shows tests in -v mode, to be more useful
20
939
     for the PQM status window. (Robert Collins).
 
940
     When using a progress bar, failed tests are printed out, rather than
 
941
     being overwritten by the progress bar until the suite finishes.
 
942
     (John Arbash Meinel)
21
943
 
22
944
   * 'bzr selftest --benchmark' will run a new benchmarking selftest.
23
945
     'bzr selftest --benchmark --lsprof-timed' will use lsprofile to generate
38
960
     ftp support has been improved, including support for supplying a
39
961
     non-standard port. (John Arbash Meinel).
40
962
 
41
 
   * ``log --line`` shows the revision number.  (#5162, Alexander Belchenko)
 
963
   * 'bzr log --line' shows the revision number, and uses only the
 
964
     first line of the log message (#5162, Alexander Belchenko;
 
965
     Matthieu Moy)
 
966
 
 
967
   * 'bzr status' has had the --all option removed. The 'bzr ls' command
 
968
     should be used to retrieve all versioned files. (Robert Collins)
 
969
 
 
970
   * 'bzr bundle OTHER/BRANCH' will create a bundle which can be sent
 
971
     over email, and applied on the other end, while maintaining ancestry.
 
972
     This bundle can be applied with either 'bzr merge' or 'bzr pull',
 
973
     the same way you would apply another branch.
 
974
     (John Arbash Meinel, Aaron Bentley)
 
975
  
 
976
   * 'bzr whoami' can now be used to set your identity from the command line,
 
977
     for a branch or globally.  (Robey Pointer)
 
978
 
 
979
   * 'bzr checkout' now aliased to 'bzr co', and 'bzr annotate' to 'bzr ann'.
 
980
     (Michael Ellerman)
 
981
 
 
982
   * 'bzr revert DIRECTORY' now reverts the contents of the directory as well.
 
983
     (Aaron Bentley)
 
984
 
 
985
   * 'bzr get sftp://foo' gives a better error when paramiko is not present.
 
986
     Also updates things like 'http+pycurl://' if pycurl is not present.
 
987
     (John Arbash Meinel) (Malone #47821, #52204)
 
988
 
 
989
   * New env variable BZR_PROGRESS_BAR, sets the default progress bar type.
 
990
     Can be set to 'none' or 'dummy' to disable the progress bar, 'dots' or 
 
991
     'tty' to create the respective type. (John Arbash Meinel, #42197, #51107)
 
992
 
 
993
   * Improve the help text for 'bzr diff' to explain what various options do.
 
994
     (John Arbash Meinel, #6391)
 
995
 
 
996
   * 'bzr uncommit -r 10' now uncommits revisions 11.. rather than uncommitting
 
997
     revision 10. This makes -r10 more in line with what other commands do.
 
998
     'bzr uncommit' also now saves the pending merges of the revisions that
 
999
     were removed. So it is safe to uncommit after a merge, fix something,
 
1000
     and commit again. (John Arbash Meinel, #32526, #31426)
 
1001
 
 
1002
   * 'bzr init' now also works on remote locations.
 
1003
     (Wouter van Heyst, #48904)
 
1004
 
 
1005
   * HTTP support has been updated. When using pycurl we now support 
 
1006
     connection keep-alive, which reduces dns requests and round trips.
 
1007
     And for both urllib and pycurl we support multi-range requests, 
 
1008
     which decreases the number of round-trips. Performance results for
 
1009
     ``bzr branch http://bazaar-vcs.org/bzr/bzr.dev/`` indicate
 
1010
     http branching is now 2-3x faster, and ``bzr pull`` in an existing 
 
1011
     branch is as much as 4x faster.
 
1012
     (Michael Ellerman, Johan Rydberg, John Arbash Meinel, #46768)
 
1013
 
 
1014
   * Performance improvements for sftp. Branching and pulling are now up to
 
1015
     2x faster. Utilize paramiko.readv() support for async requests if it
 
1016
     is available (paramiko > 1.6) (John Arbash Meinel)
42
1017
 
43
1018
  BUG FIXES:
44
1019
 
46
1021
      tests not to run.  (#32587, Erik Bågfors, Michael Ellerman, 
47
1022
      Martin Pool)
48
1023
 
 
1024
    * Fix unnecessary requirement of sign-my-commits that it be run from
 
1025
      a working directory.  (Martin Pool, Robert Collins)
 
1026
 
 
1027
    * 'bzr push location' will only remember the push location if it succeeds
 
1028
      in connecting to the remote location. (#49742, John Arbash Meinel)
 
1029
 
 
1030
    * 'bzr revert' no longer toggles the executable bit on win32
 
1031
      (#45010, John Arbash Meinel)
 
1032
 
 
1033
    * Handle broken pipe under win32 correctly. (John Arbash Meinel)
 
1034
    
 
1035
    * sftp tests now work correctly on win32 if you have a newer paramiko
 
1036
      (John Arbash Meinel)
 
1037
 
 
1038
    * Cleanup win32 test suite, and general cleanup of places where
 
1039
      file handles were being held open. (John Arbash Meinel)
 
1040
 
 
1041
    * When specifying filenames for 'diff -r x..y', the name of the file in the
 
1042
      working directory can be used, even if its name is different in both x
 
1043
      and y.
 
1044
 
 
1045
    * File-ids containing single- or double-quotes are handled correctly by
 
1046
      push.  (#52227, Aaron Bentley)
 
1047
 
 
1048
    * Normalize unicode filenames to ensure cross-platform consistency.
 
1049
      (John Arbash Meinel, #43689)
 
1050
 
 
1051
    * The argument parser can now handle '-' as an argument. Currently
 
1052
      no code interprets it specially (it is mostly handled as a file named 
 
1053
      '-'). But plugins, and future operations can use it.
 
1054
      (John Arbash meinel, #50984)
 
1055
 
 
1056
    * Bundles can properly read binary files with a plain '\r' in them.
 
1057
      (John Arbash Meinel, #51927)
 
1058
 
 
1059
    * Tuning iter_entries() to be more efficient (John Arbash Meinel, #5444)
 
1060
 
 
1061
    * Lots of win32 fixes (the test suite passes again).
 
1062
      (John Arbash Meinel, #50155)
 
1063
 
 
1064
    * Handle openbsd returning None for sys.getfilesystemencoding() (#41183) 
 
1065
 
 
1066
    * Support ftp APPE (append) to allow Knits to be used over ftp (#42592)
 
1067
 
 
1068
    * Removals are only committed if they match the filespec (or if there is
 
1069
      no filespec).  (#46635, Aaron Bentley)
 
1070
 
 
1071
    * smart-add recurses through all supplied directories 
 
1072
      (John Arbash Meinel, #52578)
 
1073
 
 
1074
    * Make the bundle reader extra lines before and after the bundle text.
 
1075
      This allows you to parse an email with the bundle inline.
 
1076
      (John Arbash Meinel, #49182)
 
1077
 
 
1078
    * Change the file id generator to squash a little bit more. Helps when
 
1079
      working with long filenames on windows. (Also helps for unicode filenames
 
1080
      not generating hidden files). (John Arbash Meinel, #43801)
 
1081
 
 
1082
    * Restore terminal mode on C-c while reading sftp password.  (#48923, 
 
1083
      Nicholas Allen, Martin Pool)
 
1084
 
 
1085
    * Timestamps are rounded to 1ms, and revision entries can be recreated
 
1086
      exactly. (John Arbash Meinel, Jamie Wilkinson, #40693)
 
1087
 
 
1088
    * Branch.base has changed to a URL, but ~/.bazaar/locations.conf should
 
1089
      use local paths, since it is user visible (John Arbash Meinel, #53653)
 
1090
 
 
1091
    * ``bzr status foo`` when foo was unversioned used to cause a full delta
 
1092
      to be generated (John Arbash Meinel, #53638)
 
1093
 
 
1094
    * When reading revision properties, an empty value should be considered
 
1095
      the empty string, not None (John Arbash Meinel, #47782)
 
1096
 
 
1097
    * ``bzr diff --diff-options`` can now handle binary files being changed.
 
1098
      Also, the output is consistent when --diff-options is not supplied.
 
1099
      (John Arbash Meinel, #54651, #52930)
 
1100
 
 
1101
    * Use the right suffixes for loading plugins (John Arbash Meinel, #51810)
 
1102
 
 
1103
    * Fix Branch.get_parent() to handle the case when the parent is not 
 
1104
      accessible (John Arbash Meinel, #52976)
 
1105
 
49
1106
  INTERNALS:
50
1107
 
51
1108
    * Combine the ignore rules into a single regex rather than looping over
52
1109
      them to reduce the threshold where  N^2 behaviour occurs in operations
53
1110
      like status. (Jan Hudec, Robert Collins).
54
1111
 
 
1112
    * Appending to bzrlib.DEFAULT_IGNORE is now deprecated. Instead, use
 
1113
      one of the add functions in bzrlib.ignores. (John Arbash Meinel)
 
1114
 
55
1115
    * 'bzr push' should only push the ancestry of the current revision, not
56
1116
      all of the history in the repository. This is especially important for
57
1117
      shared repositories. (John Arbash Meinel)
59
1119
    * bzrlib.delta.compare_trees now iterates in alphabetically sorted order,
60
1120
      rather than randomly walking the inventories. (John Arbash Meinel)
61
1121
 
 
1122
    * Doctests are now run in temporary directories which are cleaned up when
 
1123
      they finish, rather than using special ScratchDir/ScratchBranch objects.
 
1124
      (Martin Pool)
 
1125
 
 
1126
    * Split ``check`` into separate methods on the branch and on the repository,
 
1127
      so that it can be specialized in ways that are useful or efficient for
 
1128
      different formats.  (Martin Pool, Robert Collins)
 
1129
 
 
1130
    * Deprecate Repository.all_revision_ids; most methods don't really need
 
1131
      the global revision graph but only that part leading up to a particular
 
1132
      revision.  (Martin Pool, Robert Collins)
 
1133
 
 
1134
    * Add a BzrDirFormat control_formats list which allows for control formats
 
1135
      that do not use '.bzr' to store their data - i.e. '.svn', '.hg' etc.
 
1136
      (Robert Collins, Jelmer Vernooij).
 
1137
 
 
1138
    * bzrlib.diff.external_diff can be redirected to any file-like object.
 
1139
      Uses subprocess instead of spawnvp.
 
1140
      (#4047, #48914, James Henstridge, John Arbash Meinel)
 
1141
 
 
1142
    * New command line option '--profile-imports', which will install a custom
 
1143
      importer to log time to import modules and regex compilation time to 
 
1144
      sys.stderr (John Arbash Meinel)
 
1145
 
 
1146
    * 'EmptyTree' is now deprecated, please use repository.revision_tree(None)
 
1147
      instead. (Robert Collins)
 
1148
 
 
1149
    * "RevisionTree" is now in bzrlib/revisiontree.py. (Robert Collins)
 
1150
 
62
1151
bzr 0.8.2  2006-05-17
63
1152
  
64
1153
  BUG FIXES:
178
1267
    * Pull now accepts a --revision argument (Erik Bågfors)
179
1268
 
180
1269
    * 'bzr re-sign' now allows multiple revisions to be supplied on the command
181
 
      line. You can now use the following command to sign all of your old commits.
 
1270
      line. You can now use the following command to sign all of your old
 
1271
      commits::
 
1272
 
182
1273
        find .bzr/revision-store// -name my@email-* \
183
1274
          | sed 's/.*\/\/..\///' \
184
1275
          | xargs bzr re-sign
255
1346
 
256
1347
    * Add --revision option to 'annotate' command.  (Olaf Conradi)
257
1348
 
258
 
    * Add --revision option to 'annotate' command.  (Olaf Conradi)
259
 
 
260
1349
    * If bzr shows an unexpected revision-history after pulling (perhaps due
261
1350
      to a reweave) it can now be corrected by 'bzr reconcile'.
262
1351
      (Robert Collins)
772
1861
    * Config options have moved from bzrlib.osutils to bzrlib.config.
773
1862
      Configuration is now done via the config.Config interface:
774
1863
      Depending on whether you have a Branch, a Location or no information
775
 
      available, construct a *Config, and use its signature_checking,
776
 
      username and user_email methods. (Robert Collins)
 
1864
      available, construct a ``*Config``, and use its ``signature_checking``,
 
1865
      ``username`` and ``user_email`` methods. (Robert Collins)
777
1866
 
778
1867
    * Plugins are now loaded under bzrlib.plugins, not bzrlib.plugin, and
779
1868
      they are made available for other plugins to use. You should not 
925
2014
    * Symlink support: working with symlinks when not in the root of a 
926
2015
      bzr tree was broken, patch from Scott James Remnant.
927
2016
 
928
 
 
929
2017
  IMPROVEMENTS:
930
2018
 
931
2019
    * 'branch' now accepts a --basis parameter which will take advantage