~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to NEWS

  • Committer: John Arbash Meinel
  • Date: 2007-05-04 18:59:36 UTC
  • mto: This revision was merged to the branch mainline in revision 2643.
  • Revision ID: john@arbash-meinel.com-20070504185936-1mjdoqmtz74xe5mg
A C implementation of _fields_to_entry_0_parents drops the time from 400ms to 330ms for a 21k-entry tree

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
--------------------
2
 
Bazaar Release Notes
3
 
--------------------
4
 
 
5
 
.. contents::
6
 
 
7
 
 
8
1
IN DEVELOPMENT
9
 
--------------
10
 
 
11
 
  NOTES WHEN UPGRADING:
12
 
 
13
 
  CHANGES:
14
 
 
15
 
   * bzr main script cannot be imported (Benjamin Peterson)
16
 
 
17
 
   * On Linux bzr additionally looks for plugins in arch-independent site
18
 
     directory. (Toshio Kuratomi)
19
 
 
20
 
   * When a plugin cannot be loaded as the file path is not a valid
21
 
     python module name bzr will now strip a ``bzr_`` prefix from the
22
 
     front of the suggested name, as many plugins (e.g. bzr-svn)
23
 
     want to be installed without this prefix. It is a common mistake
24
 
     to have a folder named "bzr-svn" for that plugin, especially
25
 
     as this is what bzr branch lp:bzr-svn will give you. (James Westby,
26
 
     Andrew Cowie)
27
 
 
28
 
   * UniqueIntegerBugTracker now appends bug-ids instead of joining
29
 
     them to the base URL. Plugins that register bug trackers may
30
 
     need a trailing / added to the base URL if one is not already there.
31
 
     (James Wesby, Andrew Cowie)
32
 
 
33
 
  FEATURES:
34
 
 
35
 
    * Added mail-mode GNU Emacs mail package as a mail_client.
36
 
      (Xavier Maillard, Bojan Nikolic)
37
 
 
38
 
    * Added start_commit hook for mutable trees. (Jelmer Vernooij, #186422)
39
 
 
40
 
  IMPROVEMENTS:
41
 
 
42
 
    * ``bzr commit --fixes`` now recognises "gnome" as a tag by default.
43
 
      (James Westby, Andrew Cowie)
44
 
 
45
 
    * ``bzr switch`` will attempt to find branches to switch to relative to the
46
 
      current branch. E.g. ``bzr switch branchname`` will look for
47
 
      ``current_branch/../branchname``. (Robert Collins, Jelmer Vernooij,
48
 
      Wouter van Heyst)
49
 
 
50
 
    * Diff is now more specific about execute-bit changes it describes
51
 
      (Chad Miller)
52
 
 
53
 
    * Fetching data over HTTP is a bit faster when urllib is used.  This is done
54
 
      by forcing it to recv 64k at a time when reading lines in HTTP headers,
55
 
      rather than just 1 byte at a time.  (Andrew Bennetts)
56
 
 
57
 
    * Log --short and --line are much faster when -r is not specified.
58
 
      (Aaron Bentley)
59
 
 
60
 
    * Merge is faster.  We no longer check a file's existence unnecessarily
61
 
      when merging the execute bit.  (Aaron Bentley)
62
 
 
63
 
    * ``bzr status`` on an explicit list of files no longer shows pending
64
 
      merges, making it much faster on large trees. (John Arbash Meinel)
65
 
 
66
 
    * The launchpad directory service now warns the user if they have not set
67
 
      their launchpad login and are trying to resolve a URL using it, just
68
 
      in case they want to do a write operation with it.  (James Westby)
69
 
 
70
 
    * The smart protocol client is slightly faster, because it now only queries
71
 
      the server for the protocol version once per connection.  Also, the HTTP
72
 
      transport will now automatically probe for and use a smart server if
73
 
      one is present.  You can use the new ``nosmart+`` transport decorator
74
 
      to get the old behaviour.  (Andrew Bennetts)
75
 
 
76
 
     * Various operations with revision specs and commands that calculate
77
 
       revnos and revision ids are faster.  (John A. Meinel, Aaron Bentley)
78
 
 
79
 
  BUGFIXES:
80
 
 
81
 
    * Add ``root_client_path`` parameter to SmartWSGIApp and
82
 
      SmartServerRequest.  This makes it possible to publish filesystem
83
 
      locations that don't exactly match URL paths. SmartServerRequest
84
 
      subclasses should use the new ``translate_client_path`` and
85
 
      ``transport_from_client_path`` methods when dealing with paths received
86
 
      from a client to take this into account.  (Andrew Bennetts, #124089)
87
 
 
88
 
    * ``bzr mv a b`` can be now used also to rename previously renamed
89
 
      directories, not only files. (Lukáš Lalinský, #107967)
90
 
 
91
 
    * ``bzr uncommit --local`` can now remove revisions from the local
92
 
      branch to be symmetric with ``bzr commit --local``.
93
 
      (John Arbash Meinel, #93412)
94
 
 
95
 
    * Don't ask for a password if there is no real terminal.
96
 
      (Alexander Belchenko, #69851)
97
 
 
98
 
    * Fix a bug causing a ValueError crash in ``parse_line_delta_iter`` when
99
 
      fetching revisions from a knit to pack repository or vice versa using
100
 
      bzr:// (including over http or ssh).
101
 
      (#208418, Andrew Bennetts, Martin Pool, Robert Collins)
102
 
 
103
 
    * Implement handling of basename parameter for DefaultMail.  (James Westby)
104
 
 
105
 
    * Launchpad locations (lp: URLs) can be pulled.  (Aaron Bentley, #181945)
106
 
 
107
 
    * Merges that add files to deleted root directories complete.  They
108
 
      do create conflicts.  (Aaron Bentley, #210092)
109
 
 
110
 
    * vsftp's return ``550 RNFR command failed.`` supported.
111
 
      (Marcus Trautwig, #129786)
112
 
 
113
 
  DOCUMENTATION:
114
 
 
115
 
    * Improved documentation on send/merge relationship. (Peter Schuller)
116
 
 
117
 
    * Minor fixes to the User Guide. (Matthew Fuller)
118
 
 
119
 
    * Reduced the evangelism in the User Guide. (Ian Clatworthy)
120
 
 
121
 
  API BREAKS:
122
 
 
123
 
    * Attempting to pull data from a ghost aware repository (e.g. knits) into a
124
 
      non-ghost aware repository such as weaves will now fail if there are
125
 
      ghosts.  (Robert Collins)
126
 
 
127
 
    * Log formatters must now provide log_revision instead of show and
128
 
      show_merge_revno methods. The latter had been deprecated since the 0.17
129
 
      release. (James Westby)
130
 
 
131
 
    * ``Repository.get_revision_graph`` is deprecated, with no replacement
132
 
      method. The method was size(history) and not desirable. (Robert Collins)
133
 
 
134
 
    * ``revision.revision_graph`` is deprecated, with no replacement function.
135
 
      The function was size(history) and not desirable. (Robert Collins)
136
 
 
137
 
    * ``Transport.get_shared_medium`` is deprecated.  Use
138
 
      ``Transport.get_smart_medium`` instead.  (Andrew Bennetts)
139
 
 
140
 
    * ``VersionedFile.create_empty`` is removed. This method presupposed a
141
 
      sensible mapping to a transport for individual files, but pack backed
142
 
      versioned files have no such mapping. (Robert Collins)
143
 
 
144
 
    * ``VersionedFile.get_graph`` is deprecated, with no replacement method.
145
 
      The method was size(history) and not desirable. (Robert Collins)
146
 
 
147
 
    * ``VersionedFile.get_graph_with_ghosts`` is deprecated, with no
148
 
      replacement method.  The method was size(history) and not desirable.
149
 
      (Robert Collins)
150
 
 
151
 
    * ``VersionedFile.get_parents`` is deprecated, please use
152
 
      ``VersionedFile.get_parent_map``. (Robert Collins)
153
 
 
154
 
    * ``VersionedFile.has_ghost`` is now deprecated, as it is both expensive
155
 
      and unused outside of a single test. (Robert Collins)
156
 
 
157
 
  TESTING:
158
 
 
159
 
    * New -Dselftest_debug flag disables clearing of the debug flags during
160
 
      tests.  This is useful if you want to use e.g. -Dhpss to help debug a
161
 
      failing test.  Be aware that using this feature is likely to cause
162
 
      spurious test failures if used with the full suite. (Andrew Bennetts)
163
 
 
164
 
    * selftest --load-list now uses a new more agressive test loader that will
165
 
      avoid loading unneeded modules and building their tests. Plugins can use
166
 
      this new loader by defining a load_tests function instead of a test_suite
167
 
      function. (a forthcoming patch will provide many examples on how to
168
 
      implement this).
169
 
      (Vincent Ladeuil)
170
 
 
171
 
    * selftest --load-list now does some sanity checks regarding duplicate test
172
 
      IDs and tests present in the list but not found in the actual test suite.
173
 
      (Vincent Ladeuil)
174
 
 
175
 
    * Slightly more concise format for the selftest progress bar, so there's
176
 
      more space to show the test name.  (Martin Pool) ::
177
 
 
178
 
        [2500/10884, 1fail, 3miss in 1m29s] test_revisionnamespaces.TestRev
179
 
 
180
 
    * The test suite takes much less memory to run, and is a bit faster.  This
181
 
      is done by clearing most attributes of TestCases after running them, if
182
 
      they succeeded.  (Andrew Bennetts)
183
 
 
184
 
  INTERNALS:
185
 
 
186
 
    * ``VersionedFile`` now has a new method ``get_parent_map`` which, like
187
 
      ``Graph.get_parent_map`` returns a dict of key:parents. (Robert Collins)
188
 
 
189
 
 
190
 
bzr 1.3 2008-03-20
191
 
------------------
192
 
 
193
 
Bazaar has become part of the GNU project <http://www.gnu.org>
194
 
 
195
 
Many operations that act on history, including ``log`` and ``annotate`` are now
196
 
substantially faster.  Several bugs have been fixed and several new options and
197
 
features have been added.
198
 
 
199
 
  TESTING:
200
 
 
201
 
    * Avoid spurious failure of ``TestVersion.test_version`` matching
202
 
      directory names.
203
 
      (#202778, Martin Pool)
204
 
 
205
 
 
206
 
bzr 1.3rc1 2008-03-16
207
 
---------------------
208
 
 
209
 
  NOTES WHEN UPGRADING:
210
 
 
211
 
    * The backup directory created by ``upgrade`` is now called
212
 
      ``backup.bzr``, not ``.bzr.backup``. (Martin Albisetti)
213
 
 
214
 
  CHANGES:
215
 
 
216
 
    * A new repository format 'development' has been added. This format will
217
 
      represent the latest 'in-progress' format that the bzr developers are
218
 
      interested in getting early-adopter testing and feedback on.
219
 
      ``doc/developers/development-repo.txt`` has detailed information.
220
 
      (Robert Collins)
221
 
 
222
 
    * BZR_LOG environment variable controls location of .bzr.log trace file. 
223
 
      User can suppress writing messages to .bzr.log by using '/dev/null'
224
 
      filename (on Linux) or 'NUL' (on Windows). If BZR_LOG variable 
225
 
      is not defined but BZR_HOME is defined then default location
226
 
      for .bzr.log trace file is ``$BZR_HOME/.bzr.log``.
227
 
      (Alexander Belchenko)
228
 
 
229
 
    * ``launchpad`` builtin plugin now shipped as separate part in standalone
230
 
      bzr.exe, installed to ``C:\Program Files\Bazaar\plugins`` directory, 
231
 
      and standalone installer allows user to skip installation of this plugin.
232
 
      (Alexander Belchenko)
233
 
 
234
 
    * Restore auto-detection of plink.exe on Windows. (Dmitry Vasiliev)
235
 
 
236
 
    * Version number is now shown as "1.2" or "1.2pr2", without zeroed or
237
 
      missing final fields.  (Martin Pool)
238
 
 
239
 
  FEATURES:
240
 
 
241
 
    * ``branch`` and ``checkout`` can hard-link working tree files, which is
242
 
      faster and saves space.  (Aaron Bentley)
243
 
 
244
 
    * ``bzr send`` will now also look at the ``child_submit_to`` setting in
245
 
      the submit branch to determine the email address to send to. 
246
 
      (Jelmer Vernooij)
247
 
 
248
 
  IMPROVEMENTS:
249
 
 
250
 
    * BzrBranch._lefthand_history is faster on pack repos.  (Aaron Bentley)
251
 
 
252
 
    * Branch6.generate_revision_history is faster.  (Aaron Bentley)
253
 
 
254
 
    * Directory services can now be registered, allowing special URLs to be
255
 
      dereferenced into real URLs.  This is a generalization and cleanup of
256
 
      the lp: transport lookup.  (Aaron Bentley)
257
 
 
258
 
    * Merge directives that are automatically attached to emails have nicer
259
 
      filenames, based on branch-nick + revno. (Aaron Bentley)
260
 
 
261
 
    * ``push`` has a ``--revision`` option, to specify what revision to push up
262
 
      to.  (Daniel Watkins)
263
 
 
264
 
    * Significantly reducing execution time and network traffic for trivial 
265
 
      case of running ``bzr missing`` command for two identical branches.
266
 
      (Alexander Belchenko)
267
 
 
268
 
    * Speed up operations that look at the revision graph (such as 'bzr log').
269
 
      ``KnitPackRepositor.get_revision_graph`` uses ``Graph.iter_ancestry`` to
270
 
      extract the revision history. This allows filtering ghosts while
271
 
      stepping instead of needing to peek ahead. (John Arbash Meinel)
272
 
 
273
 
    * The ``hooks`` command lists installed hooks, to assist in debugging.
274
 
      (Daniel Watkins)
275
 
 
276
 
    * Updates to how ``annotate`` work. Should see a measurable improvement in
277
 
      performance and memory consumption for file with a lot of merges.
278
 
      Also, correctly handle when a line is introduced by both parents (it
279
 
      should be attributed to the first merge which notices this, and not
280
 
      to all subsequent merges.) (John Arbash Meinel)
281
 
 
282
 
  BUGFIXES:
283
 
 
284
 
    * Autopacking no longer holds the full set of inventory lines in
285
 
      memory while copying. For large repositories, this can amount to
286
 
      hundreds of MB of ram consumption.
287
 
      (Ian Clatworthy, John Arbash Meinel)
288
 
 
289
 
    * Cherrypicking when using ``--format=merge3`` now explictly excludes
290
 
      BASE lines. (John Arbash Meinel, #151731)
291
 
 
292
 
    * Disable plink's interactive prompt for password.
293
 
      (#107593, Dmitry Vasiliev)
294
 
 
295
 
    * Encode command line arguments from unicode to user_encoding before
296
 
      invoking external mail client in `bzr send` command.
297
 
      (#139318, Alexander Belchenko)
298
 
 
299
 
    * Fixed problem connecting to ``bzr+https://`` servers.
300
 
      (#198793, John Ferlito)
301
 
 
302
 
    * Improved error reporting in the Launchpad plugin. (Daniel Watkins,
303
 
      #196618)
304
 
 
305
 
    * Include quick-start-summary.svg file to python-based installer(s)
306
 
      for Windows. (#192924, Alexander Belchenko)
307
 
 
308
 
    * lca merge now respects specified files. (Aaron Bentley)
309
 
 
310
 
    * Make version-info --custom imply --all. (#195560, James Westby)
311
 
 
312
 
    * ``merge --preview`` now works for merges that add or modify
313
 
      symlinks (James Henstridge)
314
 
 
315
 
    * Redirecting the output from ``bzr merge`` (when the remembered
316
 
      location is used) now works. (John Arbash Meinel)
317
 
 
318
 
    * setup.py script explicitly checks for Python version.
319
 
      (Jari Aalto, Alexander Belchenko, #200569)
320
 
 
321
 
    * UnknownFormatErrors no longer refer to branches regardless of kind of
322
 
      unknown format. (Daniel Watkins, #173980)
323
 
 
324
 
    * Upgrade bundled ConfigObj to version 4.5.2, which properly quotes #
325
 
      signs, among other small improvements. (Matt Nordhoff, #86838)
326
 
 
327
 
    * Use correct indices when emitting LCA conflicts.  This fixes IndexError
328
 
      errors.  (Aaron Bentley, #196780)
329
 
 
330
 
  DOCUMENTATION:
331
 
 
332
 
    * Explained how to use ``version-info --custom`` in the User Guide.
333
 
      (Neil Martinsen-Burrell)
334
 
 
335
 
  API BREAKS:
336
 
 
337
 
    * Support for loading plugins from zip files and
338
 
      ``bzrlib.plugin.load_from_zip()`` function are deprecated.
339
 
      (Alexander Belchenko)
340
 
 
341
 
  TESTING:
342
 
 
343
 
    * The branch interface tests were invalid for branches using rich-root
344
 
      repositories because the empty string is not a valid file-id.
345
 
      (Robert Collins)
346
 
 
347
 
  INTERNALS:
348
 
 
349
 
    * ``Graph.iter_ancestry`` returns the ancestry of revision ids. Similar to
350
 
      ``Repository.get_revision_graph()`` except it includes ghosts and you can
351
 
      stop part-way through. (John Arbash Meinel)
352
 
 
353
 
    * New module ``tools/package_mf.py`` provide custom module finder for
354
 
      python packages (improves standard python library's modulefinder.py)
355
 
      used by ``setup.py`` script while building standalone bzr.exe.
356
 
      (Alexander Belchenko)
357
 
 
358
 
    * New remote method ``RemoteBzrDir.find_repositoryV2`` adding support for
359
 
      detecting external lookup support on remote repositories. This method is
360
 
      now attempted first when lookup up repositories, leading to an extra 
361
 
      round trip on older bzr smart servers. (Robert Collins)
362
 
 
363
 
    * Repository formats have a new supported-feature attribute
364
 
      ``supports_external_lookups`` used to indicate repositories which support
365
 
      falling back to other repositories when they have partial data.
366
 
      (Robert Collins)
367
 
 
368
 
    * ``Repository.get_revision_graph_with_ghosts`` and
369
 
      ``bzrlib.revision.(common_ancestor,MultipleRevisionSources,common_graph)``
370
 
      have been deprecated.  (John Arbash Meinel)
371
 
 
372
 
    * ``Tree.iter_changes`` is now a public API, replacing the work-in-progress
373
 
      ``Tree._iter_changes``. The api is now considered stable and ready for
374
 
      external users.  (Aaron Bentley)
375
 
 
376
 
    * The bzrdir format registry now accepts an ``alias`` keyword to
377
 
      register_metadir, used to indicate that a format name is an alias for
378
 
      some other format and thus should not be reported when describing the
379
 
      format. (Robert Collins)
380
 
 
381
 
 
382
 
bzr 1.2 2008-02-15
383
 
------------------
384
 
 
385
 
  BUG FIXES:
386
 
 
387
 
    * Fix failing test in Launchpad plugin. (Martin Pool)
388
 
 
389
 
 
390
 
bzr 1.2rc1 2008-02-13
391
 
---------------------
392
 
 
393
 
  NOTES WHEN UPGRADING:
394
 
  
395
 
    * Fetching via the smart protocol may need to reconnect once during a fetch
396
 
      if the remote server is running Bazaar 1.1 or earlier, because the client
397
 
      attempts to use more efficient requests that confuse older servers.  You
398
 
      may be required to re-enter a password or passphrase when this happens.
399
 
      This won't happen if the server is upgraded to Bazaar 1.2.
400
 
      (Andrew Bennetts)
401
 
 
402
 
  CHANGES:
403
 
 
404
 
    * Fetching via bzr+ssh will no longer fill ghosts by default (this is
405
 
      consistent with pack-0.92 fetching over SFTP). (Robert Collins)
406
 
 
407
 
    * Formatting of ``bzr plugins`` output is changed to be more human-
408
 
      friendly. Full path of plugins locations will be shown only with
409
 
      ``--verbose`` command-line option. (Alexander Belchenko)
410
 
 
411
 
    * ``merge`` now prefers to use the submit branch, but will fall back to
412
 
      parent branch.  For many users, this has no effect.  But some users who
413
 
      pull and merge on the same branch will notice a change.  This change
414
 
      makes it easier to work on a branch on two different machines, pulling
415
 
      between the machines, while merging from the upstream.
416
 
      ``merge --remember`` can now be used to set the submit_branch.
417
 
      (Aaron Bentley)
418
 
 
419
 
  FEATURES:
420
 
 
421
 
    * ``merge --preview`` produces a diff of the changes merge would make,
422
 
      but does not actually perform the merge.  (Aaron Bentley)
423
 
 
424
 
    * New smart method ``Repository.get_parent_map`` for getting revision
425
 
      parent data. This returns additional parent information topologically
426
 
      adjacent to the requested data to reduce round trip latency impacts.
427
 
      (Robert Collins)
428
 
 
429
 
    * New smart method, ``Repository.stream_revisions_chunked``, for fetching
430
 
      revision data that streams revision data via a chunked encoding.  This
431
 
      avoids buffering large amounts of revision data on the server and on the
432
 
      client, and sends less data to the server to request the revisions.
433
 
      (Andrew Bennetts, Robert Collins, #178353)
434
 
 
435
 
    * The launchpad plugin now handles lp urls of the form
436
 
      ``lp://staging/``, ``lp://demo/``, ``lp://dev/`` to use the appropriate
437
 
      launchpad instance to do the resolution of the branch identities.
438
 
      This is primarily of use to Launchpad developers, but can also
439
 
      be used by other users who want to try out Launchpad as
440
 
      a branch location without messing up their public Launchpad
441
 
      account.  Branches that are pushed to the staging environment
442
 
      have an expected lifetime of one day. (Tim Penhey)
443
 
 
444
 
  IMPROVEMENTS:
445
 
 
446
 
    * Creating a new branch no longer tries to read the entire revision-history
447
 
      unnecessarily over smart server operations. (Robert Collins)
448
 
 
449
 
    * Fetching between different repository formats with compatible models now
450
 
      takes advantage of the smart method to stream revisions.  (Andrew Bennetts)
451
 
 
452
 
    * The ``--coverage`` option is now global, rather specific to ``bzr
453
 
      selftest``.  (Andrew Bennetts)
454
 
 
455
 
    * The ``register-branch`` command will now use the public url of the branch
456
 
      containing the current directory, if one has been set and no explicit
457
 
      branch is provided.  (Robert Collins)
458
 
 
459
 
    * Tweak the ``reannotate`` code path to optimize the 2-parent case.
460
 
      Speeds up ``bzr annotate`` with a pack repository by approx 3:2.
461
 
      (John Arbash Meinel)
462
 
 
463
 
  BUGFIXES:
464
 
 
465
 
    * Calculate remote path relative to the shared medium in _SmartClient.  This
466
 
      is related to the problem in bug #124089.  (Andrew Bennetts)
467
 
 
468
 
    * Cleanly handle connection errors in smart protocol version two, the same
469
 
      way as they are handled by version one.  (Andrew Bennetts)
470
 
 
471
 
    * Clearer error when ``version-info --custom`` is used without
472
 
      ``--template`` (Lukáš Lalinský)
473
 
 
474
 
    * Don't raise UnavailableFeature during test setup when medusa is not
475
 
      available or tearDown is never called leading to nasty side effects.
476
 
      (#137823, Vincent Ladeuil)
477
 
 
478
 
    * If a plugin's test suite cannot be loaded, for example because of a syntax
479
 
      error in the tests, then ``selftest`` fails, rather than just printing 
480
 
      a warning.  (Martin Pool, #189771)
481
 
      
482
 
    * List possible values for BZR_SSH environment variable in env-variables
483
 
      help topic. (Alexander Belchenko, #181842)
484
 
 
485
 
    * New methods ``push_log_file`` and ``pop_log_file`` to intercept messages:
486
 
      popping the log redirection now precisely restores the previous state,
487
 
      which makes it easier to use bzr log output from other programs.
488
 
      TestCaseInTempDir no longer depends on a log redirection being established
489
 
      by the test framework, which lets bzr tests cleanly run from a normal
490
 
      unittest runner.
491
 
      (#124153, #124849, Martin Pool, Jonathan Lange)
492
 
 
493
 
    * ``pull --quiet`` is now more quiet, in particular a message is no longer
494
 
      printed when the remembered pull location is used. (James Westby,
495
 
      #185907)
496
 
 
497
 
    * ``reconfigure`` can safely be interrupted while fetching.
498
 
      (Aaron Bentley, #179316)
499
 
 
500
 
    * ``reconfigure`` preserves tags when converting to and from lightweight
501
 
      checkouts.  (Aaron Bentley, #182040)
502
 
 
503
 
    * Stop polluting /tmp when running selftest.
504
 
      (Vincent Ladeuil, #123623)
505
 
 
506
 
    * Switch from NFKC => NFC for normalization checks. NFC allows a few
507
 
      more characters which should be considered valid.
508
 
      (John Arbash Meinel, #185458)
509
 
 
510
 
    * The launchpad plugin now uses the ``edge`` xmlrpc server to avoid
511
 
      interacting badly with a bug on the launchpad side. (Robert Collins)
512
 
 
513
 
    * Unknown hostnames when connecting to a ``bzr://`` URL no longer cause
514
 
      tracebacks.  (Andrew Bennetts, #182849)
515
 
 
516
 
  API BREAKS:
517
 
 
518
 
    * Classes implementing Merge types like Merge3Merger must now accept (and
519
 
      honour) a do_merge flag in their constructor.  (Aaron Bentley)
520
 
 
521
 
    * ``Repository.add_inventory`` and ``add_revision`` now require the caller
522
 
      to previously take a write lock (and start a write group.)
523
 
      (Martin Pool)
524
 
 
525
 
  TESTING:
526
 
 
527
 
    * selftest now accepts --load-list <file> to load a test id list. This
528
 
      speeds up running the test suite on a limited set of tests.
529
 
      (Vincent Ladeuil)
530
 
 
531
 
  INTERNALS:
532
 
 
533
 
    * Add a new method ``get_result`` to graph search objects. The resulting
534
 
      ``SearchResult`` can be used to recreate the search later, which will
535
 
      be useful in reducing network traffic. (Robert Collins)
536
 
 
537
 
    * Use convenience function to check whether two repository handles 
538
 
      are referring to the same repository in ``Repository.get_graph``. 
539
 
      (Jelmer Vernooij, #187162)
540
 
 
541
 
    * Fetching now passes the find_ghosts flag through to the 
542
 
      ``InterRepository.missing_revision_ids`` call consistently for all
543
 
      repository types. This will enable faster missing revision discovery with
544
 
      bzr+ssh. (Robert Collins)
545
 
 
546
 
    * Fix error handling in Repository.insert_data_stream. (Lukas Lalinsky)
547
 
 
548
 
    * ``InterRepository.missing_revision_ids`` is now deprecated in favour of
549
 
      ``InterRepository.search_missing_revision_ids`` which returns a 
550
 
      ``bzrlib.graph.SearchResult`` suitable for making requests from the smart
551
 
      server. (Robert Collins)
552
 
 
553
 
    * New error ``NoPublicBranch`` for commands that need a public branch to
554
 
      operate. (Robert Collins)
555
 
 
556
 
    * New method ``iter_inventories`` on Repository for access to many
557
 
      inventories. This is primarily used by the ``revision_trees`` method, as
558
 
      direct access to inventories is discouraged. (Robert Collins)
559
 
 
560
 
    * New method ``next_with_ghosts`` on the Graph breadth-first-search objects
561
 
      which will split out ghosts and present parents into two separate sets,
562
 
      useful for code which needs to be aware of ghosts (e.g. fetching data
563
 
      cares about ghosts during revision selection). (Robert Collins)
564
 
 
565
 
    * Record a timestamp against each mutter to the trace file, relative to the
566
 
      first import of bzrlib.  (Andrew Bennetts)
567
 
 
568
 
    * ``Repository.get_data_stream`` is now deprecated in favour of
569
 
      ``Repository.get_data_stream_for_search`` which allows less network
570
 
      traffic when requesting data streams over a smart server. (Robert Collins)
571
 
 
572
 
    * ``RemoteBzrDir._get_tree_branch`` no longer triggers ``_ensure_real``,
573
 
      removing one round trip on many network operations. (Robert Collins)
574
 
 
575
 
    * RemoteTransport's ``recommended_page_size`` method now returns 64k, like
576
 
      SFTPTransport and HttpTransportBase.  (Andrew Bennetts)
577
 
 
578
 
    * Repository has a new method ``has_revisions`` which signals the presence
579
 
      of many revisions by returning a set of the revisions listed which are
580
 
      present. This can be done by index queries without reading data for parent
581
 
      revision names etc. (Robert Collins)
582
 
 
583
 
 
584
 
bzr 1.1 2008-01-15
585
 
------------------
586
 
 
587
 
(no changes from 1.1rc1)
588
 
 
589
 
bzr 1.1rc1 2008-01-05
590
 
---------------------
591
 
 
592
 
  CHANGES:
593
 
   
594
 
   * Dotted revision numbers have been revised. Instead of growing longer with
595
 
     nested branches the branch number just increases. (eg instead of 1.1.1.1.1
596
 
     we now report 1.2.1.) This helps scale long lived branches which have many
597
 
     feature branches merged between them. (John Arbash Meinel)
598
 
 
599
 
   * The syntax ``bzr diff branch1 branch2`` is no longer supported.
600
 
     Use ``bzr diff branch1 --new branch2`` instead. This change has
601
 
     been made to remove the ambiguity where ``branch2`` is in fact a
602
 
     specific file to diff within ``branch1``.
603
 
 
604
 
  FEATURES:
605
 
 
606
 
   * New option to use custom template-based formats in  ``bzr version-info``.
607
 
     (Lukáš Lalinský)
608
 
 
609
 
   * diff '--using' allows an external diff tool to be used for files.
610
 
     (Aaron Bentley)
611
 
 
612
 
   * New "lca" merge-type for fast everyday merging that also supports
613
 
     criss-cross merges.  (Aaron Bentley)
614
 
 
615
 
  IMPROVEMENTS:
616
 
 
617
 
   * ``annotate`` now doesn't require a working tree. (Lukáš Lalinský,
618
 
     #90049)
619
 
 
620
 
   * ``branch`` and ``checkout`` can now use files from a working tree to
621
 
     to speed up the process.  For checkout, this requires the new
622
 
     --files-from flag.  (Aaron Bentley)
623
 
 
624
 
   * ``bzr diff`` now sorts files in alphabetical order.  (Aaron Bentley)
625
 
 
626
 
   * ``bzr diff`` now works on branches without working trees. Tree-less
627
 
     branches can also be compared to each other and to working trees using
628
 
     the new diff options ``--old`` and ``--new``. Diffing between branches,
629
 
     with or without trees, now supports specific file filtering as well.
630
 
     (Ian Clatworthy, #6700)
631
 
 
632
 
   * ``bzr pack`` now orders revision texts in topological order, with newest
633
 
     at the start of the file, promoting linear reads for ``bzr log`` and the
634
 
     like. This partially fixes #154129. (Robert Collins)
635
 
 
636
 
   * Merge directives now fetch prerequisites from the target branch if
637
 
     needed.  (Aaron Bentley)
638
 
 
639
 
   * pycurl now handles digest authentication.
640
 
     (Vincent Ladeuil)
641
 
 
642
 
   * ``reconfigure`` can now convert from repositories.  (Aaron Bentley)
643
 
 
644
 
   * ``-l`` is now a short form for ``--limit`` in ``log``.  (Matt Nordhoff)
645
 
 
646
 
   * ``merge`` now warns when merge directives cause cherrypicks.
647
 
     (Aaron Bentley)
648
 
 
649
 
   * ``split`` now supported, to enable splitting large trees into smaller
650
 
     pieces.  (Aaron Bentley)
651
 
 
652
 
  BUGFIXES:
653
 
 
654
 
   * Avoid AttributeError when unlocking a pack repository when an error occurs.
655
 
     (Martin Pool, #180208)
656
 
 
657
 
   * Better handle short reads when processing multiple range requests.
658
 
     (Vincent Ladeuil, #179368)
659
 
 
660
 
   * build_tree acceleration uses the correct path when a file has been moved.
661
 
     (Aaron Bentley)
662
 
 
663
 
   * ``commit`` now succeeds when a checkout and its master branch share a
664
 
     repository.  (Aaron Bentley, #177592)
665
 
 
666
 
   * Fixed error reporting of unsupported timezone format in
667
 
     ``log --timezone``. (Lukáš Lalinský, #178722)
668
 
 
669
 
   * Fixed Unicode encoding error in ``ignored`` when the output is
670
 
     redirected to a pipe. (Lukáš Lalinský)
671
 
 
672
 
   * Fix traceback when sending large response bodies over the smart protocol
673
 
     on Windows. (Andrew Bennetts, #115781)
674
 
 
675
 
   * Fix ``urlutils.relative_url`` for the case of two ``file:///`` URLs
676
 
     pointed to different logical drives on Windows.
677
 
     (Alexander Belchenko, #90847)
678
 
 
679
 
   * HTTP test servers are now compatible with the http protocol version 1.1.
680
 
     (Vincent Ladeuil, #175524)
681
 
 
682
 
   * _KnitParentsProvider.get_parent_map now handles requests for ghosts
683
 
     correctly, instead of erroring or attributing incorrect parents to ghosts.
684
 
     (Aaron Bentley)
685
 
 
686
 
   * ``merge --weave --uncommitted`` now works.  (Aaron Bentley)
687
 
 
688
 
   * pycurl authentication handling was broken and incomplete. Fix handling of
689
 
     user:pass embedded in the urls.
690
 
     (Vincent Ladeuil, #177643)
691
 
 
692
 
   * Files inside non-directories are now handled like other conflict types.
693
 
     (Aaron Bentley, #177390)
694
 
 
695
 
   * ``reconfigure`` is able to convert trees into lightweight checkouts.
696
 
     (Aaron Bentley)
697
 
 
698
 
   * Reduce lockdir timeout to 0 when running ``bzr serve``.  (Andrew Bennetts,
699
 
     #148087)
700
 
 
701
 
   * Test that the old ``version_info_format`` functions still work, even
702
 
     though they are deprecated. (John Arbash Meinel, ShenMaq, #177872)
703
 
 
704
 
   * Transform failures no longer cause ImmortalLimbo errors (Aaron Bentley,
705
 
     #137681)
706
 
 
707
 
   * ``uncommit`` works even when the commit messages of revisions to be
708
 
     removed use characters not supported in the terminal encoding.
709
 
     (Aaron Bentley)
710
 
 
711
 
   * When dumb http servers return whole files instead of the requested ranges,
712
 
     read the remaining bytes by chunks to avoid overflowing network buffers.
713
 
     (Vincent Ladeuil, #175886)
714
 
 
715
 
  DOCUMENTATION:
716
 
 
717
 
   * Minor tweaks made to the bug tracker integration documentation.
718
 
     (Ian Clatworthy)
719
 
 
720
 
   * Reference material has now be moved out of the User Guide and added
721
 
     to the User Reference. The User Reference has gained 4 sections as
722
 
     a result: Authenication Settings, Configuration Settings, Conflicts
723
 
     and Hooks. All help topics are now dumped into text format in the
724
 
     doc/en/user-reference directory for those who like browsing that
725
 
     information in their editor. (Ian Clatworthy)
726
 
 
727
 
   * *Using Bazaar with Launchpad* tutorial added. (Ian Clatworthy)
728
 
 
729
 
  INTERNALS:
730
 
 
731
 
    * find_* methods available for BzrDirs, Branches and WorkingTrees.
732
 
      (Aaron Bentley)
733
 
 
734
 
    * Help topics can now be loaded from files. 
735
 
      (Ian Clatworthy, Alexander Belchenko)
736
 
 
737
 
    * get_parent_map now always provides tuples as its output.  (Aaron Bentley)
738
 
 
739
 
    * Parent Providers should now implement ``get_parent_map`` returning a
740
 
      dictionary instead of ``get_parents`` returning a list.
741
 
      ``Graph.get_parents`` is now deprecated. (John Arbash Meinel,
742
 
      Robert Collins)
743
 
 
744
 
    * Patience Diff now supports arbitrary python objects, as long as they
745
 
      support ``hash()``. (John Arbash Meinel)
746
 
 
747
 
    * Reduce selftest overhead to establish test names by memoization.
748
 
      (Vincent Ladeuil)
749
 
 
750
 
  API BREAKS:
751
 
 
752
 
  TESTING:
753
 
 
754
 
   * Modules can now customise their tests by defining a ``load_tests``
755
 
     attribute. ``pydoc bzrlib.tests.TestUtil.TestLoader.loadTestsFromModule``
756
 
     for the documentation on this attribute. (Robert Collins)
757
 
 
758
 
   * New helper function ``bzrlib.tests.condition_id_re`` which helps
759
 
     filter tests based on a regular expression search on the tests id.
760
 
     (Robert Collins)
761
 
    
762
 
   * New helper function ``bzrlib.tests.condition_isinstance`` which helps
763
 
     filter tests based on class. (Robert Collins)
764
 
    
765
 
   * New helper function ``bzrlib.tests.exclude_suite_by_condition`` which
766
 
     generalises the ``exclude_suite_by_re`` function. (Robert Collins)
767
 
 
768
 
   * New helper function ``bzrlib.tests.filter_suite_by_condition`` which
769
 
     generalises the ``filter_suite_by_re`` function. (Robert Collins)
770
 
 
771
 
   * New helper method ``bzrlib.tests.exclude_tests_by_re`` which gives a new
772
 
     TestSuite that does not contain tests from the input that matched a
773
 
     regular expression. (Robert Collins)
774
 
 
775
 
   * New helper method ``bzrlib.tests.randomize_suite`` which returns a
776
 
     randomized copy of the input suite. (Robert Collins)
777
 
 
778
 
   * New helper method ``bzrlib.tests.split_suite_by_re`` which splits a test
779
 
     suite into two according to a regular expression. (Robert Collins)
780
 
 
781
 
   * Parametrize all http tests for the transport implementations, the http
782
 
     protocol versions (1.0 and 1.1) and the authentication schemes.
783
 
     (Vincent Ladeuil) 
784
 
 
785
 
   * The ``exclude_pattern`` and ``random_order`` parameters to the function
786
 
     ``bzrlib.tests.filter_suite_by_re`` have been deprecated. (Robert Collins)
787
 
 
788
 
   * The method ``bzrlib.tests.sort_suite_by_re`` has been deprecated. It is 
789
 
     replaced by the new helper methods added in this release. (Robert Collins)
790
 
 
791
 
 
792
 
bzr 1.0 2007-12-14
793
 
------------------
794
 
 
795
 
  DOCUMENTATION:
796
 
 
797
 
   * More improvements and fixes to the User Guide.  (Ian Clatworthy)
798
 
 
799
 
   * Add information on cherrypicking/rebasing to the User Guide.
800
 
     (Ian Clatworthy)
801
 
 
802
 
   * Improve bug tracker integration documentation. (Ian Clatworthy)
803
 
 
804
 
   * Minor edits to ``Bazaar in five minutes`` from David Roberts and
805
 
     to the rebasing section of the User Guide from Aaron Bentley.
806
 
     (Ian Clatworthy)
807
 
 
808
 
 
809
 
bzr 1.0rc3 2007-12-11
810
 
---------------------
811
 
 
812
 
  CHANGES:
813
 
   
814
 
   * If a traceback occurs, users are now asked to report the bug 
815
 
     through Launchpad (https://bugs.launchpad.net/bzr/), rather than 
816
 
     by mail to the mailing list.
817
 
     (Martin Pool)
818
 
 
819
 
  BUGFIXES:
820
 
 
821
 
   * Fix Makefile rules for doc generation. (Ian Clatworthy, #175207)
822
 
 
823
 
   * Give more feedback during long http downloads by making readv deliver data
824
 
     as it arrives for urllib, and issue more requests for pycurl. High latency
825
 
     networks are better handled by urllib, the pycurl implementation give more
826
 
     feedback but also incur more latency.
827
 
     (Vincent Ladeuil, #173010)
828
 
 
829
 
   * Implement _make_parents_provider on RemoteRepository, allowing generating
830
 
     bundles against branches on a smart server.  (Andrew Bennetts, #147836)
831
 
 
832
 
  DOCUMENTATION:
833
 
 
834
 
   * Improved user guide.  (Ian Clatworthy)
835
 
 
836
 
   * The single-page quick reference guide is now available as a PDF.
837
 
     (Ian Clatworthy)
838
 
 
839
 
  INTERNALS:
840
 
 
841
 
    * readv urllib http implementation is now a real iterator above the
842
 
      underlying socket and deliver data as soon as it arrives. 'get' still
843
 
      wraps its output in a StringIO.
844
 
      (Vincent Ladeuil)
845
 
 
846
 
 
847
 
bzr 1.0rc2 2007-12-07
848
 
---------------------
849
 
 
850
 
  IMPROVEMENTS:
851
 
 
852
 
   * Added a --coverage option to selftest. (Andrew Bennetts)
853
 
 
854
 
   * Annotate merge (merge-type=weave) now supports cherrypicking.
855
 
     (Aaron Bentley)
856
 
 
857
 
   * ``bzr commit`` now doesn't print the revision number twice. (Matt
858
 
     Nordhoff, #172612)
859
 
 
860
 
   * New configuration option ``bugtracker_<tracker_abbrevation>_url`` to
861
 
     define locations of bug trackers that are not directly supported by
862
 
     bzr or a plugin. The URL will be treated as a template and ``{id}``
863
 
     placeholders will be replaced by specific bug IDs.  (Lukáš Lalinský)
864
 
 
865
 
   * Support logging single merge revisions with short and line log formatters.
866
 
     (Kent Gibson)
867
 
 
868
 
   * User Guide enhanced with suggested readability improvements from
869
 
     Matt Revell and corrections from John Arbash Meinel. (Ian Clatworthy)
870
 
 
871
 
   * Quick Start Guide renamed to Quick Start Card, moved down in
872
 
     the catalog, provided in pdf and png format and updated to refer
873
 
     to ``send`` instead of ``bundle``. (Ian Clatworthy, #165080)
874
 
 
875
 
   * ``switch`` can now be used on heavyweight checkouts as well as
876
 
     lightweight ones. After switching a heavyweight checkout, the
877
 
     local branch is a mirror/cache of the new bound branch and
878
 
     uncommitted changes in the working tree are merged. As a safety
879
 
     check, if there are local commits in a checkout which have not
880
 
     been committed to the previously bound branch, then ``switch``
881
 
     fails unless the ``--force`` option is given. This option is
882
 
     now also required if the branch a lightweight checkout is pointing
883
 
     to has been moved. (Ian Clatworthy)
884
 
 
885
 
  INTERNALS:
886
 
 
887
 
    * New -Dhttp debug option reports http connections, requests and responses.
888
 
      (Vincent Ladeuil)
889
 
 
890
 
    * New -Dmerge debug option, which emits merge plans for merge-type=weave.
891
 
 
892
 
  BUGFIXES:
893
 
 
894
 
   * Better error message when running ``bzr cat`` on a non-existant branch.
895
 
     (Lukáš Lalinský, #133782)
896
 
 
897
 
   * Catch OSError 17 (file exists) in final phase of tree transform and show
898
 
     filename to user.
899
 
     (Alexander Belchenko, #111758)
900
 
 
901
 
   * Catch ShortReadvErrors while using pycurl. Also make readv more robust by
902
 
     allowing multiple GET requests to be issued if too many ranges are
903
 
     required.
904
 
     (Vincent Ladeuil, #172701)
905
 
 
906
 
   * Check for missing basis texts when fetching from packs to packs.
907
 
     (John Arbash Meinel, #165290)
908
 
 
909
 
   * Fall back to showing e-mail in ``log --short/--line`` if the 
910
 
     committer/author has only e-mail. (Lukáš Lalinský, #157026)
911
 
 
912
 
  API BREAKS:
913
 
 
914
 
   * Deprecate not passing a ``location`` argument to commit reporters'
915
 
     ``started`` methods. (Matt Nordhoff)
916
 
 
917
 
 
918
 
bzr 1.0rc1 2007-11-30
919
 
---------------------
920
 
 
921
 
  NOTES WHEN UPGRADING:
922
 
 
923
 
   * The default repository format is now ``pack-0.92``.  This 
924
 
     default is used when creating new repositories with ``init`` and 
925
 
     ``init-repo``, and when branching over bzr+ssh or bzr+hpss. 
926
 
     (See https://bugs.launchpad.net/bugs/164626)
927
 
 
928
 
     This format can be read and written by Bazaar 0.92 and later, and 
929
 
     data can be transferred to and from older formats.
930
 
 
931
 
     To upgrade, please reconcile your repository (``bzr reconcile``), and then
932
 
     upgrade (``bzr upgrade``). 
933
 
     
934
 
     ``pack-0.92`` offers substantially better scaling and performance than the
935
 
     previous knits format. Some operations are slower where the code already
936
 
     had bad scaling characteristics under knits, the pack format makes such
937
 
     operations more visible as part of being more scalable overall. We will
938
 
     correct such operations over the coming releases and encourage the filing
939
 
     of bugs on any operation which you observe to be slower in a packs
940
 
     repository. One particular case that we do not intend to fix is pulling
941
 
     data from a pack repository into a knit repository over a high latency
942
 
     link;  downgrading such data requires reinsertion of the file texts, and
943
 
     this is a classic space/time tradeoff. The current implementation is
944
 
     conservative on memory usage because we need to support converting data
945
 
     from any tree without problems.  
946
 
     (Robert Collins, Martin Pool, #164476)
947
 
 
948
 
  CHANGES:
949
 
 
950
 
   * Disable detection of plink.exe as possible ssh vendor. Plink vendor
951
 
     still available if user selects it explicitly with BZR_SSH environment
952
 
     variable. (Alexander Belchenko, workaround for bug #107593)
953
 
 
954
 
   * The pack format is now accessible as "pack-0.92", or "pack-0.92-subtree" 
955
 
     to enable the subtree functions (for example, for bzr-svn).  
956
 
     See http://doc.bazaar-vcs.org/latest/developer/packrepo.html
957
 
     (Martin Pool)
958
 
 
959
 
  FEATURES:
960
 
 
961
 
   * New ``authentication.conf`` file holding the password or other credentials
962
 
     for remote servers. This can be used for ssh, sftp, smtp and other 
963
 
     supported transports.
964
 
     (Vincent Ladeuil)
965
 
 
966
 
   * New rich-root and rich-root-pack formats, recording the same data about
967
 
     tree roots that's recorded for all other directories.
968
 
     (Aaron Bentley, #164639)
969
 
 
970
 
   * ``pack-0.92`` repositories can now be reconciled.
971
 
     (Robert Collins, #154173)
972
 
 
973
 
   * ``switch`` command added for changing the branch a lightweight checkout
974
 
     is associated with and updating the tree to reflect the latest content
975
 
     accordingly. This command was previously part of the BzrTools plug-in.
976
 
     (Ian Clatworthy, Aaron Bentley, David Allouche)
977
 
 
978
 
   * ``reconfigure`` command can now convert branches, trees, or checkouts to
979
 
     lightweight checkouts.  (Aaron Bentley)
980
 
 
981
 
  PERFORMANCE:
982
 
 
983
 
   * Commit updates the state of the working tree via a delta rather than
984
 
     supplying entirely new basis trees. For commit of a single specified file
985
 
     this reduces the wall clock time for commit by roughly a 30%.
986
 
     (Robert Collins, Martin Pool)
987
 
 
988
 
   * Commit with many automatically found deleted paths no longer performs
989
 
     linear scanning for the children of those paths during inventory
990
 
     iteration. This should fix commit performance blowing out when many such
991
 
     paths occur during commit. (Robert Collins, #156491)
992
 
 
993
 
   * Fetch with pack repositories will no longer read the entire history graph.
994
 
     (Robert Collins, #88319)
995
 
 
996
 
   * Revert takes out an appropriate lock when reverting to a basis tree, and
997
 
     does not read the basis inventory twice. (Robert Collins)
998
 
 
999
 
   * Diff does not require an inventory to be generated on dirstate trees.
1000
 
     (Aaron Bentley, #149254)
1001
 
 
1002
 
   * New annotate merge (--merge-type=weave) implementation is fast on
1003
 
     versionedfiles withough cached annotations, e.g. pack-0.92.
1004
 
     (Aaron Bentley)
1005
 
 
1006
 
  IMPROVEMENTS:
1007
 
 
1008
 
   * ``bzr merge`` now warns when it encounters a criss-cross merge.
1009
 
     (Aaron Bentley)
1010
 
 
1011
 
   * ``bzr send`` now doesn't require the target e-mail address to be
1012
 
     specified on the command line if an interactive e-mail client is used.
1013
 
     (Lukáš Lalinský)
1014
 
 
1015
 
   * ``bzr tags`` now prints the revision number for each tag, instead of
1016
 
     the revision id, unless --show-ids is passed. In addition, tags can be
1017
 
     sorted chronologically instead of lexicographically with --sort=time.
1018
 
     (Adeodato Simó, #120231)
1019
 
 
1020
 
   * Windows standalone version of bzr is able to load system-wide plugins from
1021
 
     "plugins" subdirectory in installation directory. In addition standalone
1022
 
     installer write to the registry (HKLM\SOFTWARE\Bazaar) useful info 
1023
 
     about paths and bzr version. (Alexander Belchenko, #129298)
1024
 
 
1025
 
  DOCUMENTATION:
1026
 
 
1027
 
  BUG FIXES:
1028
 
 
1029
 
   * A progress bar has been added for knitpack -> knitpack fetching.
1030
 
     (Robert Collins, #157789, #159147)
1031
 
 
1032
 
   * Branching from a branch via smart server now preserves the repository
1033
 
     format. (Andrew Bennetts,  #164626)
1034
 
     
1035
 
   * ``commit`` is now able to invoke an external editor in a non-ascii
1036
 
     directory. (Daniel Watkins, #84043)
1037
 
 
1038
 
   * Catch connection errors for ftp.
1039
 
     (Vincent Ladeuil, #164567)
1040
 
 
1041
 
   * ``check`` no longer reports spurious unreferenced text versions.
1042
 
     (Robert Collins, John A Meinel, #162931, #165071)
1043
 
 
1044
 
   * Conflicts are now resolved recursively by ``revert``.
1045
 
     (Aaron Bentley, #102739)
1046
 
 
1047
 
   * Detect invalid transport reuse attempts by catching invalid URLs.
1048
 
     (Vincent Ladeuil, #161819)
1049
 
 
1050
 
   * Deleting a file without removing it shows a correct diff, not a traceback.
1051
 
     (Aaron Bentley)
1052
 
 
1053
 
   * Do no use timeout in HttpServer anymore.
1054
 
     (Vincent Ladeuil, #158972).
1055
 
 
1056
 
   * Don't catch the exceptions related to the http pipeline status before
1057
 
     retrying an http request or some programming errors may be masked.
1058
 
     (Vincent Ladeuil, #160012)
1059
 
 
1060
 
   * Fix ``bzr rm`` to not delete modified and ignored files.
1061
 
     (Lukáš Lalinský, #172598)
1062
 
 
1063
 
   * Fix exception when revisionspec contains merge revisons but log
1064
 
     formatter doesn't support merge revisions. (Kent Gibson, #148908)
1065
 
 
1066
 
   * Fix exception when ScopeReplacer is assigned to before any members have
1067
 
     been retrieved.  (Aaron Bentley)
1068
 
 
1069
 
   * Fix multiple connections during checkout --lightweight.
1070
 
     (Vincent Ladeuil, #159150)
1071
 
 
1072
 
   * Fix possible error in insert_data_stream when copying between 
1073
 
     pack repositories over bzr+ssh or bzr+http.  
1074
 
     KnitVersionedFile.get_data_stream now makes sure that requested
1075
 
     compression parents are sent before any delta hunks that depend 
1076
 
     on them.
1077
 
     (Martin Pool, #164637)
1078
 
 
1079
 
   * Fix typo in limiting offsets coalescing for http, leading to
1080
 
     whole files being downloaded instead of parts.
1081
 
     (Vincent Ladeuil, #165061)
1082
 
 
1083
 
   * FTP server errors don't error in the error handling code.
1084
 
     (Robert Collins, #161240)
1085
 
 
1086
 
   * Give a clearer message when a pull fails because the source needs
1087
 
     to be reconciled.
1088
 
     (Martin Pool, #164443)
1089
 
 
1090
 
   * It is clearer when a plugin cannot be loaded because of its name, and a
1091
 
     suggestion for an acceptable name is given. (Daniel Watkins, #103023)
1092
 
 
1093
 
   * Leave port as None in transport objects if user doesn't
1094
 
     specify a port in urls.
1095
 
     (vincent Ladeuil, #150860)
1096
 
 
1097
 
   * Make sure Repository.fetch(self) is properly a no-op for all
1098
 
     Repository implementations. (John Arbash Meinel, #158333)
1099
 
 
1100
 
   * Mark .bzr directories as "hidden" on Windows.
1101
 
     (Alexander Belchenko, #71147)
1102
 
 
1103
 
   * ``merge --uncommitted`` can now operate on a single file.
1104
 
     (Aaron Bentley, Lukáš Lalinský, #136890)
1105
 
 
1106
 
   * Obsolete packs are now cleaned up by pack and autopack operations.
1107
 
     (Robert Collins, #153789)
1108
 
 
1109
 
   * Operations pulling data from a smart server where the underlying
1110
 
     repositories are not both annotated/both unannotated will now work.
1111
 
     (Robert Collins, #165304).
1112
 
 
1113
 
   * Reconcile now shows progress bars. (Robert Collins, #159351)
1114
 
 
1115
 
   * ``RemoteBranch`` was not initializing ``self._revision_id_to_revno_map``
1116
 
     properly. (John Arbash Meinel, #162486)
1117
 
 
1118
 
   * Removing an already-removed file reports the file does not exist. (Daniel
1119
 
     Watkins, #152811)
1120
 
 
1121
 
   * Rename on Windows is able to change filename case.
1122
 
     (Alexander Belchenko, #77740)
1123
 
 
1124
 
   * Return error instead of a traceback for ``bzr log -r0``.
1125
 
     (Kent Gibson, #133751)
1126
 
 
1127
 
   * Return error instead of a traceback when bzr is unable to create
1128
 
     symlink on some platforms (e.g. on Windows).
1129
 
     (Alexander Belchenko, workaround for #81689)
1130
 
 
1131
 
   * Revert doesn't crash when restoring a single file from a deleted
1132
 
     directory. (Aaron Bentley)
1133
 
 
1134
 
   * Stderr output via logging mechanism now goes through encoded wrapper
1135
 
     and no more uses utf-8, but terminal encoding instead. So all unicode
1136
 
     strings now should be readable in non-utf-8 terminal.
1137
 
     (Alexander Belchenko, #54173)
1138
 
 
1139
 
   * The error message when ``move --after`` should be used makes how to do so
1140
 
     clearer. (Daniel Watkins, #85237)
1141
 
 
1142
 
   * Unicode-safe output from ``bzr info``. The output will be encoded
1143
 
     using the terminal encoding and unrepresentable characters will be
1144
 
     replaced by '?'. (Lukáš Lalinský, #151844)
1145
 
 
1146
 
   * Working trees are no longer created when pushing into a local no-trees
1147
 
     repo. (Daniel Watkins, #50582)
1148
 
 
1149
 
   * Upgrade util/configobj to version 4.4.0.
1150
 
     (Vincent Ladeuil, #151208).
1151
 
 
1152
 
   * Wrap medusa ftp test server as an FTPServer feature.
1153
 
     (Vincent Ladeuil, #157752)
1154
 
 
1155
 
  API BREAKS:
1156
 
 
1157
 
   * ``osutils.backup_file`` is deprecated. Actually it's not used in bzrlib
1158
 
     during very long time. (Alexander Belchenko)
1159
 
 
1160
 
   * The return value of
1161
 
     ``VersionedFile.iter_lines_added_or_present_in_versions`` has been
1162
 
     changed. Previously it was an iterator of lines, now it is an iterator of
1163
 
     (line, version_id) tuples. This change has been made to aid reconcile and
1164
 
     fetch operations. (Robert Collins)
1165
 
 
1166
 
   * ``bzrlib.repository.get_versioned_file_checker`` is now private.
1167
 
     (Robert Collins)
1168
 
 
1169
 
   * The Repository format registry default has been removed; it was previously
1170
 
     obsoleted by the bzrdir format default, which implies a default repository
1171
 
     format.
1172
 
     (Martin Pool)
1173
 
 
1174
 
  INTERNALS:
1175
 
 
1176
 
   * Added ``ContainerSerialiser`` and ``ContainerPushParser`` to
1177
 
     ``bzrlib.pack``.  These classes provide more convenient APIs for generating
1178
 
     and parsing containers from streams rather than from files.  (Andrew
1179
 
     Bennetts)
1180
 
 
1181
 
   * New module ``lru_cache`` providing a cache for use by tasks that need
1182
 
     semi-random access to large amounts of data. (John A Meinel)
1183
 
 
1184
 
   * InventoryEntry.diff is now deprecated.  Please use diff.DiffTree instead.
1185
 
 
1186
 
  TESTING:
1187
 
 
1188
 
 
1189
 
bzr 0.92 2007-11-05
1190
 
-------------------
1191
 
 
1192
 
  CHANGES:
1193
 
 
1194
 
  * New uninstaller on Win32.  (Alexander Belchenko)
1195
 
 
1196
 
 
1197
 
bzr 0.92rc1 2007-10-29
1198
 
----------------------
1199
 
 
1200
 
  NOTES WHEN UPGRADING:
1201
 
 
1202
 
  CHANGES:
1203
 
  
1204
 
   * ``bzr`` now returns exit code 4 if an internal error occurred, and 
1205
 
     3 if a normal error occurred.  (Martin Pool)
1206
 
 
1207
 
   * ``pull``, ``merge`` and ``push`` will no longer silently correct some
1208
 
     repository index errors that occured as a result of the Weave disk format.
1209
 
     Instead the ``reconcile`` command needs to be run to correct those
1210
 
     problems if they exist (and it has been able to fix most such problems
1211
 
     since bzr 0.8). Some new problems have been identified during this release
1212
 
     and you should run ``bzr check`` once on every repository to see if you
1213
 
     need to reconcile. If you cannot ``pull`` or ``merge`` from a remote
1214
 
     repository due to mismatched parent errors - a symptom of index errors -
1215
 
     you should simply take a full copy of that remote repository to a clean
1216
 
     directory outside any local repositories, then run reconcile on it, and
1217
 
     finally pull from it locally. (And naturally email the repositories owner
1218
 
     to ask them to upgrade and run reconcile).
1219
 
     (Robert Collins)
1220
 
 
1221
 
  FEATURES:
1222
 
 
1223
 
   * New ``knitpack-experimental`` repository format. This is interoperable with
1224
 
     the ``dirstate-tags`` format but uses a smarter storage design that greatly
1225
 
     speeds up many operations, both local and remote. This new format can be
1226
 
     used as an option to the ``init``, ``init-repository`` and ``upgrade``
1227
 
     commands. See http://doc.bazaar-vcs.org/0.92/developers/knitpack.html
1228
 
     for further details. (Robert Collins)
1229
 
 
1230
 
   * For users of bzr-svn (and those testing the prototype subtree support) that
1231
 
     wish to try packs, a new ``knitpack-subtree-experimental`` format has also
1232
 
     been added. This is interoperable with the ``dirstate-subtrees`` format.
1233
 
     (Robert Collins)
1234
 
 
1235
 
   * New ``reconfigure`` command. (Aaron Bentley)
1236
 
 
1237
 
   * New ``revert --forget-merges`` command, which removes the record of a pending 
1238
 
     merge without affecting the working tree contents.  (Martin Pool)
1239
 
 
1240
 
   * New ``bzr_remote_path`` configuration variable allows finer control of
1241
 
     remote bzr locations than BZR_REMOTE_PATH environment variable.
1242
 
     (Aaron Bentley)
1243
 
 
1244
 
   * New ``launchpad-login`` command to tell Bazaar your Launchpad
1245
 
     user ID.  This can then be used by other functions of the
1246
 
     Launchpad plugin. (James Henstridge)
1247
 
 
1248
 
  PERFORMANCE:
1249
 
 
1250
 
   * Commit in quiet mode is now slightly faster as the information to
1251
 
     output is no longer calculated. (Ian Clatworthy)
1252
 
 
1253
 
   * Commit no longer checks for new text keys during insertion when the
1254
 
     revision id was deterministically unique. (Robert Collins)
1255
 
 
1256
 
   * Committing a change which is not a merge and does not change the number of
1257
 
     files in the tree is faster by utilising the data about whether files are
1258
 
     changed to determine if the tree is unchanged rather than recalculating
1259
 
     it at the end of the commit process. (Robert Collins)
1260
 
 
1261
 
   * Inventory serialisation no longer double-sha's the content.
1262
 
     (Robert Collins)
1263
 
 
1264
 
   * Knit text reconstruction now avoids making copies of the lines list for
1265
 
     interim texts when building a single text. The new ``apply_delta`` method
1266
 
     on ``KnitContent`` aids this by allowing modification of the revision id
1267
 
     such objects represent. (Robert Collins)
1268
 
 
1269
 
   * Pack indices are now partially parsed for specific key lookup using a
1270
 
     bisection approach. (Robert Collins)
1271
 
 
1272
 
   * Partial commits are now approximately 40% faster by walking over the
1273
 
     unselected current tree more efficiently. (Robert Collins)
1274
 
 
1275
 
   * XML inventory serialisation takes 20% less time while being stricter about
1276
 
     the contents. (Robert Collins)
1277
 
 
1278
 
   * Graph ``heads()`` queries have been fixed to no longer access all history
1279
 
     unnecessarily. (Robert Collins)
1280
 
 
1281
 
  IMPROVEMENTS:
1282
 
 
1283
 
   * ``bzr+https://`` smart server across https now supported. 
1284
 
     (John Ferlito, Martin Pool, #128456)
1285
 
 
1286
 
   * Mutt is now a supported mail client; set ``mail_client=mutt`` in your
1287
 
     bazaar.conf and ``send`` will use mutt. (Keir Mierle)
1288
 
 
1289
 
   * New option ``-c``/``--change`` for ``merge`` command for cherrypicking 
1290
 
     changes from one revision. (Alexander Belchenko, #141368)
1291
 
 
1292
 
   * Show encodings, locale and list of plugins in the traceback message.
1293
 
     (Martin Pool, #63894)
1294
 
 
1295
 
   * Experimental directory formats can now be marked with
1296
 
     ``experimental = True`` during registration. (Ian Clatworthy)
1297
 
 
1298
 
  DOCUMENTATION:
1299
 
 
1300
 
   * New *Bazaar in Five Minutes* guide.  (Matthew Revell)
1301
 
 
1302
 
   * The hooks reference documentation is now converted to html as expected.
1303
 
     (Ian Clatworthy)
1304
 
 
1305
 
  BUG FIXES:
1306
 
 
1307
 
   * Connection error reporting for the smart server has been fixed to
1308
 
     display a user friendly message instead of a traceback.
1309
 
     (Ian Clatworthy, #115601)
1310
 
 
1311
 
   * Make sure to use ``O_BINARY`` when opening files to check their
1312
 
     sha1sum. (Alexander Belchenko, John Arbash Meinel, #153493)
1313
 
 
1314
 
   * Fix a problem with Win32 handling of the executable bit.
1315
 
     (John Arbash Meinel, #149113)
1316
 
 
1317
 
   * ``bzr+ssh://`` and ``sftp://`` URLs that do not specify ports explicitly
1318
 
     no longer assume that means port 22.  This allows people using OpenSSH to
1319
 
     override the default port in their ``~/.ssh/config`` if they wish.  This
1320
 
     fixes a bug introduced in bzr 0.91.  (Andrew Bennetts, #146715)
1321
 
 
1322
 
   * Commands reporting exceptions can now be profiled and still have their
1323
 
     data correctly dumped to a file. For example, a ``bzr commit`` with
1324
 
     no changes still reports the operation as pointless but doing so no
1325
 
     longer throws away the profiling data if this command is run with
1326
 
     ``--lsprof-file callgrind.out.ci`` say. (Ian Clatworthy)
1327
 
 
1328
 
   * Fallback to ftp when paramiko is not installed and sftp can't be used for
1329
 
     ``tests/commands`` so that the test suite is still usable without
1330
 
     paramiko.
1331
 
     (Vincent Ladeuil, #59150)
1332
 
 
1333
 
   * Fix commit ordering in corner case. (Aaron Bentley, #94975)
1334
 
 
1335
 
   * Fix long standing bug in partial commit when there are renames 
1336
 
     left in tree. (Robert Collins, #140419)
1337
 
 
1338
 
   * Fix selftest semi-random noise during http related tests.
1339
 
     (Vincent Ladeuil, #140614)
1340
 
 
1341
 
   * Fix typo in ftp.py making the reconnection fail on temporary errors.
1342
 
     (Vincent Ladeuil, #154259)
1343
 
 
1344
 
   * Fix failing test by comparing real paths to cover the case where the TMPDIR
1345
 
     contains a symbolic link.
1346
 
     (Vincent Ladeuil, #141382).
1347
 
 
1348
 
   * Fix log against smart server branches that don't support tags.
1349
 
     (James Westby, #140615)
1350
 
 
1351
 
   * Fix pycurl http implementation by defining error codes from
1352
 
     pycurl instead of relying on an old curl definition.
1353
 
     (Vincent Ladeuil, #147530)
1354
 
 
1355
 
   * Fix 'unprintable error' message when displaying BzrCheckError and 
1356
 
     some other exceptions on Python 2.5.
1357
 
     (Martin Pool, #144633)
1358
 
 
1359
 
   * Fix ``Inventory.copy()`` and add test for it. (Jelmer Vernooij)
1360
 
 
1361
 
   * Handles default value for ListOption in cmd_commit.
1362
 
     (Vincent Ladeuil, #140432)
1363
 
 
1364
 
   * HttpServer and FtpServer need to be closed properly or a listening socket
1365
 
     will remain opened.
1366
 
     (Vincent Ladeuil, #140055)
1367
 
 
1368
 
   * Monitor the .bzr directory created in the top level test
1369
 
     directory to detect leaking tests.
1370
 
     (Vincent Ladeuil, #147986)
1371
 
 
1372
 
   * The basename, not the full path, is now used when checking whether
1373
 
     the profiling dump file begins with ``callgrind.out`` or not. This
1374
 
     fixes a bug reported by Aaron Bentley on IRC. (Ian Clatworthy)
1375
 
 
1376
 
   * Trivial fix for invoking command ``reconfigure`` without arguments.
1377
 
     (Rob Weir, #141629)
1378
 
 
1379
 
   * ``WorkingTree.rename_one`` will now raise an error if normalisation of the
1380
 
     new path causes bzr to be unable to access the file. (Robert Collins)
1381
 
 
1382
 
   * Correctly detect a NoSuchFile when using a filezilla server. (Gary van der
1383
 
     Merwe)
1384
 
 
1385
 
  API BREAKS:
1386
 
 
1387
 
   * ``bzrlib.index.GraphIndex`` now requires a size parameter to the
1388
 
     constructor, for enabling bisection searches. (Robert Collins)
1389
 
 
1390
 
   * ``CommitBuilder.record_entry_contents`` now requires the root entry of a
1391
 
     tree be supplied to it, previously failing to do so would trigger a
1392
 
     deprecation warning. (Robert Collins)
1393
 
 
1394
 
   * ``KnitVersionedFile.add*`` will no longer cache added records even when
1395
 
     enable_cache() has been called - the caching feature is now exclusively for
1396
 
     reading existing data. (Robert Collins)
1397
 
 
1398
 
   * ``ReadOnlyLockError`` is deprecated; ``LockFailed`` is usually more 
1399
 
     appropriate.  (Martin Pool)
1400
 
 
1401
 
   * Removed ``bzrlib.transport.TransportLogger`` - please see the new
1402
 
     ``trace+`` transport instead. (Robert Collins)
1403
 
 
1404
 
   * Removed previously deprecated varargs interface to ``TestCase.run_bzr`` and
1405
 
     deprecated methods ``TestCase.capture`` and ``TestCase.run_bzr_captured``.
1406
 
     (Martin Pool)
1407
 
 
1408
 
   * Removed previous deprecated ``basis_knit`` parameter to the
1409
 
     ``KnitVersionedFile`` constructor. (Robert Collins)
1410
 
 
1411
 
   * Special purpose method ``TestCase.run_bzr_decode`` is moved to the test_non_ascii 
1412
 
     class that needs it.
1413
 
     (Martin Pool)
1414
 
 
1415
 
   * The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
1416
 
     ``KnitRepository`` by parameters to the constructor. (Robert Collins)
1417
 
 
1418
 
   * The ``VersionedFile`` interface now allows content checks to be bypassed
1419
 
     by supplying check_content=False.  This saves nearly 30% of the minimum
1420
 
     cost to store a version of a file. (Robert Collins)
1421
 
 
1422
 
   * Tree's with bad state such as files with no length or sha will no longer
1423
 
     be silently accepted by the repository XML serialiser. To serialise
1424
 
     inventories without such data, pass working=True to write_inventory.
1425
 
     (Robert Collins)
1426
 
 
1427
 
   * ``VersionedFile.fix_parents`` has been removed as a harmful API.
1428
 
     ``VersionedFile.join`` will no longer accept different parents on either
1429
 
     side of a join - it will either ignore them, or error, depending on the
1430
 
     implementation. See notes when upgrading for more information.
1431
 
     (Robert Collins)
1432
 
 
1433
 
  INTERNALS:
1434
 
 
1435
 
   * ``bzrlib.transport.Transport.put_file`` now returns the number of bytes
1436
 
     put by the method call, to allow avoiding stat-after-write or
1437
 
     housekeeping in callers. (Robert Collins)
1438
 
 
1439
 
   * ``bzrlib.xml_serializer.Serializer`` is now responsible for checking that
1440
 
     mandatory attributes are present on serialisation and deserialisation.
1441
 
     This fixes some holes in API usage and allows better separation between
1442
 
     physical storage and object serialisation. (Robert Collins)
1443
 
 
1444
 
   * New class ``bzrlib.errors.InternalBzrError`` which is just a convenient
1445
 
     shorthand for deriving from BzrError and setting internal_error = True.
1446
 
     (Robert Collins)
1447
 
 
1448
 
   * New method ``bzrlib.mutabletree.update_to_one_parent_via_delta`` for
1449
 
     moving the state of a parent tree to a new version via a delta rather than
1450
 
     a complete replacement tree. (Robert Collins)
1451
 
 
1452
 
   * New method ``bzrlib.osutils.minimum_path_selection`` useful for removing
1453
 
     duplication from user input, when a user mentions both a path and an item
1454
 
     contained within that path. (Robert Collins)
1455
 
 
1456
 
   * New method ``bzrlib.repository.Repository.is_write_locked`` useful for
1457
 
     determining if a repository is write locked. (Robert Collins)
1458
 
 
1459
 
   * New method on ``bzrlib.tree.Tree`` ``path_content_summary`` provides a
1460
 
     tuple containing the key information about a path for commit processing
1461
 
     to complete. (Robert Collins)
1462
 
 
1463
 
   * New method on xml serialisers, write_inventory_to_lines, which matches the
1464
 
     API used by knits for adding content. (Robert Collins)
1465
 
 
1466
 
   * New module ``bzrlib.bisect_multi`` with generic multiple-bisection-at-once
1467
 
     logic, currently only available for byte-based lookup
1468
 
     (``bisect_multi_bytes``). (Robert Collins)
1469
 
 
1470
 
   * New helper ``bzrlib.tuned_gzip.bytes_to_gzip`` which takes a byte string
1471
 
     and returns a gzipped version of the same. This is used to avoid a bunch
1472
 
     of api friction during adding of knit hunks. (Robert Collins)
1473
 
 
1474
 
   * New parameter on ``bzrlib.transport.Transport.readv``
1475
 
     ``adjust_for_latency`` which changes readv from returning strictly the
1476
 
     requested data to inserted return larger ranges and in forward read order
1477
 
     to reduce the effect of network latency. (Robert Collins)
1478
 
 
1479
 
   * New parameter yield_parents on ``Inventory.iter_entries_by_dir`` which
1480
 
     causes the parents of a selected id to be returned recursively, so all the
1481
 
     paths from the root down to each element of selected_file_ids are
1482
 
     returned. (Robert Collins)
1483
 
 
1484
 
   * Knit joining has been enhanced to support plain to annotated conversion
1485
 
     and annotated to plain conversion. (Ian Clatworthy)
1486
 
 
1487
 
   * The CommitBuilder method ``record_entry_contents`` now returns summary
1488
 
     information about the effect of the commit on the repository. This tuple
1489
 
     contains an inventory delta item if the entry changed from the basis, and a
1490
 
     boolean indicating whether a new file graph node was recorded.
1491
 
     (Robert Collins)
1492
 
 
1493
 
   * The python path used in the Makefile can now be overridden.
1494
 
     (Andrew Bennetts, Ian Clatworthy)
1495
 
 
1496
 
  TESTING:
1497
 
 
1498
 
   * New transport implementation ``trace+`` which is useful for testing,
1499
 
     logging activity taken to its _activity attribute. (Robert Collins)
1500
 
 
1501
 
   * When running bzr commands within the test suite, internal exceptions are
1502
 
     not caught and reported in the usual way, but rather allowed to propagate
1503
 
     up and be visible to the test suite.  A new API ``run_bzr_catch_user_errors``
1504
 
     makes this behavior available to other users.
1505
 
     (Martin Pool)
1506
 
 
1507
 
   * New method ``TestCase.call_catch_warnings`` for testing methods that 
1508
 
     raises a Python warning.  (Martin Pool)
1509
 
 
1510
 
 
1511
 
bzr 0.91 2007-09-26
1512
 
-------------------
1513
 
 
1514
 
  BUG FIXES:
1515
 
 
1516
 
   * Print a warning instead of aborting the ``python setup.py install``
1517
 
     process if building of a C extension is not possible.
1518
 
     (Lukáš Lalinský, Alexander Belchenko)
1519
 
 
1520
 
   * Fix commit ordering in corner case (Aaron Bentley, #94975)
1521
 
 
1522
 
   * Fix ''bzr info bzr://host/'' and other operations on ''bzr://' URLs with
1523
 
     an implicit port.  We were incorrectly raising PathNotChild due to
1524
 
     inconsistent treatment of the ''_port'' attribute on the Transport object.
1525
 
     (Andrew Bennetts, #133965)
1526
 
 
1527
 
   * Make RemoteRepository.sprout cope gracefully with servers that don't
1528
 
     support the ``Repository.tarball`` request.
1529
 
     (Andrew Bennetts)
1530
 
 
1531
 
 
1532
 
bzr 0.91rc2 2007-09-11
1533
 
----------------------
1534
 
 
1535
 
   * Replaced incorrect tarball for previous release; a debug statement was left 
1536
 
     in bzrlib/remote.py.
1537
 
 
1538
 
 
1539
 
bzr 0.91rc1 2007-09-11
1540
 
----------------------
1541
 
 
1542
 
  CHANGES:
1543
 
 
1544
 
   * The default branch and repository format has changed to 
1545
 
     ``dirstate-tags``, so tag commands are active by default.
1546
 
     This format is compatible with Bazaar 0.15 and later.
1547
 
     This incidentally fixes bug #126141.
1548
 
     (Martin Pool)
1549
 
 
1550
 
   * ``--quiet`` or ``-q`` is no longer a global option. If present, it
1551
 
     must now appear after the command name. Scripts doing things like
1552
 
     ``bzr -q missing`` need to be rewritten as ``bzr missing -q``.
1553
 
     (Ian Clatworthy)
1554
 
 
1555
 
  FEATURES:
1556
 
 
1557
 
   * New option ``--author`` in ``bzr commit`` to specify the author of the
1558
 
     change, if it's different from the committer. ``bzr log`` and
1559
 
     ``bzr annotate`` display the author instead of the committer.
1560
 
     (Lukáš Lalinský)
1561
 
 
1562
 
   * In addition to global options and command specific options, a set of
1563
 
     standard options are now supported. Standard options are legal for
1564
 
     all commands. The initial set of standard options are:
1565
 
     
1566
 
     * ``--help`` or ``-h`` - display help message
1567
 
     * ``--verbose`` or ``-v`` - display additional information
1568
 
     * ``--quiet``  or ``-q`` - only output warnings and errors.
1569
 
 
1570
 
     Unlike global options, standard options can be used in aliases and
1571
 
     may have command-specific help. (Ian Clatworthy)
1572
 
 
1573
 
   * Verbosity level processing has now been unified. If ``--verbose``
1574
 
     or ``-v`` is specified on the command line multiple times, the
1575
 
     verbosity level is made positive the first time then increased.
1576
 
     If ``--quiet`` or ``-q`` is specified on the command line
1577
 
     multiple times, the verbosity level is made negative the first
1578
 
     time then decreased. To get the default verbosity level of zero,
1579
 
     either specify none of the above , ``--no-verbose`` or ``--no-quiet``.
1580
 
     Note that most commands currently ignore the magnitude of the
1581
 
     verbosity level but do respect *quiet vs normal vs verbose* when
1582
 
     generating output. (Ian Clatworthy)
1583
 
 
1584
 
   * ``Branch.hooks`` now supports ``pre_commit`` hook. The hook's signature
1585
 
     is documented in BranchHooks constructor. (Nam T. Nguyen, #102747)
1586
 
 
1587
 
   * New ``Repository.stream_knit_data_for_revisions`` request added to the
1588
 
     network protocol for greatly reduced roundtrips when retrieving a set of
1589
 
     revisions. (Andrew Bennetts)
1590
 
 
1591
 
  BUG FIXES:
1592
 
 
1593
 
   * ``bzr plugins`` now lists the version number for each plugin in square
1594
 
     brackets after the path. (Robert Collins, #125421)
1595
 
 
1596
 
   * Pushing, pulling and branching branches with subtree references was not
1597
 
     copying the subtree weave, preventing the file graph from being accessed
1598
 
     and causing errors in commits in clones. (Robert Collins)
1599
 
 
1600
 
   * Suppress warning "integer argument expected, got float" from Paramiko,
1601
 
     which sometimes caused false test failures.  (Martin Pool)
1602
 
 
1603
 
   * Fix bug in bundle 4 that could cause attempts to write data to wrong
1604
 
     versionedfile.  (Aaron Bentley)
1605
 
 
1606
 
   * Diffs generated using "diff -p" no longer break the patch parser.
1607
 
     (Aaron Bentley)
1608
 
 
1609
 
   * get_transport treats an empty possible_transports list the same as a non-
1610
 
     empty one.  (Aaron Bentley)
1611
 
 
1612
 
   * patch verification for merge directives is reactivated, and works with
1613
 
     CRLF and CR files.  (Aaron Bentley)
1614
 
 
1615
 
   * Accept ..\ as a path in revision specifiers. This fixes for example
1616
 
     "-r branch:..\other-branch" on Windows.  (Lukáš Lalinský) 
1617
 
 
1618
 
   * ``BZR_PLUGIN_PATH`` may now contain trailing slashes.
1619
 
     (Blake Winton, #129299)
1620
 
 
1621
 
   * man page no longer lists hidden options (#131667, Aaron Bentley)
1622
 
 
1623
 
   * ``uncommit --help`` now explains the -r option adequately.  (Daniel
1624
 
     Watkins, #106726)
1625
 
 
1626
 
   * Error messages are now better formatted with parameters (such as
1627
 
     filenames) quoted when necessary. This avoids confusion when directory
1628
 
     names ending in a '.' at the end of messages were confused with a
1629
 
     full stop that may or not have been there. (Daniel Watkins, #129791)
1630
 
 
1631
 
   * Fix ``status FILE -r X..Y``. (Lukáš Lalinský)
1632
 
 
1633
 
   * If a particular command is an alias, ``help`` will show the alias
1634
 
     instead of claiming there is no help for said alias. (Daniel Watkins,
1635
 
     #133548)
1636
 
 
1637
 
   * TreeTransform-based operations, like pull, merge, revert, and branch,
1638
 
     now roll back if they encounter an error.  (Aaron Bentley, #67699)
1639
 
 
1640
 
   * ``bzr commit`` now exits cleanly if a character unsupported by the
1641
 
     current encoding is used in the commit message.  (Daniel Watkins,
1642
 
     #116143)
1643
 
 
1644
 
   * bzr send uses default values for ranges when only half of an elipsis
1645
 
     is specified ("-r..5" or "-r5..").  (#61685, Aaron Bentley)
1646
 
 
1647
 
   * Avoid trouble when Windows ssh calls itself 'plink' but no plink
1648
 
     binary is present.  (Martin Albisetti, #107155)
1649
 
 
1650
 
   * ``bzr remove`` should remove clean subtrees.  Now it will remove (without
1651
 
     needing ``--force``) subtrees that contain no files with text changes or
1652
 
     modified files.  With ``--force`` it removes the subtree regardless of
1653
 
     text changes or unknown files. Directories with renames in or out (but
1654
 
     not changed otherwise) will now be removed without needing ``--force``.
1655
 
     Unknown ignored files will be deleted without needing ``--force``.
1656
 
     (Marius Kruger, #111665)
1657
 
 
1658
 
   * When two plugins conflict, the source of both the losing and now the
1659
 
     winning definition is shown.  (Konstantin Mikhaylov, #5454)
1660
 
 
1661
 
   * When committing to a branch, the location being committed to is
1662
 
     displayed.  (Daniel Watkins, #52479)
1663
 
 
1664
 
   * ``bzr --version`` takes care about encoding of stdout, especially
1665
 
     when output is redirected. (Alexander Belchenko, #131100)
1666
 
 
1667
 
   * Prompt for an ftp password if none is provided.
1668
 
     (Vincent Ladeuil, #137044)
1669
 
 
1670
 
   * Reuse bound branch associated transport to avoid multiple
1671
 
     connections.
1672
 
     (Vincent Ladeuil, #128076, #131396)
1673
 
 
1674
 
   * Overwrite conflicting tags by ``push`` and ``pull`` if the
1675
 
     ``--overwrite`` option is specified.  (Lukáš Lalinský, #93947)
1676
 
 
1677
 
   * In checkouts, tags are copied into the master branch when created,
1678
 
     changed or deleted, and are copied into the checkout when it is 
1679
 
     updated.  (Martin Pool, #93856, #93860)
1680
 
 
1681
 
   * Print a warning instead of aborting the ``python setup.py install``
1682
 
     process if building of a C extension is not possible.
1683
 
     (Lukáš Lalinský, Alexander Belchenko)
1684
 
 
1685
 
  IMPROVEMENTS:
1686
 
 
1687
 
   * Add the option "--show-diff" to the commit command in order to display
1688
 
     the diff during the commit log creation. (Goffredo Baroncelli)
1689
 
 
1690
 
   * ``pull`` and ``merge`` are much faster at installing bundle format 4.
1691
 
     (Aaron Bentley)
1692
 
 
1693
 
   * ``pull -v`` no longer includes deltas, making it much faster.
1694
 
     (Aaron Bentley)
1695
 
 
1696
 
   * ``send`` now sends the directive as an attachment by default.
1697
 
     (Aaron Bentley, Lukáš Lalinský, Alexander Belchenko)
1698
 
 
1699
 
   * Documentation updates (Martin Albisetti)
1700
 
 
1701
 
   * Help on debug flags is now included in ``help global-options``.
1702
 
     (Daniel Watkins, #124853)
1703
 
 
1704
 
   * Parameters passed on the command line are checked to ensure they are
1705
 
     supported by the encoding in use. (Daniel Watkins)
1706
 
 
1707
 
   * The compression used within the bzr repository has changed from zlib
1708
 
     level 9 to the zlib default level. This improves commit performance with
1709
 
     only a small increase in space used (and in some cases a reduction in
1710
 
     space). (Robert Collins)
1711
 
 
1712
 
   * Initial commit no longer SHAs files twice and now reuses the path
1713
 
     rather than looking it up again, making it faster.
1714
 
     (Ian Clatworthy)
1715
 
 
1716
 
   * New option ``-c``/``--change`` for ``diff`` and ``status`` to show
1717
 
     changes in one revision.  (Lukáš Lalinský)
1718
 
 
1719
 
   * If versioned files match a given ignore pattern, a warning is now
1720
 
     given. (Daniel Watkins, #48623)
1721
 
 
1722
 
   * ``bzr status`` now has -S as a short name for --short and -V as a
1723
 
     short name for --versioned. These have been added to assist users
1724
 
     migrating from Subversion: ``bzr status -SV`` is now like
1725
 
     ``svn status -q``.  (Daniel Watkins, #115990)
1726
 
 
1727
 
   * Added C implementation of  ``PatienceSequenceMatcher``, which is about
1728
 
     10x faster than the Python version. This speeds up commands that
1729
 
     need file diffing, such as ``bzr commit`` or ``bzr diff``.
1730
 
     (Lukáš Lalinský)
1731
 
 
1732
 
   * HACKING has been extended with a large section on core developer tasks.
1733
 
     (Ian Clatworthy)
1734
 
 
1735
 
   * Add ``branches`` and ``standalone-trees`` as online help topics and
1736
 
     include them as Concepts within the User Reference.
1737
 
     (Paul Moore, Ian Clatworthy)
1738
 
 
1739
 
    * ``check`` can detect versionedfile parent references that are
1740
 
      inconsistent with revision and inventory info, and ``reconcile`` can fix
1741
 
      them.  These faulty references were generated by 0.8-era releases,
1742
 
      so repositories which were manipulated by old bzrs should be
1743
 
      checked, and possibly reconciled ASAP.  (Aaron Bentley, Andrew Bennetts)
1744
 
 
1745
 
  API BREAKS:
1746
 
 
1747
 
   * ``Branch.append_revision`` is removed altogether; please use 
1748
 
     ``Branch.set_last_revision_info`` instead.  (Martin Pool)
1749
 
 
1750
 
   * CommitBuilder now advertises itself as requiring the root entry to be
1751
 
     supplied. This only affects foreign repository implementations which reuse
1752
 
     CommitBuilder directly and have changed record_entry_contents to require
1753
 
     that the root not be supplied. This should be precisely zero plugins
1754
 
     affected. (Robert Collins)
1755
 
 
1756
 
   * The ``add_lines`` methods on ``VersionedFile`` implementations has changed
1757
 
     its return value to include the sha1 and length of the inserted text. This
1758
 
     allows the avoidance of double-sha1 calculations during commit.
1759
 
     (Robert Collins)
1760
 
 
1761
 
   * ``Transport.should_cache`` has been removed.  It was not called in the
1762
 
     previous release.  (Martin Pool)
1763
 
 
1764
 
  TESTING:
1765
 
 
1766
 
   * Tests may now raise TestNotApplicable to indicate they shouldn't be 
1767
 
     run in a particular scenario.  (Martin Pool)
1768
 
 
1769
 
   * New function multiply_tests_from_modules to give a simpler interface
1770
 
     to test parameterization.  (Martin Pool, Robert Collins)
1771
 
 
1772
 
   * ``Transport.should_cache`` has been removed.  It was not called in the
1773
 
     previous release.  (Martin Pool)
1774
 
 
1775
 
   * NULL_REVISION is returned to indicate the null revision, not None.
1776
 
     (Aaron Bentley)
1777
 
 
1778
 
   * Use UTF-8 encoded StringIO for log tests to avoid failures on
1779
 
     non-ASCII committer names.  (Lukáš Lalinský)
1780
 
 
1781
 
  INTERNALS:
1782
 
 
1783
 
   * ``bzrlib.plugin.all_plugins`` has been deprecated in favour of
1784
 
     ``bzrlib.plugin.plugins()`` which returns PlugIn objects that provide
1785
 
     useful functionality for determining the path of a plugin, its tests, and
1786
 
     its version information. (Robert Collins)
1787
 
 
1788
 
   * Add the option user_encoding to the function 'show_diff_trees()'
1789
 
     in order to move the user encoding at the UI level. (Goffredo Baroncelli)
1790
 
 
1791
 
   * Add the function make_commit_message_template_encoded() and the function
1792
 
     edit_commit_message_encoded() which handle encoded strings.
1793
 
     This is done in order to mix the commit messages (which is a unicode
1794
 
     string), and the diff which is a raw string. (Goffredo Baroncelli)
1795
 
 
1796
 
   * CommitBuilder now defaults to using add_lines_with_ghosts, reducing
1797
 
     overhead on non-weave repositories which don't require all parents to be
1798
 
     present. (Robert Collins)
1799
 
 
1800
 
   * Deprecated method ``find_previous_heads`` on
1801
 
     ``bzrlib.inventory.InventoryEntry``. This has been superseded by the use
1802
 
     of ``parent_candidates`` and a separate heads check via the repository
1803
 
     API. (Robert Collins)
1804
 
 
1805
 
   * New trace function ``mutter_callsite`` will print out a subset of the
1806
 
     stack to the log, which can be useful for gathering debug details.
1807
 
     (Robert Collins)
1808
 
 
1809
 
   * ``bzrlib.pack.ContainerWriter`` now tracks how many records have been
1810
 
     added via a public attribute records_written. (Robert Collins)
1811
 
 
1812
 
   * New method ``bzrlib.transport.Transport.get_recommended_page_size``.
1813
 
     This provides a hint to users of transports as to the reasonable
1814
 
     minimum data to read. In principle this can take latency and
1815
 
     bandwidth into account on a per-connection basis, but for now it
1816
 
     just has hard coded values based on the url. (e.g. http:// has a large
1817
 
     page size, file:// has a small one.) (Robert Collins)
1818
 
 
1819
 
   * New method on ``bzrlib.transport.Transport`` ``open_write_stream`` allows
1820
 
     incremental addition of data to a file without requiring that all the
1821
 
     data be buffered in memory. (Robert Collins)
1822
 
 
1823
 
   * New methods on ``bzrlib.knit.KnitVersionedFile``:
1824
 
     ``get_data_stream(versions)``, ``insert_data_stream(stream)`` and
1825
 
     ``get_format_signature()``.  These provide some infrastructure for
1826
 
     efficiently streaming the knit data for a set of versions over the smart
1827
 
     protocol.
1828
 
 
1829
 
   * Knits with no annotation cache still produce correct annotations.
1830
 
     (Aaron Bentley)
1831
 
 
1832
 
   * Three new methods have been added to ``bzrlib.trace``:
1833
 
     ``set_verbosity_level``, ``get_verbosity_level`` and ``is_verbose``.
1834
 
     ``set_verbosity_level`` expects a numeric value: negative for quiet,
1835
 
     zero for normal, positive for verbose. The size of the number can be
1836
 
     used to determine just how quiet or verbose the application should be.
1837
 
     The existing ``be_quiet`` and ``is_quiet`` routines have been
1838
 
     integrated into this new scheme. (Ian Clatworthy)
1839
 
 
1840
 
   * Options can now be delcared with a ``custom_callback`` parameter. If
1841
 
     set, this routine is called after the option is processed. This feature
1842
 
     is now used by the standard options ``verbose`` and ``quiet`` so that
1843
 
     setting one implicitly resets the other. (Ian Clatworthy)
1844
 
 
1845
 
   * Rather than declaring a new option from scratch in order to provide
1846
 
     custom help, a centrally registered option can be decorated using the
1847
 
     new ``bzrlib.Option.custom_help`` routine. In particular, this routine
1848
 
     is useful when declaring better help for the ``verbose`` and ``quiet``
1849
 
     standard options as the base definition of these is now more complex
1850
 
     than before thanks to their use of a custom callback. (Ian Clatworthy)
1851
 
      
1852
 
    * Tree._iter_changes(specific_file=[]) now iterates through no files,
1853
 
      instead of iterating through all files.  None is used to iterate through
1854
 
      all files.  (Aaron Bentley)
1855
 
 
1856
 
    * WorkingTree.revert() now accepts None to revert all files.  The use of
1857
 
      [] to revert all files is deprecated.  (Aaron Bentley)
1858
 
 
1859
 
 
1860
 
bzr 0.90 2007-08-28
1861
 
-------------------
1862
 
 
1863
 
  IMPROVEMENTS:
1864
 
 
1865
 
    * Documentation is now organized into multiple directories with a level
1866
 
      added for different languages or locales. Added the Mini Tutorial
1867
 
      and Quick Start Summary (en) documents from the Wiki, improving the
1868
 
      content and readability of the former. Formatted NEWS as Release Notes
1869
 
      complete with a Table of Conents, one heading per release. Moved the
1870
 
      Developer Guide into the main document catalog and provided a link
1871
 
      from the developer document catalog back to the main one.
1872
 
      (Ian Clatworthy, Sabin Iacob, Alexander Belchenko)
1873
 
 
1874
 
 
1875
 
  API CHANGES:
1876
 
 
1877
 
    * The static convenience method ``BzrDir.create_repository``
1878
 
      is deprecated.  Callers should instead create a ``BzrDir`` instance
1879
 
      and call ``create_repository`` on that.  (Martin Pool)
1880
 
 
1881
 
 
1882
 
bzr 0.90rc1 2007-08-14
1883
 
----------------------
1884
 
 
1885
 
  BUGFIXES:
1886
 
 
1887
 
    * ``bzr init`` should connect to the remote location one time only.  We
1888
 
      have been connecting several times because we forget to pass around the
1889
 
      Transport object. This modifies ``BzrDir.create_branch_convenience``,
1890
 
      so that we can give it the Transport we already have.
1891
 
      (John Arbash Meinel, Vincent Ladeuil, #111702)
1892
 
 
1893
 
    * Get rid of sftp connection cache (get rid of the FTP one too).
1894
 
      (Vincent Ladeuil, #43731)
1895
 
 
1896
 
    * bzr branch {local|remote} remote don't try to create a working tree
1897
 
      anymore.
1898
 
      (Vincent Ladeuil, #112173)
1899
 
 
1900
 
    * All identified multiple connections for a single bzr command have been
1901
 
      fixed. See bzrlib/tests/commands directory.
1902
 
      (Vincent Ladeuil)
1903
 
 
1904
 
    * ``bzr rm`` now does not insist on ``--force`` to delete files that
1905
 
      have been renamed but not otherwise modified.  (Marius Kruger,
1906
 
      #111664)
1907
 
 
1908
 
    * ``bzr selftest --bench`` no longer emits deprecation warnings
1909
 
      (Lukáš Lalinský)
1910
 
 
1911
 
    * ``bzr status`` now honours FILE parameters for conflict lists
1912
 
      (Aaron Bentley, #127606)
1913
 
 
1914
 
    * ``bzr checkout`` now honours -r when reconstituting a working tree.
1915
 
      It also honours -r 0.  (Aaron Bentley, #127708)
1916
 
 
1917
 
    * ``bzr add *`` no more fails on Windows if working tree contains
1918
 
      non-ascii file names. (Kuno Meyer, #127361)
1919
 
 
1920
 
    * allow ``easy_install bzr`` runs without fatal errors. 
1921
 
      (Alexander Belchenko, #125521)
1922
 
 
1923
 
    * Graph._filter_candidate_lca does not raise KeyError if a candidate
1924
 
      is eliminated just before it would normally be examined.  (Aaron Bentley)
1925
 
 
1926
 
    * SMTP connection failures produce a nice message, not a traceback.
1927
 
      (Aaron Bentley)
1928
 
 
1929
 
  IMPROVEMENTS:
1930
 
 
1931
 
    * Don't show "dots" progress indicators when run non-interactively, such
1932
 
      as from cron.  (Martin Pool)
1933
 
 
1934
 
    * ``info`` now formats locations more nicely and lists "submit" and
1935
 
      "public" branches (Aaron Bentley)
1936
 
 
1937
 
    * New ``pack`` command that will trigger database compression within
1938
 
      the repository (Robert Collins)
1939
 
 
1940
 
    * Implement ``_KnitIndex._load_data`` in a pyrex extension. The pyrex
1941
 
      version is approximately 2-3x faster at parsing a ``.kndx`` file.
1942
 
      Which yields a measurable improvement for commands which have to
1943
 
      read from the repository, such as a 1s => 0.75s improvement in
1944
 
      ``bzr diff`` when there are changes to be shown.  (John Arbash Meinel)
1945
 
 
1946
 
    * Merge is now faster.  Depending on the scenario, it can be more than 2x
1947
 
      faster. (Aaron Bentley)
1948
 
 
1949
 
    * Give a clearer warning, and allow ``python setup.py install`` to
1950
 
      succeed even if pyrex is not available.
1951
 
      (John Arbash Meinel)
1952
 
 
1953
 
    * ``DirState._read_dirblocks`` now has an optional Pyrex
1954
 
      implementation. This improves the speed of any command that has to
1955
 
      read the entire DirState. (``diff``, ``status``, etc, improve by
1956
 
      about 10%).
1957
 
      ``bisect_dirblocks`` has also been improved, which helps all
1958
 
      ``_get_entry`` type calls (whenever we are searching for a
1959
 
      particular entry in the in-memory DirState).
1960
 
      (John Arbash Meinel)
1961
 
 
1962
 
    * ``bzr pull`` and ``bzr push`` no longer do a complete walk of the 
1963
 
      branch revision history for ui display unless -v is supplied.
1964
 
      (Robert Collins)
1965
 
 
1966
 
    * ``bzr log -rA..B`` output shifted to the left margin if the log only 
1967
 
      contains merge revisions. (Kent Gibson) 
1968
 
 
1969
 
    * The ``plugins`` command is now public with improved help.
1970
 
      (Ian Clatworthy)
1971
 
 
1972
 
    * New bundle and merge directive formats are faster to generate, and
1973
 
 
1974
 
    * Annotate merge now works when there are local changes. (Aaron Bentley)
1975
 
 
1976
 
    * Commit now only shows the progress in terms of directories instead of
1977
 
      entries. (Ian Clatworthy)
1978
 
 
1979
 
    * Fix ``KnitRepository.get_revision_graph`` to not request the graph 2
1980
 
      times. This makes ``get_revision_graph`` 2x faster. (John Arbash
1981
 
      Meinel)
1982
 
 
1983
 
    * Fix ``VersionedFile.get_graph()`` to avoid using
1984
 
      ``set.difference_update(other)``, which has bad scaling when
1985
 
      ``other`` is large. This improves ``VF.get_graph([version_id])`` for
1986
 
      a 12.5k graph from 2.9s down to 200ms. (John Arbash Meinel)
1987
 
 
1988
 
    * The ``--lsprof-file`` option now generates output for KCacheGrind if
1989
 
      the file starts with ``callgrind.out``. This matches the default file
1990
 
      filtering done by KCacheGrind's Open Dialog. (Ian Clatworthy)
1991
 
 
1992
 
    * Fix ``bzr update`` to avoid an unnecessary
1993
 
      ``branch.get_master_branch`` call, which avoids 1 extra connection
1994
 
      to the remote server. (Partial fix for #128076, John Arbash Meinel)
1995
 
 
1996
 
    * Log errors from the smart server in the trace file, to make debugging 
1997
 
      test failures (and live failures!) easier.  (Andrew Bennetts)
1998
 
 
1999
 
    * The HTML version of the man page has been superceded by a more
2000
 
      comprehensive manual called the Bazaar User Reference. This manual
2001
 
      is completed generated from the online help topics. As part of this
2002
 
      change, limited reStructuredText is now explicitly supported in help
2003
 
      topics and command help with 'unnatural' markup being removed prior
2004
 
      to display by the online help or inclusion in the man page.
2005
 
      (Ian Clatworthy)
2006
 
 
2007
 
    * HTML documentation now use files extension ``*.html``
2008
 
      (Alexander Belchenko)
2009
 
 
2010
 
    * The cache of ignore definitions is now cleared in WorkingTree.unlock()
2011
 
      so that changes to .bzrignore aren't missed. (#129694, Daniel Watkins)
2012
 
 
2013
 
    * ``bzr selftest --strict`` fails if there are any missing features or
2014
 
      expected test failures. (Daniel Watkins, #111914)
2015
 
 
2016
 
    * Link to registration survey added to README. (Ian Clatworthy)
2017
 
 
2018
 
    * Windows standalone installer show link to registration survey
2019
 
      when installation finished. (Alexander Belchenko)
2020
 
 
2021
 
  LIBRARY API BREAKS:
2022
 
 
2023
 
    * Deprecated dictionary ``bzrlib.option.SHORT_OPTIONS`` removed.
2024
 
      Options are now required to provide a help string and it must
2025
 
      comply with the style guide by being one or more sentences with an
2026
 
      initial capital and final period. (Martin Pool)
2027
 
 
2028
 
    * KnitIndex.get_parents now returns tuples. (Robert Collins)
2029
 
 
2030
 
    * Ancient unused ``Repository.text_store`` attribute has been removed.
2031
 
      (Robert Collins)
2032
 
 
2033
 
    * The ``bzrlib.pack`` interface has changed to use tuples of bytestrings
2034
 
      rather than just bytestrings, making it easier to represent multiple
2035
 
      element names. As this interface was not used by any internal facilities
2036
 
      since it was introduced in 0.18 no API compatibility is being preserved.
2037
 
      The serialised form of these packs is identical with 0.18 when a single
2038
 
      element tuple is in use. (Robert Collins)
2039
 
 
2040
 
  INTERNALS:
2041
 
 
2042
 
    * merge now uses ``iter_changes`` to calculate changes, which makes room for
2043
 
      future performance increases.  It is also more consistent with other
2044
 
      operations that perform comparisons, and reduces reliance on
2045
 
      Tree.inventory.  (Aaron Bentley)
2046
 
 
2047
 
    * Refactoring of transport classes connected to a remote server.
2048
 
      ConnectedTransport is a new class that serves as a basis for all
2049
 
      transports needing to connect to a remote server.  transport.split_url
2050
 
      have been deprecated, use the static method on the object instead. URL
2051
 
      tests have been refactored too.
2052
 
      (Vincent Ladeuil)
2053
 
 
2054
 
    * Better connection sharing for ConnectedTransport objects.
2055
 
      transport.get_transport() now accepts a 'possible_transports' parameter.
2056
 
      If a newly requested transport can share a connection with one of the
2057
 
      list, it will.
2058
 
      (Vincent Ladeuil)
2059
 
 
2060
 
    * Most functions now accept ``bzrlib.revision.NULL_REVISION`` to indicate
2061
 
      the null revision, and consider using ``None`` for this purpose
2062
 
      deprecated.  (Aaron Bentley)
2063
 
 
2064
 
    * New ``index`` module with abstract index functionality. This will be
2065
 
      used during the planned changes in the repository layer. Currently the
2066
 
      index layer provides a graph aware immutable index, a builder for the
2067
 
      same index type to allow creating them, and finally a composer for
2068
 
      such indices to allow the use of many indices in a single query. The
2069
 
      index performance is not optimised, however the API is stable to allow
2070
 
      development on top of the index. (Robert Collins)
2071
 
 
2072
 
    * ``bzrlib.dirstate.cmp_by_dirs`` can be used to compare two paths by
2073
 
      their directory sections. This is equivalent to comparing
2074
 
      ``path.split('/')``, only without having to split the paths.
2075
 
      This has a Pyrex implementation available.
2076
 
      (John Arbash Meinel)
2077
 
 
2078
 
    * New transport decorator 'unlistable+' which disables the list_dir
2079
 
      functionality for testing.
2080
 
 
2081
 
    * Deprecated ``change_entry`` in transform.py. (Ian Clatworthy)
2082
 
 
2083
 
    * RevisionTree.get_weave is now deprecated.  Tree.plan_merge is now used
2084
 
      for performing annotate-merge.  (Aaron Bentley)
2085
 
 
2086
 
    * New EmailMessage class to create email messages. (Adeodato Simó)
2087
 
 
2088
 
    * Unused functions on the private interface KnitIndex have been removed.
2089
 
      (Robert Collins)
2090
 
 
2091
 
    * New ``knit.KnitGraphIndex`` which provides a ``KnitIndex`` layered on top
2092
 
      of a ``index.GraphIndex``. (Robert Collins)
2093
 
 
2094
 
    * New ``knit.KnitVersionedFile.iter_parents`` method that allows querying
2095
 
      the parents of many knit nodes at once, reducing round trips to the 
2096
 
      underlying index. (Robert Collins)
2097
 
 
2098
 
    * Graph now has an is_ancestor method, various bits use it.
2099
 
      (Aaron Bentley)
2100
 
 
2101
 
    * The ``-Dhpss`` flag now includes timing information. As well as
2102
 
      logging when a new connection is opened. (John Arbash Meinel)
2103
 
 
2104
 
    * ``bzrlib.pack.ContainerWriter`` now returns an offset, length tuple to
2105
 
      callers when inserting data, allowing generation of readv style access
2106
 
      during pack creation, without needing a separate pass across the output
2107
 
      pack to gather such details. (Robert Collins)
2108
 
 
2109
 
    * ``bzrlib.pack.make_readv_reader`` allows readv based access to pack
2110
 
      files that are stored on a transport. (Robert Collins)
2111
 
 
2112
 
    * New ``Repository.has_same_location`` method that reports if two
2113
 
      repository objects refer to the same repository (although with some risk
2114
 
      of false negatives).  (Andrew Bennetts)
2115
 
 
2116
 
    * InterTree.compare now passes require_versioned on correctly.
2117
 
      (Marius Kruger)
2118
 
 
2119
 
    * New methods on Repository - ``start_write_group``,
2120
 
      ``commit_write_group``, ``abort_write_group`` and ``is_in_write_group`` -
2121
 
      which provide a clean hook point for transactional Repositories - ones
2122
 
      where all the data for a fetch or commit needs to be made atomically
2123
 
      available in one step. This allows the write lock to remain while making
2124
 
      a series of data insertions.  (e.g. data conversion). (Robert Collins)
2125
 
 
2126
 
    * In ``bzrlib.knit`` the internal interface has been altered to use
2127
 
      3-tuples (index, pos, length) rather than two-tuples (pos, length) to
2128
 
      describe where data in a knit is, allowing knits to be split into 
2129
 
      many files. (Robert Collins)
2130
 
 
2131
 
    * ``bzrlib.knit._KnitData`` split into cache management and physical access
2132
 
      with two access classes - ``_PackAccess`` and ``_KnitAccess`` defined.
2133
 
      The former provides access into a .pack file, and the latter provides the
2134
 
      current production repository form of .knit files. (Robert Collins)
2135
 
 
2136
 
  TESTING:
2137
 
 
2138
 
    * Remove selftest ``--clean-output``, ``--numbered-dirs`` and
2139
 
      ``--keep-output`` options, which are obsolete now that tests
2140
 
      are done within directories in $TMPDIR.  (Martin Pool)
2141
 
 
2142
 
    * The SSH_AUTH_SOCK environment variable is now reset to avoid 
2143
 
      interaction with any running ssh agents.  (Jelmer Vernooij, #125955)
2144
 
 
2145
 
    * run_bzr_subprocess handles parameters the same way as run_bzr:
2146
 
      either a string or a list of strings should be passed as the first
2147
 
      parameter.  Varargs-style parameters are deprecated. (Aaron Bentley)
2148
 
 
2149
 
 
2150
 
bzr 0.18  2007-07-17
2151
 
--------------------
2152
 
 
2153
 
  BUGFIXES:
2154
 
 
2155
 
    * Fix 'bzr add' crash under Win32 (Kuno Meyer)
2156
 
 
2157
 
 
2158
 
bzr 0.18rc1  2007-07-10
2159
 
-----------------------
2160
 
 
2161
 
  BUGFIXES:
2162
 
 
2163
 
    * Do not suppress pipe errors, etc. in non-display commands
2164
 
      (Alexander Belchenko, #87178)
2165
 
 
2166
 
    * Display a useful error message when the user requests to annotate
2167
 
      a file that is not present in the specified revision.
2168
 
      (James Westby, #122656)
2169
 
 
2170
 
    * Commands that use status flags now have a reference to 'help
2171
 
      status-flags'.  (Daniel Watkins, #113436)
2172
 
 
2173
 
    * Work around python-2.4.1 inhability to correctly parse the
2174
 
      authentication header.
2175
 
      (Vincent Ladeuil, #121889)
2176
 
 
2177
 
    * Use exact encoding for merge directives. (Adeodato Simó, #120591)
2178
 
 
2179
 
    * Fix tempfile permissions error in smart server tar bundling under
2180
 
      Windows. (Martin _, #119330)
2181
 
 
2182
 
    * Fix detection of directory entries in the inventory. (James Westby)
2183
 
 
2184
 
    * Fix handling of http code 400: Bad Request When issuing too many ranges.
2185
 
      (Vincent Ladeuil, #115209)
2186
 
 
2187
 
    * Issue a CONNECT request when connecting to an https server
2188
 
      via a proxy to enable SSL tunneling.
2189
 
      (Vincent Ladeuil, #120678)
2190
 
 
2191
 
    * Fix ``bzr log -r`` to support selecting merge revisions, both 
2192
 
      individually and as part of revision ranges.
2193
 
      (Kent Gibson, #4663)
2194
 
 
2195
 
    * Don't leave cruft behind when failing to acquire a lockdir.
2196
 
      (Martin Pool, #109169)
2197
 
 
2198
 
    * Don't use the '-f' strace option during tests.
2199
 
      (Vincent Ladeuil, #102019).
2200
 
 
2201
 
    * Warn when setting ``push_location`` to a value that will be masked by
2202
 
      locations.conf.  (Aaron Bentley, #122286)
2203
 
 
2204
 
    * Fix commit ordering in corner case (Aaron Bentley, #94975)
2205
 
 
2206
 
    *  Make annotate behave in a non-ASCII world (Adeodato Simó).
2207
 
 
2208
 
  IMPROVEMENTS:
2209
 
 
2210
 
    * The --lsprof-file option now dumps a text rendering of the profiling
2211
 
      information if the filename ends in ".txt". It will also convert the
2212
 
      profiling information to a format suitable for KCacheGrind if the
2213
 
      output filename ends in ".callgrind". Fixes to the lsprofcalltree
2214
 
      conversion process by Jean Paul Calderone and Itamar were also merged.
2215
 
      See http://ddaa.net/blog/python/lsprof-calltree. (Ian Clatworthy)
2216
 
 
2217
 
    * ``info`` now defaults to non-verbose mode, displaying only paths and
2218
 
      abbreviated format info.  ``info -v`` displays all the information
2219
 
      formerly displayed by ``info``.  (Aaron Bentley, Adeodato Simó)
2220
 
 
2221
 
    * ``bzr missing`` now has better option names ``--this`` and ``--other``.
2222
 
      (Elliot Murphy)
2223
 
 
2224
 
    * The internal ``weave-list`` command has become ``versionedfile-list``,
2225
 
      and now lists knits as well as weaves.  (Aaron Bentley)
2226
 
 
2227
 
    * Automatic merge base selection uses a faster algorithm that chooses
2228
 
      better bases in criss-cross merge situations (Aaron Bentley)
2229
 
 
2230
 
    * Progress reporting in ``commit`` has been improved. The various logical
2231
 
      stages are now reported on as follows, namely:
2232
 
 
2233
 
      * Collecting changes [Entry x/y] - Stage n/m
2234
 
      * Saving data locally - Stage n/m
2235
 
      * Uploading data to master branch - Stage n/m
2236
 
      * Updating the working tree - Stage n/m
2237
 
      * Running post commit hooks - Stage n/m
2238
 
      
2239
 
      If there is no master branch, the 3rd stage is omitted and the total
2240
 
      number of stages is adjusted accordingly.
2241
 
 
2242
 
      Each hook that is run after commit is listed with a name (as hooks
2243
 
      can be slow it is useful feedback).
2244
 
      (Ian Clatworthy, Robert Collins)
2245
 
 
2246
 
    * Various operations that are now faster due to avoiding unnecessary
2247
 
      topological sorts. (Aaron Bentley)
2248
 
 
2249
 
    * Make merge directives robust against broken bundles. (Aaron Bentley)
2250
 
 
2251
 
    * The lsprof filename note is emitted via trace.note(), not standard
2252
 
      output.  (Aaron Bentley)
2253
 
 
2254
 
    * ``bzrlib`` now exports explicit API compatibility information to assist
2255
 
      library users and plugins. See the ``bzrlib.api`` module for details.
2256
 
      (Robert Collins)
2257
 
 
2258
 
    * Remove unnecessary lock probes when acquiring a lockdir.
2259
 
      (Martin Pool)
2260
 
 
2261
 
    * ``bzr --version`` now shows the location of the bzr log file, which
2262
 
      is especially useful on Windows.  (Martin Pool)
2263
 
 
2264
 
    * -D now supports hooks to get debug tracing of hooks (though its currently
2265
 
      minimal in nature). (Robert Collins)
2266
 
 
2267
 
    * Long log format reports deltas on merge revisions. 
2268
 
      (John Arbash Meinel, Kent Gibson)
2269
 
 
2270
 
    * Make initial push over ftp more resilient. (John Arbash Meinel)
2271
 
 
2272
 
    * Print a summary of changes for update just like pull does.
2273
 
      (Daniel Watkins, #113990)
2274
 
 
2275
 
    * Add a -Dhpss option to trace smart protocol requests and responses.
2276
 
      (Andrew Bennetts)
2277
 
 
2278
 
  LIBRARY API BREAKS:
2279
 
 
2280
 
    * Testing cleanups - 
2281
 
      ``bzrlib.repository.RepositoryTestProviderAdapter`` has been moved
2282
 
      to ``bzrlib.tests.repository_implementations``;
2283
 
      ``bzrlib.repository.InterRepositoryTestProviderAdapter`` has been moved
2284
 
      to ``bzrlib.tests.interrepository_implementations``;
2285
 
      ``bzrlib.transport.TransportTestProviderAdapter`` has moved to 
2286
 
      ``bzrlib.tests.test_transport_implementations``.
2287
 
      ``bzrlib.branch.BranchTestProviderAdapter`` has moved to
2288
 
      ``bzrlib.tests.branch_implementations``.
2289
 
      ``bzrlib.bzrdir.BzrDirTestProviderAdapter`` has moved to 
2290
 
      ``bzrlib.tests.bzrdir_implementations``.
2291
 
      ``bzrlib.versionedfile.InterVersionedFileTestProviderAdapter`` has moved
2292
 
      to ``bzrlib.tests.interversionedfile_implementations``.
2293
 
      ``bzrlib.store.revision.RevisionStoreTestProviderAdapter`` has moved to
2294
 
      ``bzrlib.tests.revisionstore_implementations``.
2295
 
      ``bzrlib.workingtree.WorkingTreeTestProviderAdapter`` has moved to
2296
 
      ``bzrlib.tests.workingtree_implementations``.
2297
 
      These changes are an API break in the testing infrastructure only.
2298
 
      (Robert Collins)
2299
 
 
2300
 
    * Relocate TestCaseWithRepository to be more central. (Robert Collins)
2301
 
 
2302
 
    * ``bzrlib.add.smart_add_tree`` will no longer perform glob expansion on
2303
 
      win32. Callers of the function should do this and use the new
2304
 
      ``MutableTree.smart_add`` method instead. (Robert Collins)
2305
 
 
2306
 
    * ``bzrlib.add.glob_expand_for_win32`` is now
2307
 
      ``bzrlib.win32utils.glob_expand``.  (Robert Collins)
2308
 
 
2309
 
    * ``bzrlib.add.FastPath`` is now private and moved to 
2310
 
      ``bzrlib.mutabletree._FastPath``. (Robert Collins, Martin Pool)
2311
 
 
2312
 
    * ``LockDir.wait`` removed.  (Martin Pool)
2313
 
 
2314
 
    * The ``SmartServer`` hooks API has changed for the ``server_started`` and
2315
 
      ``server_stopped`` hooks. The first parameter is now an iterable of
2316
 
      backing URLs rather than a single URL. This is to reflect that many
2317
 
      URLs may map to the external URL of the server. E.g. the server interally
2318
 
      may have a chrooted URL but also the local file:// URL will be at the 
2319
 
      same location. (Robert Collins)
2320
 
 
2321
 
  INTERNALS:
2322
 
 
2323
 
    * New SMTPConnection class to unify email handling.  (Adeodato Simó)
2324
 
 
2325
 
    * Fix documentation of BzrError. (Adeodato Simó)
2326
 
 
2327
 
    * Make BzrBadParameter an internal error. (Adeodato Simó)
2328
 
 
2329
 
    * Remove use of 'assert False' to raise an exception unconditionally.
2330
 
      (Martin Pool)
2331
 
 
2332
 
    * Give a cleaner error when failing to decode knit index entry.
2333
 
      (Martin Pool)
2334
 
 
2335
 
    * TreeConfig would mistakenly search the top level when asked for options
2336
 
      from a section. It now respects the section argument and only
2337
 
      searches the specified section. (James Westby)
2338
 
 
2339
 
    * Improve ``make api-docs`` output. (John Arbash Meinel)
2340
 
 
2341
 
    * Use os.lstat rather than os.stat for osutils.make_readonly and
2342
 
      osutils.make_writeable. This makes the difftools plugin more
2343
 
      robust when dangling symlinks are found. (Elliot Murphy)
2344
 
 
2345
 
    * New ``-Dlock`` option to log (to ~/.bzr.log) information on when 
2346
 
      lockdirs are taken or released.  (Martin Pool)
2347
 
 
2348
 
    * ``bzrlib`` Hooks are now nameable using ``Hooks.name_hook``. This 
2349
 
      allows a nicer UI when hooks are running as the current hook can
2350
 
      be displayed. (Robert Collins)
2351
 
 
2352
 
    * ``Transport.get`` has had its interface made more clear for ease of use.
2353
 
      Retrieval of a directory must now fail with either 'PathError' at open
2354
 
      time, or raise 'ReadError' on a read. (Robert Collins)
2355
 
 
2356
 
    * New method ``_maybe_expand_globs`` on the ``Command`` class for 
2357
 
      dealing with unexpanded glob lists - e.g. on the win32 platform. This
2358
 
      was moved from ``bzrlib.add._prepare_file_list``. (Robert Collins)
2359
 
 
2360
 
    * ``bzrlib.add.smart_add`` and ``bzrlib.add.smart_add_tree`` are now
2361
 
      deprecated in favour of ``MutableTree.smart_add``. (Robert Collins,
2362
 
      Martin Pool)
2363
 
 
2364
 
    * New method ``external_url`` on Transport for obtaining the url to
2365
 
      hand to external processes. (Robert Collins)
2366
 
 
2367
 
    * Teach windows installers to build pyrex/C extensions.
2368
 
      (Alexander Belchenko)
2369
 
 
2370
 
  TESTING:
2371
 
 
2372
 
    * Removed the ``--keep-output`` option from selftest and clean up test
2373
 
      directories as they're used.  This reduces the IO load from 
2374
 
      running the test suite and cuts the time by about half.
2375
 
      (Andrew Bennetts, Martin Pool)
2376
 
 
2377
 
    * Add scenarios as a public attribute on the TestAdapter classes to allow
2378
 
      modification of the generated scenarios before adaption and easier
2379
 
      testing. (Robert Collins)
2380
 
 
2381
 
    * New testing support class ``TestScenarioApplier`` which multiplies
2382
 
      out a single teste by a list of supplied scenarios. (RobertCollins)
2383
 
 
2384
 
    * Setting ``repository_to_test_repository`` on a repository_implementations
2385
 
      test will cause it to be called during repository creation, allowing the
2386
 
      testing of repository classes which are not based around the Format
2387
 
      concept. For example a repository adapter can be tested in this manner,
2388
 
      by altering the repository scenarios to include a scenario that sets this
2389
 
      attribute during the test parameterisation in
2390
 
      ``bzrlib.tests.repository.repository_implementations``. (Robert Collins)
2391
 
 
2392
 
    * Clean up many of the APIs for blackbox testing of Bazaar.  The standard 
2393
 
      interface is now self.run_bzr.  The command to run can be passed as
2394
 
      either a list of parameters, a string containing the command line, or
2395
 
      (deprecated) varargs parameters.  (Martin Pool)
2396
 
 
2397
 
    * The base TestCase now isolates tests from -D parameters by clearing
2398
 
      ``debug.debug_flags`` and restores it afterwards. (Robert Collins)
2399
 
 
2400
 
    * Add a relpath parameter to get_transport methods in test framework to
2401
 
      avoid useless cloning.
2402
 
      (Vincent Ladeuil, #110448)
2403
 
 
2404
 
 
2405
 
bzr 0.17  2007-06-18
2406
 
--------------------
2407
 
 
2408
 
  BUGFIXES:
2409
 
 
2410
 
    * Fix crash of commit due to wrong lookup of filesystem encoding.
2411
 
      (Colin Watson, #120647)
2412
 
 
2413
 
    * Revert logging just to stderr in commit as broke unicode filenames.
2414
 
      (Aaron Bentley, Ian Clatworthy, #120930)
2415
 
 
2416
 
 
2417
 
bzr 0.17rc1  2007-06-12
2418
 
-----------------------
2419
 
 
2420
 
  NOTES WHEN UPGRADING:
2421
 
 
2422
 
    * The kind() and is_executable() APIs on the WorkingTree interface no
2423
 
      longer implicitly (read) locks and unlocks the tree. This *might*
2424
 
      impact some plug-ins and tools using this part of the API. If you find
2425
 
      an issue that may be caused by this change, please let us know,
2426
 
      particularly the plug-in/tool maintainer. If encountered, the API
2427
 
      fix is to surround kind() and is_executable() calls with lock_read()
2428
 
      and unlock() like so::
2429
 
 
2430
 
        work_tree.lock_read()
2431
 
        try:
2432
 
            kind = work_tree.kind(...)
2433
 
        finally:
2434
 
            work_tree.unlock()
2435
 
 
2436
 
  INTERNALS:
2437
 
    * Rework of LogFormatter API to provide beginning/end of log hooks and to
2438
 
      encapsulate the details of the revision to be logged in a LogRevision
2439
 
      object.
2440
 
      In long log formats, merge revision ids are only shown when --show-ids
2441
 
      is specified, and are labelled "revision-id:", as per mainline
2442
 
      revisions, instead of "merged:". (Kent Gibson)
2443
 
 
2444
 
    * New ``BranchBuilder`` API which allows the construction of particular
2445
 
      histories quickly. Useful for testing and potentially other applications
2446
 
      too. (Robert Collins)
2447
 
 
2448
 
  IMPROVEMENTS:
2449
 
  
2450
 
    * There are two new help topics, working-trees and repositories that
2451
 
      attempt to explain these concepts. (James Westby, John Arbash Meinel,
2452
 
      Aaron Bentley)
2453
 
 
2454
 
    * Added ``bzr log --limit`` to report a limited number of revisions.
2455
 
      (Kent Gibson, #3659)
2456
 
 
2457
 
    * Revert does not try to preserve file contents that were originally
2458
 
      produced by reverting to a historical revision.  (Aaron Bentley)
2459
 
 
2460
 
    * ``bzr log --short`` now includes ``[merge]`` for revisions which
2461
 
      have more than one parent. This is a small improvement to help
2462
 
      understanding what changes have occurred
2463
 
      (John Arbash Meinel, #83887)
2464
 
 
2465
 
    * TreeTransform avoids many renames when contructing large trees,
2466
 
      improving speed.  3.25x speedups have been observed for construction of
2467
 
      kernel-sized-trees, and checkouts are 1.28x faster.  (Aaron Bentley)
2468
 
 
2469
 
    * Commit on large trees is now faster. In my environment, a commit of
2470
 
      a small change to the Mozilla tree (55k files) has dropped from
2471
 
      66 seconds to 32 seconds. For a small tree of 600 files, commit of a
2472
 
      small change is 33% faster. (Ian Clatworthy)
2473
 
 
2474
 
    * New --create-prefix option to bzr init, like for push.  (Daniel Watkins,
2475
 
      #56322)
2476
 
 
2477
 
  BUGFIXES:
2478
 
 
2479
 
    * ``bzr push`` should only connect to the remote location one time.
2480
 
      We have been connecting 3 times because we forget to pass around
2481
 
      the Transport object. This adds ``BzrDir.clone_on_transport()``, so
2482
 
      that we can pass in the Transport that we already have.
2483
 
      (John Arbash Meinel, #75721)
2484
 
 
2485
 
    * ``DirState.set_state_from_inventory()`` needs to properly order
2486
 
      based on split paths, not just string paths.
2487
 
      (John Arbash Meinel, #115947)
2488
 
 
2489
 
    * Let TestUIFactoy encode the password prompt with its own stdout.
2490
 
      (Vincent Ladeuil, #110204)
2491
 
 
2492
 
    * pycurl should take use the range header that takes the range hint
2493
 
      into account.
2494
 
      (Vincent Ladeuil, #112719)
2495
 
 
2496
 
    * WorkingTree4.get_file_sha1 no longer raises an exception when invoked
2497
 
      on a missing file.  (Aaron Bentley, #118186)
2498
 
 
2499
 
    * WorkingTree.remove works correctly with tree references, and when pwd is
2500
 
      not the tree root. (Aaron Bentley)
2501
 
 
2502
 
    * Merge no longer fails when a file is renamed in one tree and deleted
2503
 
      in the other. (Aaron Bentley, #110279)
2504
 
 
2505
 
    * ``revision-info`` now accepts dotted revnos, doesn't require a tree,
2506
 
      and defaults to the last revision (Matthew Fuller, #90048)
2507
 
 
2508
 
    * Tests no longer fail when BZR_REMOTE_PATH is set in the environment.
2509
 
      (Daniel Watkins, #111958)
2510
 
 
2511
 
    * ``bzr branch -r revid:foo`` can be used to branch any revision in
2512
 
      your repository. (Previously Branch6 only supported revisions in your
2513
 
      mainline). (John Arbash Meinel, #115343)
2514
 
 
2515
 
bzr 0.16  2007-05-07
2516
 
--------------------
2517
 
  
2518
 
  BUGFIXES:
2519
 
 
2520
 
    * Handle when you have 2 directories with similar names, but one has a
2521
 
      hyphen. (``'abc'`` versus ``'abc-2'``). The WT4._iter_changes
2522
 
      iterator was using direct comparison and ``'abc/a'`` sorts after
2523
 
      ``'abc-2'``, but ``('abc', 'a')`` sorts before ``('abc-2',)``.
2524
 
      (John Arbash Meinel, #111227)
2525
 
 
2526
 
    * Handle when someone renames a file on disk without telling bzr.
2527
 
      Previously we would report the first file as missing, but not show
2528
 
      the new unknown file. (John Arbash Meinel, #111288)
2529
 
 
2530
 
    * Avoid error when running hooks after pulling into or pushing from
2531
 
      a branch bound to a smartserver branch.  (Martin Pool, #111968)
2532
 
 
2533
 
  IMPROVEMENTS:
2534
 
 
2535
 
    * Move developer documentation to doc/developers/. This reduces clutter in
2536
 
      the root of the source tree and allows HACKING to be split into multiple
2537
 
      files. (Robert Collins, Alexander Belchenko)
2538
 
 
2539
 
    * Clean up the ``WorkingTree4._iter_changes()`` internal loops as well as
2540
 
      ``DirState.update_entry()``. This optimizes the core logic for ``bzr
2541
 
      diff`` and ``bzr status`` significantly improving the speed of
2542
 
      both. (John Arbash Meinel)
2543
2
 
2544
3
bzr 0.16rc2  2007-04-30
2545
 
-----------------------
2546
4
 
2547
5
  BUGFIXES:
2548
6
 
2565
23
      directories. (John Arbash Meinel, #110399)
2566
24
 
2567
25
bzr 0.16rc1  2007-04-26
2568
 
-----------------------
2569
26
 
2570
27
  NOTES WHEN UPGRADING:
2571
28
 
2868
325
      (Vincent Ladeuil)
2869
326
 
2870
327
bzr 0.15 2007-04-01
2871
 
-------------------
2872
328
 
2873
329
  BUGFIXES:
2874
330
 
2880
336
      (Martin Pool)
2881
337
 
2882
338
bzr 0.15rc3  2007-03-26
2883
 
-----------------------
2884
339
 
2885
340
  CHANGES:
2886
341
 
2952
407
      (vila, #88780)
2953
408
 
2954
409
bzr 0.15rc2  2007-03-14
2955
 
-----------------------
2956
410
 
2957
411
  NOTES WHEN UPGRADING:
2958
412
        
3002
456
 
3003
457
 
3004
458
bzr 0.15rc1  2007-03-07
3005
 
-----------------------
3006
459
 
3007
460
  SURPRISES:
3008
461
 
3228
681
 
3229
682
 
3230
683
bzr 0.14  2007-01-23
3231
 
--------------------
3232
684
 
3233
685
  IMPROVEMENTS:
3234
686
 
3246
698
 
3247
699
 
3248
700
bzr 0.14rc1  2007-01-16
3249
 
-----------------------
3250
701
 
3251
702
  IMPROVEMENTS:
3252
703
 
3378
829
 
3379
830
 
3380
831
bzr 0.13  2006-12-05
3381
 
--------------------
3382
832
    
3383
833
  No changes from 0.13rc1
3384
834
    
3385
835
bzr 0.13rc1  2006-11-27
3386
 
-----------------------
3387
836
 
3388
837
  IMPROVEMENTS:
3389
838
 
3505
954
      (previously it was ignoring it and returning the whole file,).
3506
955
 
3507
956
bzr 0.12  2006-10-30
3508
 
--------------------
3509
957
 
3510
958
  INTERNALS:
3511
959
 
3514
962
      (John Arbash Meinel)
3515
963
  
3516
964
bzr 0.12rc1  2006-10-23
3517
 
-----------------------
3518
965
 
3519
966
  IMPROVEMENTS:
3520
967
 
3631
1078
      created objects. (Robert Collins, John Arbash Meinel)
3632
1079
 
3633
1080
bzr 0.11  2006-10-02
3634
 
--------------------
3635
1081
 
3636
1082
    * Smart server transport test failures on windows fixed. (Lukáš Lalinský).
3637
1083
 
3638
1084
bzr 0.11rc2  2006-09-27
3639
 
-----------------------
3640
1085
 
3641
1086
  BUG FIXES:
3642
1087
 
3646
1091
      Arbash Meinel).
3647
1092
 
3648
1093
bzr 0.11rc1  2006-09-25
3649
 
-----------------------
3650
1094
 
3651
1095
  IMPROVEMENTS:
3652
1096
 
3835
1279
      Transport. (Andrew Bennetts, Martin Pool)
3836
1280
 
3837
1281
bzr 0.10  2006-08-29
3838
 
--------------------
3839
1282
  
3840
1283
  IMPROVEMENTS:
3841
1284
    * 'merge' now takes --uncommitted, to apply uncommitted changes from a
3910
1353
      easier. (John Arbash Meinel)
3911
1354
 
3912
1355
bzr 0.9.0  2006-08-11
3913
 
---------------------
3914
1356
 
3915
1357
  SURPRISES:
3916
1358
 
4174
1616
    * "RevisionTree" is now in bzrlib/revisiontree.py. (Robert Collins)
4175
1617
 
4176
1618
bzr 0.8.2  2006-05-17
4177
 
---------------------
4178
1619
  
4179
1620
  BUG FIXES:
4180
1621
   
4181
1622
    * setup.py failed to install launchpad plugin.  (Martin Pool)
4182
1623
 
4183
1624
bzr 0.8.1  2006-05-16
4184
 
---------------------
4185
1625
 
4186
1626
  BUG FIXES:
4187
1627
 
4229
1669
      uses bzrlib api now. (Olaf Conradi)
4230
1670
 
4231
1671
bzr 0.8  2006-05-08
4232
 
-------------------
4233
1672
 
4234
1673
  NOTES WHEN UPGRADING:
4235
1674
 
4486
1925
      parameter which will provide String("foo") to the command as its stdin.
4487
1926
 
4488
1927
bzr 0.7 2006-01-09
4489
 
------------------
4490
1928
 
4491
1929
  CHANGES:
4492
1930
 
4777
2215
      for functions that need unicode strings. (Robert Collins)
4778
2216
 
4779
2217
bzr 0.6 2005-10-28
4780
 
------------------
4781
2218
 
4782
2219
  IMPROVEMENTS:
4783
2220
  
4989
2426
 
4990
2427
 
4991
2428
bzr 0.1.1 2005-10-12
4992
 
--------------------
4993
2429
 
4994
2430
  BUG FIXES:
4995
2431
 
5005
2441
 
5006
2442
 
5007
2443
bzr 0.1 2005-10-11
5008
 
------------------
5009
2444
 
5010
2445
  NOTES:
5011
2446
 
5130
2565
 
5131
2566
      
5132
2567
bzr 0.0.9 2005-09-23
5133
 
--------------------
5134
2568
 
5135
2569
  BUG FIXES:
5136
2570
 
5169
2603
 
5170
2604
 
5171
2605
bzr 0.0.8 2005-09-20
5172
 
--------------------
5173
2606
 
5174
2607
  IMPROVEMENTS:
5175
2608
 
5216
2649
 
5217
2650
 
5218
2651
bzr-0.0.7 2005-09-02
5219
 
--------------------
5220
2652
 
5221
2653
  NEW FEATURES:
5222
2654
 
5266
2698
 
5267
2699
 
5268
2700
bzr-0.0.6 2005-08-18
5269
 
--------------------
5270
2701
 
5271
2702
  NEW FEATURES:
5272
2703
 
5348
2779
 
5349
2780
 
5350
2781
bzr-0.0.5  2005-06-15
5351
 
---------------------
5352
2782
  
5353
2783
  CHANGES:
5354
2784
 
5484
2914
 
5485
2915
 
5486
2916
bzr-0.0.4  2005-04-22
5487
 
---------------------
5488
2917
 
5489
2918
  ENHANCEMENTS:
5490
2919
 
5548
2977
 
5549
2978
 
5550
2979
bzr-0.0.3  2005-04-06
5551
 
---------------------
5552
2980
 
5553
2981
  ENHANCEMENTS:
5554
2982
 
5589
3017
 
5590
3018
 
5591
3019
bzr-0.0.2.1
5592
 
-----------
5593
3020
 
5594
3021
  PORTABILITY:
5595
3022
 
5597
3024
 
5598
3025
 
5599
3026
bzr-0.0.2  "black cube"  2005-03-31
5600
 
-----------------------------------
5601
3027
 
5602
3028
  ENHANCEMENTS:
5603
3029
 
5625
3051
 
5626
3052
 
5627
3053
bzr-0.0.1  2005-03-26
5628
 
---------------------
5629
3054
 
5630
3055
  ENHANCEMENTS:
5631
3056
 
5652
3077
 
5653
3078
 
5654
3079
bzr-0.0.0.69  2005-03-22
5655
 
------------------------
5656
3080
 
5657
3081
  ENHANCEMENTS:
5658
3082