summaryrefslogtreecommitdiff
path: root/xdelta1/NEWS
blob: 6bbcbf9c6a7a01f7435e08316faed47b08b22893 (plain)
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
XDelta NEWS -- history of user-visible changes. -*- Text -*-
$Date: Sun, 24 Feb 2002 11:31:12 -0800 $
$ReleaseVersion: 1.1.4 $

Please send bug reports to xdelta-bugs@XCF.Berkeley.EDU.  See the file
`README' for a description of how to report bugs.


** Changes since version 1.1.3

* Add an implementation of xdp_generator_free() for users of the
  libxdelta API.  Previously there were no such users of the 1.x API,
  but Elliot Lee <sopwith@redhat.com> has written a program for
  providing delta operations on RPM files.  See http://@@@

* The man page now documents return values.

** Changes since version 1.1.2

* Correct error message format for the case when gzread fails trying
  to automatically decompress a corrupted GZIP file.  The situation
  itself--corrupt GZIP files--should be dealt with the -p (--pristine)
  option, which disables GZIP file recognition.  Reported by Ben
  Escoto.

* Apply a patch from Klaus Dittrich for building on HPUX with the
  native compiler.  There is now a script called "contrib/build_hpux".


** Changes since version 1.1.1

* This code release is a distant fork of the 2.0 release.  It will
  hopefully be replaced.

* When 'patch' supplies its default TO file name recorded in the
  delta, it still generates a unique file name to avoid overwriting an
  existing copy.  Use the 'xdelta info' command to see what file names
  are contained in the delta.

* The code for writing patches to stdout was broken in the case where
  gzip compression is used.  Writing patches to stdout has therefore
  been disabled.  The problem is a limitation in the gzdopen/gzwrite
  functions provided by zlib--you cannot determine how many bytes have
  been written to the file descriptor without dup-ing the FD
  beforehand and then lseek-ing afterwards, which does not work
  correctly if the output file is not seekable.

* By default, Xdelta uses a hard-coded 16 byte block size.  If you're
  working with large files, try #undef XDELTA_HARDCODE_SIZE in
  xdelta.h then use -s BLOCKSIZE (--blocksize=BLOCKSIZE), which should
  be a power of 2.

* New test program in the 'test' subdirectory, which runs comparisons
  against "diff --rcs -a" and also verifies the "xdelta patch"
  command.

* Incorporate DJGPP patches from Richard Dawe <richdawe@bigfoot.com>.
  You can find his versions directly at:

      ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2apps/xdlt112b.zip
      ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2apps/xdlt112s.zip

* Updated xdelta(1) man page.

* Updated autoconf (2.50), automake (1.4-p4), libtool (1.4) scripts,
  which includes updated config.guess and config.sub scripts.

* Correct some backward compatibility issues: strcmp() was not being
  tested == 0 for formats older than 1.0.4.

* Update GLIB version requirement, now 1.2.8.

* We really need support for 64bit file sizes...  perhaps the next
  version?


** Changes since version 1.1.0

* No one was were able to build the 1.1.0 release because it depended
  on a version of glib which will not be distributed for some time.
  This version backs out those dependencies and now requires
  glib-1.2.1.


** Changes since version 1.0.6

* The 64M limit on file sizes has been lifted.  File lengths are now
  limited by the size of a 32-bit integer.

* The internal data structures were changed and some of the
  experimental bits of the interface have been moved out of libxdelta,
  resulting in a simpler interface.  Old patch files are still
  supported.


** Changes since version 1.0.5

* There are 8 bytes of space in the patch format's header that are
  reserved for future use.  They are not currently used, but were also
  not being initialized, making it possible for two deltas produced in
  the same manner to differ.  This was exposed by comparing deltas
  produced between the same files on Windows and Linux.  With this
  patch, the results should be identical.


** Changes since version 1.0.4

* The code now compiles natively under Windows.  I used MS VC++ 5.0.
  It depends on glib and zlib, but I don't feel like documenting
  the build process yet.  I have had some trouble with the zlib DLLs
  and had to build my own, so you can't build it yourself yet.  There
  is a pre-built version at

     ftp://ftp.xcf.berkeley.edu/pub/xdelta/xdelta-1.0.5.win32.zip

* Many changes required to keep Xdelta working with PRCS 2.  Mostly
  this involved keeping up to date with some code that is shared
  between the two.  All the shared code is now in the "libedsio"
  subdirectory, which stands for "Error Delivery and Serialized IO".


** Changes since version 1.0.3

* Slight change in file format to improve detection of and error
  messages regarding corrupt deltas (specifically, those left behing
  when an xdelta process is killed while computing a delta).  This
  means 1.0.0-1.0.3 will not read these new deltas, they will report a
  bad magic number.

* Improve several error messages related to corrupt deltas.


** Changes since version 1.0.2

* Fix a few bugs, especially one related to the implementation of -m,
  and a couple more which were shaken out by testing on a pair of
  emacs releases (~55M each).  These changes only affect the xdelta
  application, the library is unchanged.

* Add a new command `xdelta info' that lists information about a
  delta, for example:

    $ xdelta info some.patch
    xdelta: version 1.0.3 found patch version 1.0 in some.patch
    xdelta: patch contents are compressed
    xdelta: patch from:          from
    xdelta: patch from length:   53309440
    xdelta: patch from md5:      c0ddcb6904d40da7cf1eae5e6bdbbc01
    xdelta: patch to:            to
    xdelta: patch to length:     55377920
    xdelta: patch to md5:        00b3dd4d1a9b450bc5b8991b183013fb
    xdelta: patch insert length: 2436426
    xdelta: patch inst count:    253649


** Changes since version 1.0.1

* Fix minor typos, and build improvements.  There is now a gtk-style
  'xdelta-config' program and autoconf macro to locate the library.


** Changes since version 1.0.0

* Fix incorrect usage report in --help output for the patch command.

* Abort when directories are specified, there is no recursive mode.

* Now requires glib-1.1.5.

* The new ``pristine'' option (-p, --pristine) disables
  automatic uncompression of compressed input data, and is for use
  when data integrity is being externally verified.  This enables a
  tool written by Manish Singh (yosh@gimp.org) to compute deltas
  between the Debian dpkg utility's .deb format.

* A draft paper describing its algorithms, rational, advanced
  features, and future work is now available at
  ftp://ftp.xcf.berkeley.edu/pub/xdelta/xdelta.ps.

** Changes since version 0.24

* This version is a complete rewrite, and removes some of the features
  available in version 0.  Featuring:

  - A completely new and much improved library interface.  This code is
    a complete rewrite.
  - An optimized implementation of the XDelta algorithm.
  - A drastic memory reduction.
  - The library stream-processes files where possible and uses a page-
    based interface when seeking is required (allowing the application
    to run in bounded memory on large files).
  - There is now a little documentation.  A man page and the
    beginnings of texinfo documentation.
  - Includes several advanced features used by PRCS version 2, see the
    documentation for more information.
  - Includes a minimal implementation of the Rsync algorithm, also used
    by PRCS version 2.
  - Uses an abstract file handle interface, the library has very few
    system dependencies.  This allows the library client to compute
    MD5 checksums in a single-pass as XDelta reads files, use pre-
    computed checksums, or disable checksum verification entirely.
  - Compression and file-unarchival have been removed from the library,
    these features are orthogonal.

  At the application level:

  - GDBM archive experiment has been removed.  This functionality is
    implemented directly in PRCS version 2 using the present library
    interface.
  - Base 64 encoding support has been removed for technical reasons.
  - Can no longer accept patches from stdin, due to the same
    technical reasons (the patch instruction index is stored at the
    end of the file, requiring seeking).
  - Automatic detection and un-archival of RPM and dpkg file formats
    has been removed.  Automatic uncompression of gzipped files is
    still supported.
  - The GIMP plugin is no longer supported.