~bzr-pqm/bzr/bzr.dev

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
End of Line Conversion
======================

EOL conversion is provided as a content filter where Bazaar internally
stores a canonical format but outputs a convenience format. See
``bzr help content-filters`` for general information about using these.

Note: Content filtering is only supported in recently added formats,
e.g. 1.14.

EOL conversion needs to be enabled for selected branches and files using
rules. See ``bzr help rules`` for general information on defining rules.

To configure which files to filter, set ``eol`` to one of the values below.
(If a value is not set, ``exact`` is the default.)

 ============== ============================== ======================
 Value          Checkout end-of-lines as       Commit end-of-lines as
 ============== ============================== ======================
 native         crlf on Windows, lf otherwise  lf
 -------------- ------------------------------ ----------------------
 lf             lf                             lf
 -------------- ------------------------------ ----------------------
 crlf           crlf                           lf
 -------------- ------------------------------ ----------------------
 exact          No conversion                  exactly as in file
 ============== ============================== ======================

Note: For safety reasons, no conversion is applied to any file where a null
byte is detected in the file.

For users working on a cross-platform project, here is a suggested rule
to use as a starting point::

  [name *]
  eol = native

If you have binary files that do not contain a null byte though, be
sure to add ``eol = exact`` rules for those as well. You can do this
by giving more explicit patterns earlier in the rules file. For example::

  [name *.png]
  eol = exact

  [name *]
  eol = native

If your working tree is on a network drive shared by users on different
operating systems, you typically want to force certain conventions for
certain files. In that way, if a file is created with the wrong line
endings or line endings get mixed during editing, it gets committed
correctly and gets checked out correctly. For example::

  [name *.bat]
  eol = crlf

  [name *.sh]
  eol = lf

  [name *]
  eol = native

If you take the care to create files with their required endings, you can
achieve *almost* the same thing by using ``eol = exact``. It is slightly
safer to use ``lf`` and ``crlf`` though because edits accidentally
introducing mixed line endings will be corrected during commit for files
with those settings.

If you have sample test data that deliberately has text files with mixed
newline conventions, you can ask for those to be left alone like this::

  [name test_data/]
  eol = exact

  [name *]
  eol = native

Note that ``exact`` does not imply the file is binary but it does mean
that no conversion of end-of-lines will be done. (Bazaar currently relies
of content analysis to detect binary files for commands like ``diff``.
In the future, a ``binary = true`` rule may be added but it is not
supported yet.)

If you have an existing repository with text files already stored using
Windows newline conventions (crlf), then you may want to keep using that
convention in the repository. Forcing certain files to this convention
may also help users who do not have rules configured. To do this, set
``eol`` to one of the values below.

 ========================= ============================== ======================
 Value                     Checkout end-of-lines as       Commit end-of-lines as
 ========================= ============================== ======================
 native-with-crlf-in-repo  crlf on Windows, lf otherwise  crlf
 ------------------------- ------------------------------ ----------------------
 lf-with-crlf-in-repo      lf                             crlf
 ------------------------- ------------------------------ ----------------------
 crlf-with-crlf-in-repo    crlf                           crlf
 ========================= ============================== ======================

For users working on an existing project that uses Windows newline
conventions in their Bazaar repository, this rule is suggested as a
starting point::

  [name *]
  eol = native-with-crlf-in-repo

For new projects, it is recommended that end-of-lines be stored as lf
and that users stick to the basic settings, i.e. ``native``, ``lf``,
``crlf`` and ``exact``.

Note: Bazaar's EOL conversion will convert the content of files but
never reject files because a given line ending or mixed line endings
are found. A precommit hook should be used if you wish to validate
(and not just convert) content before committing.