/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to doc/developers/uncommit.txt

  • Committer: John Arbash Meinel
  • Date: 2009-10-29 16:15:43 UTC
  • mto: This revision was merged to the branch mainline in revision 4780.
  • Revision ID: john@arbash-meinel.com-20091029161543-tdqlm2l4e2z5o7le
We don't have to pad 'short' records.

When writing a row, we reserve 120 bytes from the first node so that we
can write our 'B+Tree Graph Index' signature and other meta-information.
For the root node, we don't always use the 120 bytes, and for non-root
rows, we don't use that data at all. So we usually pad back that
record. However, for indexes that fit entirely in the root record,
we don't pad them to 4096, and it turns out we don't need to pad
them with the spare 120 bytes either.

I was doing a test with lots of 'chained' btree indexes, and this
extra padding ended up being 4.6M => 4.3M of wasted space. I imagine
that bzr-search will have a similar issue with tiny indexes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
Uncommit Performance Notes
 
2
==========================
 
3
 
 
4
Specification of uncommit
 
5
-------------------------
 
6
 
 
7
``uncommit`` removes revisions from the head of a branch.  (By default, only
 
8
the very latest revision is removed, but optionally more can be taken.)
 
9
Uncommit does not affect the repository (garbage collection is a separate
 
10
step and not done by default).  The working tree is not logically
 
11
modified (revert is a different operation), except as described below
 
12
about merges.
 
13
 
 
14
Uncommit can be performed on either a branch or a working tree (and
 
15
implicitly its branch.)
 
16
 
 
17
If the uncommitted revisions includes one or more merges, after the
 
18
uncommit those revisions are in the working tree's list of pending merges,
 
19
because their tree changes are still present in the tree.
 
20
 
 
21
For a bound branch, uncommit fails unless the local branch is up to date.