doc: clarified btool -X in its man page
[barry.git] / ChangeLog
blob673264d11f6d236d097cc7d1e5d88fdf71d5a2b8
1 Release: version 0.17.0 - 2010/01/??
2 ------------------------------------------------------------------------------
3 2010/11/16
4         - doc: clarified btool -X in its man page
5 2010/11/09
6         - doc: updated Fedora's RPM git repo URL
7 2010/11/02
8         - added library dependency info to pkg-config .pc files
9         - cleaned up constructor and initialization order and pointer
10                 issues found by the automatic API tester at:
11                 http://linuxtesting.org/upstream-tracker/versions/barry.html
12 2010/11/01
13         - lib: fixed header bugs
14         - maint: added abi checker scripts and config
15 2010/10/28
16         - changed the versioning sheme for Barry, updating doc/VersionNotes,
17                 src/Makefile.am, and ChangeLog
18         - updated maintainer scripts to support 3-number versions
19 2010/10/20
20         - lib: simplified parser and builder API, using the new DBData class
21                 This also updates the DBData class to support copy-on-write
22                 in construction, to avoid copies wherever possible.
23                 Also, this patch affects a lot of code, and it is all
24                 updated at once.
25 2010/10/18
26         - lib: removed needless data copy in Socket::Packet()
27         - lib: moved command/response buffers into Desktop class itself
28         - lib: added DBData and DBLoader... these classes make it possible
29                 for the programmer to control the database record loading
30                 process, instead of using the parser callback mechanism...
31                 this is the beginning stage of adding generic data flow
32                 channels to Barry, to hopefully make it easy to pass
33                 data from backup files to devices, from device to device,
34                 from backup to backup, and more
35 2010/10/14
36         - lib: fixed timeout mismatch behaviour between USB and Router
37                 The default timeout (-1) for usbwrap is about 30 seconds,
38                 while the default timeout (-1) for the DataQueues used
39                 by the Router is forever.  The router now accepts a default
40                 read timeout of its own, and defaults to the same 30
41                 seconds as usbwrap.
42 2010/10/13
43         - a number of build tweaks for compiling command line tools
44                 on Windows
45 2010/10/07
46         - made bcharge more flexible... Dual mode is not the default anymore,
47                 since newer devices seem to present themselves in a sane
48                 manner via USB.  Instead -o and -d only happen if specified.
49                 This patch also adds a new option, -g, which will set dual
50                 mode only if Interface Class 255 (database) is not found.
51                 Also updated the udev rules to use -d and -g as appropriate.
52         - reverted commit c7685942140b123bf110e755ce11a97c3c6372f7 (the
53                 UnrouteableReadError patch) since it was discovered that
54                 usb bulk reads of 0 bytes are possible and valid
55 2010/10/05
56         - doc: added note about --with-libintl-prefix=/opt/local/ on Mac OSX
57                 Thanks to Toby Gray for reporting this.
58 2010/10/04
59         - merged from Toby Gray:
60                 - missing header in builder.h
61                 - added try/catch in SimpleReadThread()
62                 - added fallback to set_altinterface() in probe
63         - added gettext.h convenience header to support --disable-nls
64                 Toby Gray discovered that when --disable-nls is used or
65                 on systems that do not support <libintl.h> well, it
66                 is recommended to use the gettext.h header as specified
67                 in the gettext documentation:
68                 http://www.gnu.org/software/gettext/manual/gettext.html#lib_002fgettext_002eh
69                 This commit adds gettext.h to both tools/ and the gui/
70         - lib: added Builder::BuildDone() to make the multiple-call
71                 possibility of Retrieve() more explicit
72         - lib: added Pipe class to join builders and parsers together
73 2010/10/02
74         - lib: added start of libbarrybackup, and copied tarfile support
75                 from gui
76         - lib: added DBName support to parsers and builders
77         - lib: added BackupError and RestoreError exceptions
78         - lib: removed the dbId from Builder::Retrieve()
79         - tools: changed parser/builder auto_ptr to shared_ptr
80         - added libbarrybackup*.pc file to install target
81         - lib: added EndOfFile() to Builder
82         - lib: added Backup parser and Restore builder classes
83                 These classes are based on the backup and restore logic of
84                 the GUI's DeviceIface.cc code, but made general.
85         - tools: added tar backup option to btool (!)
86 2010/10/01
87         - lib: cleaned up missing BXEXPORT / BXLOCAL flags for exceptions
88                 http://gcc.gnu.org/wiki/Visibility
89         - lib: fixed build bug where GCC visibility flags were missing from
90                 the libbarrysync library
91         - merged clear halt fixes from Toby Gray, which should make it
92                 possible to use Barry and usb-storage at the same time
93 2010/09/30
94         - merged build fixes from Toby Gray
95         - merged UnroutableReadError exception patch from Toby Gray
96         - moved platform specific detail into tools/platform.h
97 2010/09/21
98         - merged constant and timeout fixes from Toby Gray
99         - lib: added belt-and-suspenders fix to usb Read functions
100                 This is to avoid the possibility of inappropriate asserts
101 2010/09/20
102         - removed ppa_build.sh per request by Martin Owens
103         - debian: added autopoint to build deps
104                 The new Debian Squeeze and Ubuntu Maverick have split out
105                 the autopoint script from the gettext package.  On systems
106                 with gettext 0.18 or newer, we require autopoint, and hope
107                 that autopoint depends on gettext.
108 2010/09/19
109         - further split up the m4 directories to make the submodules
110                 yet more independent
111         - debian: added back the autoreconf targets, but not cleanup targets
112 2010/09/18
113         - debian: remove all autoreconf and cleanup targets
114                 Having the debian/rules files try to manage their own
115                 autoreconf is too much of a headache.  Binary packages
116                 should start with a valid autoconf and gettext / autopoint
117                 system already in place.
118                 This patch removes any temptation to believe otherwise.
119                 If you have been building source packages from git
120                 already, just add a call to "./buildgen.sh" before your
121                 debian binary build.
122         - maint: overhaul of release / test build scripts
123                 Made scripts configurable by user, in case others have
124                 chroot build systems of their own.
125 2010/09/16
126         - debian: updated rules to allow for building with an external debian/
127         - applied Martin Owens' patch to add a debian directory to
128                 the opensync-plugin-0.4x plugin
129         - debian: moved 0.22 plugin packaging to its own directory
130 2010/09/15
131         - set AC_CONFIG_AUX_DIR to [.] instead of parent directory, to make
132                 the submodules more independent
133         - lib: fixed Makefile.am to install semaphore.h and scoped_lock.h
134                 This is needed for the raw channel code.
135 2010/09/11
136         - added -A option to bjavaloader save
137 2010/09/07
138         - added hardware contribution section to AUTHORS
139 2010/09/03
140         - merged Toby Gray's and Adrian Taylor's RAW channel support code
141         - updated debian binary package with brawchannel and examples and
142                 ppp chat scripts as docs
143         - updated rpm barry.spec with brawchannel and ppp README
144 2010/08/31
145         - os4x: optimized dirty flag clearing
146                 Clearing the dirty flags on newly updated records requires
147                 a reconnect, but it only requires one reconnect, and no
148                 reconnect it needed if nothing is written to the device,
149                 so skip the reconnect whenever possible, which makes syncing
150                 much faster
151 2010/08/30
152         - lib: use thread-safe getpwuid_r() in config file code
153 2010/08/18
154         - fixed build bug, where libbarrysync was still used even if glib2
155                 was not found on the system.  Thanks to Eric Arseneau
156                 for finding this during his Mac build testing.
157         - added LTLIBINTL and LTLIBICONV to tools/Makefile.am for systems
158                 that have separate libraries for these features, such as
159                 the Mac
160         - buildgen.sh calls libtoolize and glibtoolize now (Mac support)
161 2010/08/15
162         - lib: fixed bug in ISO timezone detection... must be in [-+]HH[:]MM
163                 format, with 2 digits for the hours and minutes
164 2010/08/12
165         - lib: added better ISO timestamp support... Now handles timestamps
166                 with dashes and colons, including timestamps with their
167                 own timezone offsets
168         - lib: fixed vsnprintf() error check bug in log.cc... and added
169                 code to allocate memory if message is too long for
170                 static buffer
171 2010/07/29
172         - applied patch from Martin Owens fixing version dependencies in
173                 debian binary packages
174 2010/07/22
175         - gettext: removed autogenerated files and generate them in buildgen.sh
176                 Not sure if the version will matter, but since gettext 0.17
177                 is the only gettext version in common use (Ubuntu 10.04
178                 doesn't even have 0.18 yet) we'll stick with it for now.
179                 Hopefully 0.18's autopoint is smart enough to update things
180                 automatically.  I don't have 0.18 to test with.
181 2010/07/21
182         - applied Nicolas Vivien's compile fix and French translation patches
183 2010/07/20
184         - sync: added 1 second wait during Reconnect() to let firmware settle
185                 This seems to help prevent the firmware hang fixed yesterday,
186                 which ultimately speeds up the whole sync
187         - os4x: reverted run-as-process undo commit... now runs as process
188                 again... I believe the timeout was the firmware issue, not
189                 an opensync issue
190 2010/07/19
191         - lib: added ability to do a USB ClearHalt() from socket level
192         - lib: added ability to override USB default timeout from controller
193         - sync: added workarounds for firmware hang issue
194                 This workaround overrides the timeout due to a firmware
195                 issue: sometimes the firmware will hang during a plugin
196                 Reconnect(), during the shutdown stage when the plugin
197                 attempts to update the device's dirty flags.  When the
198                 device hangs like this, it fails to respond to a
199                 Desktop::Open().  To work around this, we set the default
200                 timeout to 15 seconds so that we find this failure early
201                 enough to fix it within opensync's 30 second timeout.
202                 Then if we get such a timeout, we do the Reconnect again and
203                 hope for the best... this often fixes it.
204 2010/07/17
205         - lib: added tm_to_iso() to tzwrapper functions
206         - lib: vbase now has default implementation of vTimeConverter (was
207                 vTimeZone) with a simpler API, based on TzWrapper underneath
208         - lib: pulled in os4x vbase code, so both plugins are using one
209                 set of vformat code
210         - lib: added vtodo and vjournal vformat support from os4x plugin
211         - deb: added new libbarrysync library to debian binary package
212         - tools: added -V option to btool, to output in the new MIME vformat
213                 mode for records that are supported
214 2010/07/16
215         - lib: added BARRY_GCC_FORMAT_CHECK() for printf() style arg checking
216         - lib: added C-style BarryLogf() function for internal use
217         - libsync: moved vformat-related code from os22 to library
218         - lib: included tzwrapper in Barry and Barrified the namespace
219 2010/07/13
220         - os4x: undo run-as-process setting, since some tests indicate that
221                 sync will timeout
222 2010/07/10
223         - ppp: copied barry-sprint to barry-telus, which also works
224                 Thanks to Matt McGirr who confirmed it works with Telus
225         - os4x: run plugin as process... other opensync plugins seem to run
226                 better with this, and it seems like a good idea to isolate
227                 plugins as much as possible
228 2010/07/08
229         - fixed bug in both opensync plugins where they would attempt to
230                 access a database, even if it was disabled in the config.
231                 Thanks to R. Brent Clements for reporting this bug.
232 2010/06/26
233         - added Pete Zaitcev's usbmon-6, with some minor changes to
234                 remove root requirements and pretty up the hex dump format
235 2010/06/12
236         - applied chat scripts for Orange Spain from Adrian Gibanel
237         - updated debian and rpm packages with new chatscripts
238 2010/06/04
239         - os22: ported Nicolas Vivien's multi-calendar patch to 0.22 plugin
240                 From commit: eb4d68df8d06f734e79e13ea05f7755aa5b0a5f3
241                 This patch is untested with multiple calendars as I don't
242                 have a device for such testing, but is identical to
243                 the 0.4x plugin code.
244 2010/06/03
245         - doc: added wireshark USB capture method to USB-capture.txt
246         - lib: added GetStore() access function to RecordParser template class
247         - lib: Improved the record class operator<() member functions, basing
248                 the sort order on multiple fields in many cases.  This should
249                 produce a fairly stable sort for a given data set, regardless
250                 of RecordId.  This should be useful for scripted tests.
251         - tools: Added -I command line option to make use of new sort order
252         - man: Updated btool manpage
253 2010/05/29
254         - applied 3 patches from Nicolas Vivien that add:
255                 - Calendar - All parser
256                 - special handling for syncing of multiple calendars
257                 - compiler fixes
258         - lib: updated src/s11n-boost.h with new CalendarID and CalendarAll
259         - lib: refactored Calendar*::Dump() functions
260                 note: this introduces a change in my earlier policy that
261                 avoided virtual functions in the record classes...
262                 the duplicate code overhead is just too heavy, and
263                 I think I was wrong to be afraid of virtual functions
264                 in containers anyway... vive la virtual! :-)
265 2010/05/28
266         - rpm: added Fedora 13 support, and cleaned up conditionals
267         - udev: fixed permissions issue, so device shows up in lsusb
268                 output even for users not in plugdev
269         - applied two patches from Nicolas Vivien, one fixing a precision
270                 bug in BuildField() and another adding a 64bit BuildField()
271 2010/05/13
272         - lib: fixed compile error in j_message.h
273                 Thanks to Raymond Blostein for the bug report and the
274                 link to the explanation of the C++ standard change:
275                 https://bugs.launchpad.net/inkscape/+bug/522327/comments/1
276 2010/05/11
277         - ppp: cleaned up ppp options files and put notes in README
278                 Thanks to feedback from Matt Machado for Rogers specific
279                 notes, and for recommendation to have one copy of
280                 comments for the PPP options.
281 2010/04/19
282         - lib: added LDIF mapping support for Contact::Image fields
283         - lib: fixed signed extension bug in base64 encoder
284         - sync: ported Photo support from 0.4x plugin to 0.22 plugin
285 2010/03/30
286         - updated Fedora and Mandriva maintainer info
287 2010/03/18
288         - added chat script for FIDO from Sujay D'Souza
289 2010/03/11
290         - added Probe::Find(), for simple searching of probe results
291 2010/02/09
292         - added message during restore, to let user know that the erased
293                 database was restored (requested by Pierre Pietri)
294 2010/01/29
295         - added product ID 8001 (Pearl Flip) to udev rules
296 2010/01/26
297         - examples: added dbdump.cc example for extracting database data
298         - bumped the copyright dates for 2010
299         - added F12 build target to maintainer scripts
300         - added missing BXEXPORT to src/configfile.h that shows up
301                 on ubuntu 7.10
302         - added headers to sources list in src/Makefile.am, since header
303                 changes didn't always cause a library rebuild
304 2010/01/15
305         - updated barry.spec to install 69-blackberry.rules on Fedora 12
306                 note that this further breaks the opensuse build, but
307                 that is not currently supported anyway, due to lack of time
308         - doc: added notes on tools to use for building RPMs in homedir
309 2010/01/04
310         - udev: added 69-blackberry.rules for Fedora 12 systems. Thanks
311                 to Nathanael Noblet (list email dated 2009/12/30)
312                 for hunting this down!
313 2009/12/15
314         - lib: added operator==() to ProbeResult, and operator!= to Pin
315         - os22: fixed bug while loading opensync config file (may not load
316                 the pin number correctly, or may rely on luck)
317         - added 'addmemo' example, to test newline behaviour
318         - lib: Memo::Dump() now translates \r chars into prettier output
319                 Requested by Michael Brown
320         - doc: added some notes on how to tether via Bluetooth
321 2009/12/04
322         - tools: added libbarry to bdptest build (needed on opensuse?)
323 2009/12/03
324         - lib: added GetKey/SetKey support in GlobalConfigFile
325 2009/12/02
326         - gettextize BarryBackup by Nicolas VIVIEN
327         - lib: added support for a global config file
328                 Barry::ConfigFile now supports a per-device configuration (as
329                 usual) as well as a global config file.  Both are loaded
330                 by default, but they can be saved and loaded separately.
331                 This new global config file is for global defaults,
332                 preferences, etc.
333         - lib: added IsVerbose() API call
334         - lib: added VerboseLogging setting to global config
335         - lib: made Probe results more storage friendly
336 2009/11/27
337         - made Barry::Init() safe to be called multiple times
338         - added Barry::Verbose() for controlling debug output on the fly
339 2009/11/26
340         - moved the Pin and ConfigFile classes from gui/ to the library
341         - Probe now loads ConfigFile's device name if available
342 2009/11/24
343         - added '-P' password option to upldif tool, and updated manpage
344                 including applying Nicolas Vivien's bugfix patch
345         - applied Nicolas Vivien's "NOT_ENOUGH_MEMORY" javaloader patch
346         - added gettext support to RPM and DEB packages
347 2009/11/19  
348         - gettextize by Nicolas VIVIEN
349 2009/10/02
350         - doc: added list of reasons why to submit patches, and notes
351                 on how to create a forked tree on repo.or.cz
352 2009/10/01
353         - removed redundant library dependencies from autoconf build
354         - version bump:
355                 - configure.ac
356                 - src/Makefile.am
357                 - src/version.cc
358                 - gui/src/BackupWindow.cc
359                 - Doxyfile
360                 - rpm/barry.spec
361                 - debian/changelog
362                 - opensync-plugin/src/barry_sync.cc
363                 - opensync-plugin-0.4x/src/barry_sync.cc
365 Release: version 0.16 - 2009/10/01
366 ------------------------------------------------------------------------------
367 2009/09/30
368         - added PNG generated icon based on SVG source files
369         - added barry logo to barrybackup-gui Debian and RPM packages
370         - applied new barry logo and icon from Martin Owens
371         - gui: use short barry URL in About box
372         - gui: fixed bug where actual finished records were overwritten
373                 with the starting total... don't overwrite the actual
374                 with the estimated
375         - gui: added thread state, to determine what operation finished
376                 Also improved status message, specifying exact operation
377         - gui: added code to check that actual # of backed up records
378                 matches the total number reported by the device, and
379                 display a warning to the user if they don't match
380         - www: added known issue about international chars and protocol change
381 2009/09/29
382         - os4x plugin: updated for the pkgconfig libopensync -> libopensync1
383                 rename
384         - added bjdwp.1 manpage
385         - added bjdwp and manpage to rpm and debian packages
386         - added bash and zsh completion scripts to debian & rpm packages
387 2009/09/26
388         - gui: fixed status text during restore (said "Backup" instead
389                 of "Restore")
390 2009/09/24
391         - updated various URLs to point to netdirect.ca
392         - lib: moved vSmartPtr<> from opensync plugin code to main library
393         - lib: fixed memory leaks in vSmartPtr (doh!)
394         - lib: added vLateSmartPtr<> for setting of FreeFunc after construction
395 2009/09/18
396         - updated opensync 0.4x plugin to compile against latest SVN
397                 - removed unneeded osync_error_unref() from get_sync_info()
398                 - updated plugin to support the new OSyncError** arguments
399                         scattered all over the code
400 2009/09/17
401         - added IRC info to contact www doc page
402 2009/09/16
403         - changed all the ancient SYSFS{} keynames into ATTRS{} keynames
404                 in all udev rules files
405         - added udev rule for BB Tour Product ID 8007
406                 Thanks to Theodore Charles III for testing and suggested
407                 rules.
408         - removed obsolete duplicate SUBSYSTEM keynames from udev rules
409         - created new cross-distro udev rules set, with documentation
410                 in udev/README
411         - updated deb and rpm package rules with new udev rules set
412                 note: opensuse needs work
413 2009/09/15
414         - merged Josh Kropf's brimtrans fix: 59abfa6959eb350221fa56a03ba5816
415         - applied bash-completion scripts by Ryan Li
416 2009/09/14
417         - merged Josh Kropf's compile fixes
418         - applied zsh missing bracket patch from Ryan Li
419 2009/09/11
420         - merged Nicolas Vivien's debug parser lib updates
421                 with change:
422                 - fixed API spelling typo and capitalization
423         - added firmware upgrade to TODO list
424         - added checks for pthread function errors in Thread class
425         - moved #defines out of public dp_codinfo.h into dp_codinfo.cc
426                 Applications probably don't care about these.
427         - changed string arguments to const references
428         - added STL-style typedefs to list classes to make looping easier
429                 and easier to change types if needed
430         - added libbarrydp as dependency for libbarryjdwp
431         - replaced direct cout usage with dout() in dp_codinfo.cc
432                 - added Barry::Init to bdptest.cc, defaulting to verbose
433                   mode, to keep the same behaviour as expected
434         - use more generic std::istream in dp_codinfo, instead of ifstream
435         - use references with iterator looping to avoid copies, and
436                 use const where appropriate
437         - added typedef for j_server.cc's ConsoleCallbackType
438         - tightened up member variable init and cleanup in JDWServer class
439         - added exceptions in JDWServer class where marked TODO
440         - made setup sequence dependent on previous steps, in acceptThread,
441                 so that the logic doesn't assume success where it could
442                 have failed
443 2009/09/10
444         - added copyright notices to all source files in bjdwp/
445                 This is based on the initial README included in
446                 the patches from Nicolas Vivien stating that bjdwp
447                 was under the GPL.
448         - added GPL license as file bjdwp/COPYING, since bjdwp is
449                 somewhat standalone, like the plugins and the gui
450         - bjdwp: removed jdwplog() in favour of identical barryverbose()
451         - bjdwp: moved into main tree from bjdwp/ and created two new
452                 libraries: libbarrydp and libbarryjdwp
453 2009/09/09
454         - fixed potential loss of serial data during PPP init
455                 when seding the AT test, usually the OK response is
456                 sent to the callback, but if the expected non-serial
457                 response doesn't appear, the OK is lost... this fix
458                 passes the OK to the callback, which fixes some chatscript
459                 behaviour
460         - gui: updated web documentation and screenshots
461 2009/09/08
462         - changed wording on GUI reload button to clarify what it does
463         - added documentation on how to change the theme for GTK+ apps
464                 when not using the Gnome desktop environment
465         - fixed broken links in web doc generation
466 2009/09/05
467         - applied backup GUI patches from Ryan Li:
468                 - resolved crash while disconnecting from no devices
469                 - added confirmation dialog before quitting
470         - gui: handled case where the user exits via window manager Close
471                 button
472                 - also refactored 'working' confirmation logic
473 2009/09/04
474         - fixed socket RawReceive verbose log message
475                 when reading from the default queue, the queue knows the
476                 endpoint, not the socket object
477 2009/09/03
478         - added version output when -v is used in pppob
479 2009/09/02
480         - fixed syncing of 8 contact phone numbers. Reported by
481                 Ian B. MacDonald, 2009/08/22
482         - ported above syncing fix to opensync 0.4x plugin
483         - applied Martin Owens' Barry logos 'patch'
484 2009/09/01
485         - applied chatscript patch from Andrew Nording
486                 Sourceforge tracker #2848549
487         - added KPN chatscripts to DEB and RPM binary packages
488         - added KPN to script list in doc/www/modem.php
489         - pulled from Nicolas Vivien: a909925ef6bf3d75b1597a9ddd16f52201690cbb
490                 Fixes for library and bjdwp documentation
491         - moved bjdwp/doc/* to doc/bjdwp/ to keep docs in one spot
492 2009/08/31
493         - pulled from Nicolas Vivien's repo.or.cz repo: bjvmdebug support
494                 With rebase changes and fixes to library.
495                 Fixes to library:
496                 - fixed buffer size checks in m_jvmdebug.cc
497                 - used #defines instead of hard coded numbers where possible
498                 - added FIXME to tidy up the Unknowns in the API
499                 - commented out Mode::Close(): not convinced that applications
500                         should have to worry about socket-level details
501                 - added #define for JVM STOP command
502                 - removed unused Socket::PacketJVM() functions
503                 - made sizeof check in JVMPacket::Size() more specific
504                 Rebase changes:
505                 - removed executable chmod bits from BarryDemo java samples
506                 - removed copyrighted Sun documentation from bjdwp/doc/
507         - fixed longstanding buffer size check bug in CheckSize()
508         - updated AUTHORS
509         - applied Ryan Li's latest threaded GUI patch (2009/08/25 email)
510                 - gui: added a wrapper around pStatusbar->push() to avoid
511                         the never ending push syndrome
512         - gui: added PIN to the "please name new device" dialog
513         - gui: added statusbar workaround: normally the statusbar shows
514                 Ready after initialization, but since the initial Scan()
515                 happens right away, and the statusbar doesn't seem to
516                 update the screen until the handler is finished,
517                 we update the status bar during init instead
518 2009/08/30
519         - applied Martin Owens' ppa_build.sh patch
520         - added version output when -v is used in btool
521         - changed USB verbose bus tree dump (i.e. btool -v) so the
522                 hex/decimal values look more like lsusb -v output,
523                 for ease of debugging
524 2009/08/29
525         - version bump:
526                 - configure.ac
527                 - src/Makefile.am
528                 - src/version.cc
529                 - gui/src/BackupWindow.cc
530                 - Doxyfile
531                 - rpm/barry.spec
532                 - debian/changelog
533                 - opensync-plugin/src/barry_sync.cc
534                 - opensync-plugin-0.4x/src/barry_sync.cc
536 Release: version 0.15 - 2009/08/28
537 ------------------------------------------------------------------------------
538 2009/08/28
539         - added binary build for Ubuntu 9.04 to maintainer scripts
540 2009/08/27
541         - added binary build for Fedora 11 to maintainer scripts
542 2009/08/21
543         - updated www documentation for upcoming release
544         - applied Nicolas Vivien's phone duplication patch (opensync 0.4x)
545         - fixed missing conflict check in vcard code in opensync 0.4x plugin
546         - backported new TYPE parsing code from opensync-0.4x plugin to
547                 old opensync 0.22 plugin
548         - added X-EVOLUTION-UI-SLOT support in both sync plugins to retain
549                 phone number order
550 2009/08/17
551         - added pin and password command line support to bfuse
552         - updated bfuse man page
553 2009/07/29
554         - added border to barrybackup doc images
555 2009/07/28
556         - updated license and URL in barry.spec
557         - updated barrybackup Credits dialog to reference AUTHORS file
558         - updated barrybackup.1 man page
559         - updated doc/www scripts to generate more dynamic pages,
560                 so subheaders are not hard coded... this helps support
561                 updating the new NetDirect website
562         - commented out out-of-date docs in hacking.php
563         - marked milestone 4 complete (javaloader)
564         - linked device compatibility list from index.php
565 2009/07/10
566         - changed pppob to report if Serial was fallback or command line
567         - started device compatibility list in web docs
568 2009/07/07
569         - applied Ryan Li's GUI enhancement patches, which let the user
570                 switch devices without restarting, with fixes:
571                 - reorganized BackupWindow.glade for better spacing
572                         - fixed width issue (main window was set to 275
573                           width, which made things too narrow on Debian
574                           Lenny
575                         - moved buttons beside the drop down box, to
576                           mimic old GUI behaviour
577                         - added space around the middle controls, but
578                           not around the menu bar or status bar, which
579                           should be right against the outer window.
580                 - renamed m_device_num to m_device_count for clarity
581                 - changed m_device_count to unsigned int to fix compiler
582                   warnings
583                 - removed gtkmm call to unset_model()
584                   The function unset_model() is only available in gtkmm
585                   2.16, and Debian Lenny only has 2.12, and won't compile.
586                   Since set_model() automatically does the unset for us,
587                   just reorganize the calls so Lenny is supported.
588 2009/07/06
589         - applied Ryan Li's SMS clarification patch
590 2009/07/02
591         - added Martin Owens' new Ubuntu PPA link to docs
592         - added DEPUTY documentation and updated AUTHORS
593 2009/06/30
594         - documentation updates
595                 - added SMS to list of parsers in documentation
596                 - updated sync notes for Fedora 9 and 10 in documentation
597                 - removed Martin Owens' PPA binary package link, since
598                         I can't find the binaries anymore
599         - reverted commit 2d0e60d1: put hal fdi files back
600         - updated HAL FDI files for Fedora 11
601                 - duplicated directory hierarchy under hal
602                 - added 19-blackberry-acl.fdi to add the access_control
603                         capability to blackberry devices when they are
604                         plugged in.  As long as this file is under
605                         the 10osvendor directory, then
606                         20-acl-management.fdi runs after it, adding
607                         the hal-acl-tool callout, which does the low
608                         level getfacl/setfacl work on the /dev/bus/usb/*/*
609                         device file.
610                 related thread:
611         http://lists.freedesktop.org/archives/devkit-devel/2009-June/000247.html
612         - changed hal fdi policy to use "pda" instead of "scanner"
613         - applied Ryan Li's 7-bit GSM conversion patch for SMS records
614         - applied Ryan Li's barrybackup patch: can now select backup path
615 2009/06/26
616         - fixed install location of hal fdi files in debian and rpm
617                 HAL reserves /usr/share/hal/fdi/information/10freedesktop
618                 for files that the project itself distributes, so
619                 we get to use 20thirdparty.
620 2009/06/24
621         - cleaning up autoconf warnings on Fedora 11
622         - changed buildgen.sh to run libtoolize first for all subprojects,
623                 otherwise, a later project's run may copy files into ../m4
624                 after having created configure for a previous project.
625                 This would cause a makefile discrepency during the build
626                 on some systems (Fedora 11), and cause configure to be
627                 incorrectly regenerated mid-build, due to timestamps.
628 2009/06/21
629         - updated dependencies documentation page
630 2009/06/20
631         - added BadPacket exception, for socket errors that need to meddle
632                 with the response code
633         - added special case for JavaLoader's Goodbye packet
634                 On older devices, such as the 7750 and 7130, they respond
635                 with a NOT_SUPPORTED error instead of an ACK, for Goodbye
636                 packet commands.  This is seen in Windows traffic as well,
637                 so should not be considered an error.  Thanks to Josh Kropf
638                 for confirming this protocol behaviour.
639         - updated socket.cc to use new BadPacket exception where appropriate
640         - pulled from Josh Kropf: 0f1cca2fa69d0810d439ade4fb3dd0dfa15c89a6
641                 - fixed size issue with deviceinfo command on 7130 devices
642 2009/06/19
643         - reworked autoconf rules to handle every kind of Boost dependency:
644                 - let user enable/disable from configure, default to
645                         disable, but error if enabled and not available
646                 - let user specify separate include and lib paths, since
647                         some Boost installations have an additional
648                         boost-1.34.1 style directory in them
649                         - default to no path overrides, using system defaults
650                 - let user specify name of serialization library, since
651                         the name of the library can change whether you're
652                         building from source or not
653                         - default to searching for boost_serialization or
654                                 boost_serialization-mt, and error if not found
655                 - New configure switches are:
656                   --enable-boost                   Handles enable/disable
657                   --with-boost-include=path        Override the include path
658                   --with-boost-lib=path            Override the lib path
659                   --with-boost-serialization=name  Override the name of
660                                                    serialization library
661                                                    to link with
662         - updated documentation, build test, and binary packages to use
663                 new switches
664 2009/06/18
665         - added non-backward-compatibility note to man/btool.1
666         - applied Nicolas Vivien's LDIF patches, clarifying split
667                 between work and home addresses, and adding support
668                 for the homePostalAddress LDAP field
669         - fixed missing #includes for Fedora 11.  Thanks to
670                 Nathanael Noblet for reporting this.
671         - applied Ryan Li's PPP chat script for China Mobile
672         - added barry-chinamobile chat script to RPM and Debian packages
673         - renamed blacklist-berry_charge to blacklist-berry_charge.conf
674                 for Debian sid and Fedora 11.  Thanks to Rodrigo Linfati
675                 for reporting.
676         - applied Nicolas Vivien's autoconf patch to automatically
677                 search for boost_serialization or boost_serialization-mt
678 2009/05/12
679         - applied Dr. J A Gow's category patches (task + memo)
680                 - fixed compile error when using Boost
681                 - cleaned up Categories handling:
682                         - s11n-boost.h
683                         - Dump() should be consistent across Calendar, Memo, Task
684                         - fixed i18n support to category names
685                 - cleaned up code formatting to match surrounding code
686         - moved CategoryList to its own class, and removed duplicated
687                 string conversion code
688         - removed protocol-specific MemoType and TaskType fields from
689                 their corresponding record classes
690 2009/05/09
691         - applied Nicolas Vivien's Task builder patch for the Storm
692                 and Bookmark documentation patch
693 2009/05/08
694         - applied most of Dr. J A Gow's recurring iCal sync patch
695                 - did not include the pure upper case changes, since
696                   it is an RFC bug in SynCE
697                   see http://www.mail-archive.com/barry-devel@lists.sourceforge.net/msg01109.html
698                 - added starttime to RecurToBarryCal() args, to make the
699                   prerequisites clear (StartTime must be determined before
700                   recurrence is parsed)
701                 - added check that COUNT is not zero (RFC requirement)
702                 - fixed timezone drift: using gmtime() + mktime() uses two
703                   different timezones... use localtime() + mktime()  instead
704                 - comment resizing
705                 - reformatted if/else FREQ tests into a more readable
706                   sequence, and fixed a logic error in the yearly count
707                   advance, which should only happen when FREQ == YEARLY
708         - updated AUTHORS
709 2009/05/06
710         - going through www documentation, updating for 0.15
711         - updated man/btool.1 with new -a option
712         - updated TODO list with new reality
713         - applied Nicolas Vivien's phone call log parser patches
714                 - added CallLog to s11n-boost.h
715                 - added size checks to parser
716                 - removed CallLogType, since it is protocol specific
717                 - added and tidied comments
718                 - made CallLog::Clear() match the class declaration order,
719                   fixed missing member, and used enum names to set
720                   enum defaults
721 2009/05/05
722         - applied Nicolas Vivien's task sync patches, with btool updates
723                 - fixed "VTOTO" typo
724                 - now that there's a Desktop::ClearDatabase() call,
725                   use it in SaveDatabase() to reduce code duplication
726                 - use separate vector<> clearDbNames in btool
727                   to eliminate chance of mixing -d and -a argument
728                   types and losing data
729                 - reverted VNOTE change in vformat.c
730                 - added VFORMAT_JOURNAL support to vformat.c based on
731                   r2795 of the opensync vformat plugin
732         - fixed some TimeZoneValid flag mistakes in Task and Calendar
733         - display DueDateFlag in src/r_task.cc
734         - changed vtodo.cc so DTSTART is only set if available in BB data
735 2009/05/01
736         - applied Nicolas Vivien's zsh patch
737         - applied Nicolas Vivien's memo sync patch
738                 - added MEMO_TYPE 'm' to built memo record
739         - updated btool to include new Memo builder
740         - updated config.rpath to latest from Debian stable
741 2009/04/27
742         - removed free() in tarfile.cc, since some distros have bugs in
743                 th_get_pathname() that doesn't return a freeable string
744 2009/04/22
745         - fixed some missing headers as reported by Christopher Stover
746         - applied Ryan Li's SMS body null terminator strip patch
747                 - fixed code formatting issues
748                 - added comment on why we're stripping out nulls
749                 - fixed potential single byte buffer overflow
750         - pulled from Josh Kropf: 8266c95a94
751                 added "reset to factory" command to bjavaloader
752         - split creation of deb src tarballs into separate script
753                 instead of tar-create.sh
754         - added more statements for the m4/ directory in configure.ac
755                 and Makefile.am, attempting to eliminate build warnings
756                 on FC10, as reported by Christopher Stover
757 2009/04/14
758         - applied Nicolas Vivien's sscanf patch (opensync-0.4x)
759         - wrapped OSyncList in vSmartPtr<> to automatically handle
760                 all calls to new osync_list_free() API
761         - applied Ryan Li's updated SMS parser patch
762                 - moved SMS metadata structure into its own struct
763                         in protostructs.h
764                 - fixed some endian conversion errors
765                 - added strnlen() call to avoid null terminators in
766                         the Addresses strings
767 2009/04/10
768         - added brimtrans to rpm spec file and debian install
769 2009/04/09
770         - fixed OSyncList* leak in 0.4x plugin from call to
771                 osync_plugin_info_get_objtype_sinks()
772 2009/04/08
773         - added IConvHandle, making it possible to support more than one
774                 charset in Blackberry data
775         - removed patches from opensync-plugin-0.4x 'make dist' target
776         - updated buildtest.sh for opensync 0.4x
777 2009/04/06
778         - updated man/bjavaloader.1
779 2009/04/04
780         - added Product ID 8001 for the Pearl Flip.  Thanks to John Ladan
781                 for reporting the new ID.
782 2009/04/03
783         - removed 0.22 opensync patches from 0.4x tree
784         - applied opensync Photo support patches from Nicolas Vivien
785         - renamed SequencePacket() to HideSequencePacket() for clarity
786                 This is a temporary measure... this sequence packet
787                 code needs to be cleaned up.
788         - added Photo support to examples/addcontact.cc
789         - removed try/catch from vcard/vevent, pending feedback from Nicolas
790         - applied Ryan Li's SMS record parsing patch
791                 - changed capitalization to match other code
792                 - added Sms to s11n-boost.h and required operator
793                 - added Sms to btool.cc, record.h, and Makefile.am
794                 - added size checks to the parser code
795                 - cleaned up brackets and casting
796                 - made dump output prettier (at least to me) :-)
797                 - added "unknown" state for MessageStatus, as default
798                 - cleaned up whitespace
799         - updated AUTHORS
800         - added endpoint override to Probe class while testing the 7130
801                 When using btool's -e option, the Probe class still
802                 attempted to probe endpoints as it saw fit.
803 2009/04/02
804         - fixed double-free bug in opensync 0.4x plugin
805                 Can only report error or success once in a change.
806         - updated buildgen.sh to handle ctags for multiple opensyncs
807         - fixed inverted logic when doing a hashtable slowsync (opensync 0.4x)
808         - fixed uninitialized osync_trace args in both vformat.c files
809 2009/04/01
810         - opensync 0.4x changes due to upstream API updates
811                 - removed idmap and cache code, in favour of opensync's
812                         uid mapping and hashtables respectively
813 2009/03/31
814         - opensync 0.4x changes due to upstream API updates
815                 - removed deprecated opensync header
816                 - updated 0.4x plugin to use new slow-sync API
817                 - updated 0.4x plugin to use new function registration and
818                         user data API
819                 - updated 0.4x plugin to use new sink list (API change)
820 2009/03/27
821         - changed PIN format from decimal to hex in opensync-0.4x plugin
822                 config
823         - added special case so photo data does not print raw in btool dumps
824         - fixed call to trace.logf() in plugin code... should never call
825                 a printf-like function unless you use a constant "%s"
826         - made opensync-0.4x:vformat.c's base64 routines const-correct
827         - fixed free()-crash bug in both vformat.c files
828                 When generating the resulting VCARD data, vformat.c assigned
829                 static strings to a dynamic heap list pointer, and the
830                 later free always failed.
831         - merged some changes from Jose Sogo's Debian package work
832                 - menu changes to conform with policy
833                 - renamed opensync plugin package name to match Debian
834         - added Nicolas Vivien and Josh Kropf to debian/copyright
835         - fixed uninitialized variable in SocketZero
836         - fixed memory leak in tarfile.cc
837         - fixed uninitialized time struct in bjavaloader.cc (valgrind error)
838 2009/03/24
839         - fixed typo in zsh/_bjavaloader thanks to feedback from Nicolas V.
840         - pulled from Josh Kropf: 75b1a89e8b1eb9d89bcd8b5ecbed9a47af5a8930
841                 added logstacktraces support to bjavaloader
842         - updated TODO list with "- All" database parsing
843 2009/03/13
844         - added git tag signing to maintainer scripts
845         - added signed tagging to release checklist doc
846 2009/03/11
847         - updated opensync-plugin-0.4x/README with build help
848 2009/03/10
849         - pulled from Josh Kropf: d6c3173ccd87c6223647950963da79331a68d712
850                 added deviceinfo support to bjavaloader
851         - pulled from Josh Kropf: 272f371e8bb95b6c41a8293de657da45a782736f
852                 new tool: brimtrans for dealing with RIM USB logs
853         - pulled from Josh Kropf: 7ed1df560ea7cc6a2205d8f8627c00c7aaed2294
854                 added wipe support to bjavaloader
855         - added confirmation step to bjavaloader wipe, so it is harder to
856                 accidentally wipe your device
857         - applied zsh patch from Nicolas Vivien for bjavaloader wipe
858 2009/03
859         - changes inspired from Rick Scott's XmBlackberry
860                 - event log timestamp is a time_t in milliseconds
861 2009/03/07
862         - added Mode base class for common mode class code
863 2009/03/06
864         - reorganized external links by date and topic, and added link
865                 to Nicolas Vivien's Blackberry on Linux documentation
866 2009/03/05
867         - pulled from Josh Kropf: b3d3a6f48fe008e8842c057df4a653a04b9c56ce
868                 - compile fix when using __DEBUG_MODE__
869                 - fixed timeout when calling JavaLoader::GetDir on device
870                         with zero modules
871 2009/03/04
872         - fixed embarrassing incorrect exception messages in usbwrap.cc
873                 Fortunately, these didn't affect my timeout testing.
874         - added Data::QuickZap(), so that usb read errors don't
875                 return old data
876         - inlined Data::QuickZap()
877         - added usb_set_altinterface() call to Interface class
878                 This should hopefully workaround the change in 2.6.28
879                 kernels where set_interface is not called by the kernel
880                 automatically anymore.
881 2009/03/03
882         - applied Nicolas Vivien's opensync-0.4x API patch
883 2009/02/28
884         - applied Nicolas Vivien's zsh patches
885 2009/02/26
886         - added opensync-0.4x to tar-prepare.sh maintainer script
887 2009/02/24
888         - added note about novj option issue in barry-att_cingular
889         - added gettext to documentation dependency list (for iconv.m4)
890 2009/02/20
891         - clarified bjavaloader save behaviour
892         - updated bjavaloader man page
893         - added maintainer/build as exception for test/buildtest.sh
894         - merge opensync-0.4x branch into master:
895                 2009/02/20
896                         - removed nested m4 in preparation for merge into
897                           main Barry tree
898                 2009/02/18
899                         - applied Nicolas Vivien's opensync-0.4x
900                           Calendar+Contact patch
901                 2009/02/01
902                         - applied Nicolas Vivien's opensync-0.4x
903                           porting update patch
904         - removed unneeded ChangeLog.osync
905         - added opensync-plugin-0.4x to top level configure, but not to
906                 binary packages
907         - added old emails from Ron Gage from 2006 regarding Autotext
908                 and Service Book parsing
909 2009/02/19
910         - pulled from Josh Kropf: 9b63a99867b3314b8d42212cac05a6f28860d37b
911                 - saving large modules in pkzip format
912                 - cleaned up StartStream function; use JLPacket instance
913                 - refactored SendStream; use JLPacket instance and use simple
914                         function for seeking to next cod file in input stream
915         - made following changes to Josh Kropf's patches
916                 - Added CODFILE_TYPE_SIMPLE check back in
917                 - Minor change of c_str() to data() where a null terminator
918                         is not needed
919                 - Fixed unlikely buffer overflow in m_javaloader.cc
920                         Goal: never trust outside sources of
921                         information (including that from the device) when
922                         managing our own buffers.
923                 - Removed CodFile forward declaration, since class does not
924                         exist anymore
925                 - Fixed typo in configure.ac, and made missing zlib warning
926                         more emphatic
927                 - Added clarifying comment to CodFileBuilder
928                 - Fixed potential reference bug in CodFileBuilder constructor
929                         It is possible that the const std::string& passed
930                         into the constructor is a temporary, so make a copy
931                         of it instead of just holding a reference.
932                 - Removed multi-unget call in cod.cc -- only one unget() is
933                         guaranteed in C++.  It appears that the unget is
934                         unnecessary, since the following code seeks to end
935                         and back to beginning anyway.
936                 - Added copyright line for Josh Kropf in cod.cc and
937                         cod-internal.h
938                 - Fixed incorrect zlib check, since zlib doesn't support
939                         pkg-config on most systems yet.  Changed it to
940                         use AC_CHECK_LIB, and added a --with-zlib configure
941                         option which will cause configure to halt if
942                         zlib is not available.  Added --with-zlib to
943                         binary package builds, and to build test script.
944         - added zlib to rpm and deb build requirements list
945 2009/02/18
946         - updated USB capture logs archive page with new logs from Josh Kropf
947         - applied as patch Josh Kropf's annotated javaloader-reset.txt log
948         - added note about windows registry keys to USB-capture.txt
949 2009/02/17
950         - applied Josh Kropf's patch adding support for forced erase and
951                 load while module in use, properly handling when the
952                 device requests a reset
953 2009/02/15
954         - applied Nicolas Vivien's RecordId patch for Contact class...
955                 this updates Barry to deal with the new record ID behaviour
956                 on the Storm
957 2009/02/13
958         - removed unneeded call to .c_str() in EmailAddress stream operator
959         - added support for Calendar fields: Organizer, Accepted, Invited
960         - reorganized the udev/ script directory, based on distro,
961                 and added a specific rules file for openSUSE 11.1
962         - updated Debian and RPM binary scripts to point to correct udev files
963 2009/02/07
964         - applied Nicolas Vivien's patch to fix the timeout issue on the
965                 Blackberry Storm
966 2009/02/04
967         - applied Josh Kropf's save module patch
968                 - minor whitespace fixes
969                 - removed unneeded exception (fstream closes files
970                   automatically on exit of scope, or exception)
971                 - fixed compile error with variable sized array...
972                   replaced with std::vector<> instead of memcpy,
973                   in JavaLoader::SaveData()
974                 - commented out an unused variable
975 2009/02/03
976         - commented out AT+CREG? in barry-rogers.chat, since it causes some
977                 Blackberry devices to reboot
978         - applied Josh Kropf's eventlog and clear eventlog patches
979                 - capitalized JLEventlogEntry fields, to match other
980                   record classes
981                 - use constant when parsing entry
982                 - renamed a define
983         - sweeping cleanup of record classes and clarified all constant
984                 conversions i.e. whenever converting between a protocol
985                 constant and an API constant, do it through a function,
986                 in case the constants change on the Blackberry side
987 2009/01/31
988         - applied patch of binary VSM file from Robert Yaklin
989 2009/01/30
990         - moved Nicolas Vivien's codfile code into library class API
991                 - this change avoids having packed structs exposed in
992                   installable header files, and gives the library
993                   user an easy way to work with COD files
994                 - added CodFile class
995                 - added JavaLoader::LoadApp(CodFile&)
996                 - cleaned up bjavaloader to use new API
997                 - moved codfile_*_t structs to internal header
998                 - also fixed command line status output when exceptions
999                   are caught (unrelated fix)
1000         - added / updated manpages: bfuse, bjavaloader, btool
1001         - added fuse to build dependencies for rpm and deb packages
1002         - updated web docs, adding libfuse to dependencies page
1003                 - added libiconv as well
1004 2009/01/29
1005         - applied screenshot and zsh patch from Nicolas Vivien
1006           His git log, as posted to the mailing list, was:
1007                 Remove bscreenshot binary
1008                 Add screenshot option to bjavaloader binary
1009                 Add comments in the code
1010                 Use defines beside of integer constant
1011                 Use b2hons to be compliant with evrywhat host
1012                 ZSH scripts completion
1013                 Use BMP structs beside of unreadable buffer !
1014           His changelog notes:
1015                 - add command GetScreenShot to JLPacket class
1016                 - add JLScreenInfo to protocol structures
1017         - updated AUTHORS
1018         - minor tweaks to Nicolas's screenshot+zsh patch:
1019                 - renamed DIR_ENTRY and SS_ENTRY to DATA_ENTRY constant
1020                   as suggested by comments
1021                 - fixed some packet size checks
1022                 - whitespace fixes
1023                 - removed unneeded packet.GetReceive(), since response
1024                   buffer is the same as what GetReceive() returns
1025                 - used AutoClose for fopen() calls in bjavaloader.cc
1026                   for exception safety
1027                 - removed manual buffer handling in favour of Data object
1028                   in JavaLoader::GetScreenshot()
1029         - removed "unknown packet" exception from Socket::PacketData()
1030                 I think it is probably better to handle javaloader-level
1031                 errors and codes in the JavaLoader class, not the low-
1032                 level Socket class.
1033         - added erase and force erase support to bjavaloader, library, and zsh
1034                 - force erase is experimental
1035         - applied documentation patch from Robert Yaklin on VSM file format
1036                 - did slight formatting changes before applying, for 80
1037                   columns, and set file to unix format instead of DOS
1038         - added links to new USB capture logs from Robert Yaklin to
1039                 logs.php doc page
1040         - cleaned up src/Makefile.am, regarding non-install headers
1041         - moved Nicolas Vivien's bitmap conversion code into library API
1042                 - added bmp.h api, and moved internal structs to bmp-internal.h
1043                 - added size checks and endian conversion to bitmap
1044                   conversion code, so this code should run anywhere
1045 2009/01/27
1046         - added link Josh Kropf's 'Blackberry development in linux' blog
1047                 post to doc/www/index.php
1048         - added USB capture log archive page to www docs
1049         - added config.rpath, needed by new AM_ICONV check
1050                 Thanks to Bill Paul for debugging this.
1051         - applied Nicolas Vivien's opensync plugin 0.4x patch
1052 2009/01/26
1053         - added template wrapper for iconv() due to casting differences on
1054                 various platforms... thanks to Bill Paul for FreeBSD testing
1055         - added AM_ICONV automake/autoconf check to configure.ac
1056                 This should take care of checking for libc or library
1057                 iconv installs, and checking the iconv() prototype for whether
1058                 const is needed or not.  This removes the need for the
1059                 template added earlier.
1060 2009/01/25
1061         - applied patch from Josh Kropf making bjavaloader's syntax more
1062                 compatible with the windows version, to make cross
1063                 platform build scripts possible
1064         - applied Josh Kropf's settime syntax patch
1065         - clarified timezone behaviour in javaloader settime
1066         - added flag to JavaLoader mode class, so StopStream() is called
1067                 automatically in the destructor if not called manually
1068 2009/01/24
1069         - added another ctor to BadSize exception class
1070         - fixed bug in SocketZero where it checked sequence on packets
1071                 from non-zero sockets
1072         - javaloader list mode updates:
1073                 - added Dump() code to directory classes
1074                 - fixed size issue with JLDirEntry header size define
1075                 - fixed size checks in entry parser
1076                 - fixed copy before in JLDirectory, now uses vector
1077                 - moved bjavaloader's Start/StopStream calls to main()
1078 2009/01/23
1079         - removed default argument to CheckSize() so all code specifies
1080                 the size it really needs
1081         - fixed bug in ParseData() that didn't copy data to receive arg
1082         - adding additional javaloader commands and refactoring
1083                 this is a work in progress:
1084                 - added JLPacket class, encapsulating javaloader protocol
1085                 - added new defines for more JL commands
1086                 - refactored socket class, using PacketData()
1087                         for JL, and Packet() for Desktop (still needs
1088                         some work to be really clean)
1089                 - began implementing new commands (SetTime())
1090                 - thanks to Rick Scott for his reverse engineering effort
1091                         in XmBlackBerry, which inspired this code
1092         - refactored packet.cc to make JLPacket even tighter
1093         - updated doc/USB-capture.txt with link to vusb-analyzer
1094                 Thanks to Martin Owens for the link.
1095         - added a set of be_*() endian swap functions, for big endian data
1096                 JavaLoader code seems to use big endian a lot.
1097         - simplified bjavaloader.cc's command line args to make room for more
1098         - cleaned up big endian code to use new be_* swap macros
1099         - added protocol and packet code for directory / subdir commands
1100         - added preliminary directory support to JavaLoader class
1101 2009/01/22
1102         - reverted experimental handshaking in IpModem, since the session_key
1103                 patch fixed Bill Paul's issue
1104         - finished adding IConverter support to r_task and r_timezone
1105         - removed r_message_base.h from doxygen RecordParserClasses group
1106         - removed unused ClassType variable from Task record class
1107         - refactored Calendar and Task record classes, creating new
1108                 RecurBase to handle recurrence data
1109         - removed FIXME in Socket::Packet(), since socket is set in Send()
1110         - cleaned up socket handling and comments in packet.cc
1111 2009/01/20
1112         - applied Nicolas Vivien's javaloader patch, fixing constant defines
1113                 and other small fixes
1114         - minor whitespace and spelling fixes to above patch
1115         - changed m_ipmodem.cc to send the session key even without password
1116                 which should help reduce the "special packets" coming from
1117                 the device.
1118                 Thanks to Rick Scott and Andy Herkey.
1119 2009/01/17
1120         - refactored pthread timeout creation into ThreadTimeout() function
1121         - added experimental handshaking to IpModem.  This is in response
1122                 to Bill Paul's email regarding what he was seeing in the
1123                 logs with the special code packets which we dropped
1124                 on the floor.  This code is to test whether this handshaking
1125                 theory is true.
1126 2009/01/16
1127         - made maintainer script make-deb-local.sh more robust
1128         - added list of target binary packages in ReleaseChecklist.txt
1129         - changed to more general Fedora link to Chris Stover's packages
1130 2009/01/15
1131         - applied Andy Herkey's ipmodem password patch for the Bold
1132         - minor fixes to above patch, and in addition to above patch:
1133                 - use sizeof(seed), instead of type, in case of future changes
1134                 - removed commented out code
1135                 - added the null password check back to SendPassword(),
1136                   for historical reasons
1137                 - removed the null and zero default arguments to
1138                   SendPassword(), since they make no sense
1139                 - added define for session key size, and added size check
1140         - added missing string.h header to src/m_javaloader.cc
1141         - updated Debian and RPM packages to include bjavaloader
1142 2009/01/14
1143         - applied Nicolas Vivien's bjavaloader patch
1144         - small fixups to above patch:
1145                 - moved cod.h from installable headers to internal headers
1146                 - whitespace edits
1147                 - copyright statement tweaks
1148                 - added blog URLs to copyright list in cod.h where parts
1149                         of the structs appear to come from
1150                 - removed unused variables to compile with strict settings
1151                 - changed char to unsigned char to fix strict compiler
1152                         warnings
1153                 - removed duplicated a/b from Socket messages, and moved
1154                         read/write text to front, in socket.cc
1155                 - added NetDirect copyright notice to bjavaloader.cc, since
1156                         it is based on btool.cc
1157                 - removed unused boost-specific code from bjavaloader.cc
1158         - more fixes to above patch: (bjavaloader.cc specifically)
1159                 - moved cod.h back to installable headers, since tools/
1160                         programs depend on it... this should be fixed
1161                         or put in the library as a COD-reading API
1162                         so that applications don't need to worry about
1163                         packed files, etc.
1164                 - fixed potential buffer overflow: removed buffer read used
1165                         to skip ahead in file, and replaced with fseek()
1166                 - changed SendAppFile() to report errors by exception
1167                         instead of by return value, which wasn't checked
1168                         anyway... and C++'d the file handle closing
1169                 - removed unused StateTableCommand, leftover from btool
1170                 - added check for unlikely case of COD file being larger
1171                         than size_t, breaking the fread() assumption
1172                         for the type == 0xC0DE case
1173                 - added checks for fread() failures
1174                 - fixed compiler warnings when comparing signed/unsigned,
1175                         and changed file operation types from plain int
1176                         to size_t/off_t
1177         - changes to src/m_javaloader.cc:
1178                 - fixed comments to remove Desktop-oriented notes
1179                 - moved variables closer to their use point
1180                 - removed the duplicated response Data objects in favour
1181                         of just one (each default Data object uses 0x4000
1182                         bytes of heap)
1183                 - removed manual endian swap in favour of htobl()
1184                         - oops... this size field is actually big endian.
1185                           Since all Barry code assumes that Blackberry
1186                           protocol traffic is little endian, a special
1187                           case needs to be added in m_javaloader.cc for
1188                           this field.  The special case uses autoconf's
1189                           endian define.
1190                         - fixed long long problem in endian.h (ISO C++
1191                           compilers don't support long long) and made
1192                           the bswap() functions always available
1193                 - removed unused CommandType and m_commandTable members
1194                 - fixed exception error messages to indicate command #
1195                         instead of Desktop message
1196                 - changed Packet() call to PacketData() when sending
1197                         file size, since there is no command
1198         - added eout() data dump to socket::Packet() unknown send error
1199         - fixed my incorrect off_t/size_t check in bjavaloader.cc
1200         - removed the '0' JL_UNKNOWN4 command from src/protocol.h,
1201                 since the PacketData() change above now handles that,
1202                 and I don't think that byte is actually a command, but
1203                 really part of the uint32_t size
1204                 - Also fixed one remaining 0 command, to use PacketData()
1205 2009/01/09
1206         - added AT+CLAC note to contrib/modemtest.rb, recording tidbit
1207                 from mailing list
1208         - updated copyright dates for 2009
1209 2008/12/11
1210         - fixed missing slash in config sample in doc/www/sync.php
1211                 Thanks to sourceforge tracker #2413683 for reporting
1212 2008/12/01
1213         - added more notes to doc/USB-capture.txt, documenting my kernel
1214                 setup for capturing USB traffic, and added size-limiting
1215                 kernel patch
1216         - added TODO list item for the Blackberry Storm
1217 2008/11/30
1218         - moved Product ID constants into a single place (src/common.h)
1219                 and updated bcharge
1220         - added Product ID 8007 for the Blackberry Storm... needs testing
1221 2008/11/27
1222         - applied ppp chat script patch for AT&T Cingular from
1223                 Richard Esplin
1224         - added new chat scripts to debian and rpm packages
1225         - added known sources of additional Barry binary packages to index.php
1226         - turned on call/caller graph support in Doxygen output
1227 2008/11/23
1228         - applied 'patch' of Martin Owens' Content Store documentation
1229         - updated AUTHORS
1230 2008/11/22
1231         - large refactoring of all message/email record classes, and more
1232                 There is now a MessageBase base class, which combines
1233                 common email record parsing code in one class.  This base
1234                 class is reused by all the specific messages record classes.
1235                 This commit also includes support for multiple email
1236                 addresses per email, as well as giving IConverter support
1237                 to all message classes.
1238         - deleted empty *.cc files from project
1239         - updated TODO file, removing opensync i18n bug
1240         - added TODO item for password support in Opensync... try to avoid
1241                 storing the password in the sync config in plain text
1242         - fixed dll export bug on ErrnoError exception class
1243         - added BadPackedFormat exception for internal use
1244         - ServiceBook: added IConverter support, and general cleanup
1245                 Refactored ServiceBook class and added some experimental
1246                 template functions to generalize the FieldLink table
1247                 processing.  If possible, this needs to be expanded
1248                 to the general record classes, to reduce the amount of
1249                 code duplication during processing of FieldLinks and
1250                 CommonField structures.
1251                 Also, ServiceBook deals with packed fields, which should
1252                 also be extrapolated for general use, and reused if
1253                 possible for the new "Calendar - All" Blackberry databases
1254                 that are coming out on the new devices and firmare.
1255 2008/11/21
1256         - updated man/btool.1 with new -i option
1257         - fixed bug where opensync plugin didn't pass IConverter to Desktop
1258         - added IConverter support to r_calendar.cc
1259         - renamed utf8Needed to iconvNeeded, for consistency
1260         - added IConverter support to r_folder.cc
1261         - added IConverter support to r_memo.cc
1262         - added IConverter support to r_message.cc
1263         - added EmailAddressList, in preparation for multi-address email
1264 2008/11/20
1265         - changed Parser base class to pure abstract... this is so that
1266                 future API changes to the Parse base class will be
1267                 detected by the compiler as errors
1268         - added NullParser class, which performs the old Parser function
1269         - changed all FieldLink arrays to static
1270         - added new IConverter class to support converting the Blackberry's
1271                 WINDOWS-1252 charset to/from UTF-8 and more
1272         - fixed bug in IConverter that saved end of string instead of
1273                 beginning
1274         - reorganized barry.h app header and record.h header, so that
1275                 internal builds have fewer dependencies
1276         - large parser/builder API change, adding IConverter support
1277                 This change starts at the top (Mode::Desktop) which
1278                 takes an optional IConverter object for parsing and
1279                 building conversions.  The Desktop class passes
1280                 this IConverter object to Packet, Parser, and Builder (and
1281                 thereby, the corresponding Record classes) as needed.
1282                 This adds an extra pointer to a fair number of calls
1283                 in the stack, but maintains flexibility without putting
1284                 too much of a burden on Parser writers, which could be
1285                 application writers.
1286                 The primary use of this architecture is to pass in an
1287                 IConverter configured to convert to UTF-8... this is
1288                 basically the only useful conversion method, but others
1289                 are possible if you want to play.
1290         - first record class to support string conversions: Contact
1291         - reverted the barry.h and record.h reorganization, since
1292                 the gui depends on it
1293         - reorganized barry.h and record.h again, making inclusion of
1294                 the record headers dependent on whether it is a library
1295                 build or not
1296         - updated the gui with the parser/builder API change
1297         - added IConverter to opensync plugin, set to UTF-8
1298 2008/11/13
1299         - added comment to src/r_contact.h deprecating the Phone field
1300         - updated Doxyfile to 1.5.1
1301         - added Christopher D. Stover to AUTHORS file as Fedora contact
1302 2008/11/03
1303         - forgot #include <string.h> for memcpy/memset in tools/bfuse.cc
1304         - moved bfuse install point from /usr/sbin to /usr/bin
1305 2008/11/01
1306         - added FUSE filesystem "driver"
1307 2008/10/31
1308         - commented out the info.subsystem match level in HAL FDI file...
1309                 this should let the FDI work on old and new systems.
1310                 HAL version 0.5.8 (used by Debian Etch) has the deprecated
1311                 info.bus property, and doesn't have info.subsystem yet.
1312         - added HAL FDI scripts to rpm/barry.spec
1313         - fixed tools/Makefile.plain
1314 2008/10/30
1315         - added support for multiple work/home phone numbers to the
1316                 opensync plugin.
1317                 - Thanks to Richard Esplin for his test data.
1318                 - This fix has a conflict when a cell phone number is
1319                         marked as the preferred contact as well.
1320                         See http://sourceforge.net/mailarchive/message.php?msg_name=20081030231045.GA28989%40foursquare.net
1321                         for the full details.
1322                 - This fix also changes the VCARD output... pager phone
1323                         numbers are given the TYPE code of "pager"
1324                         instead of "msg".
1325                 - Added OtherPhone field as well
1326 2008/10/22
1327         - applied HAL FDI scripts and configuration from Martin Owens
1328         - updated AUTHORS file
1329         - added HAL FDI and python script to Debian package install
1330 2008/10/18
1331         - updated copyright notice and help text in contrib/modemtest.rb
1332         - changed barry-verizon.chat script according to Andy Herkey's
1333                 recommendation... this worked much better for Michael L.
1334                 Stokes, since his provider was getting stuck on the ATZ
1335 2008/10/16
1336         - applied Andy Herkey's modemtest.rb ruby script to contrib/
1337                 from his Aug 9, 2008 email to the mailing list
1338         - applied Andy Herkey's new modemtest.rb script to contrib/
1339                 from his Oct 8, 2008 email to the mailing list
1340         - added password pass-through code for pppob -s mode
1341         - clarified front page www doc, adding date of last release
1342                 and license
1343         - cherry-picked changes from Jose Carlos Garcia Sogo's debian git repo
1344                 - debian/rules was stripping wrong library names
1345                 - FSF address was incorrect (also updated other source
1346                         files throughout the tree myself)
1347                 - more complete debian/copyright file
1348 2008/09/24
1349         - version bump:
1350                 - configure.ac
1351                 - src/Makefile.am
1352                 - src/version.cc
1353                 - gui/src/BackupWindow.cc
1354                 - Doxyfile
1355                 - rpm/barry.spec
1356                 - debian/changelog
1357                 - opensync-plugin/src/barry_sync.cc
1358         - added link to doxygen documentation to www index.php
1360 Release: version 0.14 - 2008/09/24
1361 ------------------------------------------------------------------------------
1362 2008/09/24
1363         - changed Debian changelog version to 0.14-0 to make room for
1364                 official Debian packages which start at 0.14-1
1365         - moved Doxyfile from src/Makefile.am to Makefile.am
1366         - made RPM spec file match debian version number
1367         - www documentation updates for 0.14
1368 2008/09/19
1369         - fixed git-tagged-release.sh to not delete its own results... oops
1370 2008/09/18
1371         - fixed git command line in git-extract.sh for new 1.6.0.x behaviour
1372 2008/09/13
1373         - added notes in ReleaseChecklist.txt regarding the new tarball
1374                 tags in the git repos
1375 2008/09/12
1376         - updated doc/ReleaseChecklist.txt
1377         - moving items from private todo list to TODO file
1378         - removed unused variable from maintainer/git-release-tar.sh
1379         - added new maintainer/git-tagged-tar.sh, which puts more data
1380                 in the git repo, to make it easier for official Debian
1381                 package creation
1382         - moved src/Doxyfile to ./Doxyfile to avoid ".." in the config...
1383                 the ".." paths confused doxygen and caused it to generate
1384                 non-relative paths in the documentation.
1385         - added umask to maintainer/git-extract.sh, so it works even without
1386                 a pre-configured git
1387         - updated maintainer/tar-prepare.sh to match the new Doxyfile
1388         - added maintainer/tagged-release.sh, as replacement for the
1389                 release.sh top level script, when using git
1390         - removed CVS-style ID code from contrib/barry-unbind-storage.sh
1391                 since it made it look like cdfrey wrote it
1392         - removed doc/CodingStyle.txt as it is now documented in html
1393 2008/08/29
1394         - added device name and backup label support to the GUI
1395                 It is now possible to name devices, instead of just
1396                 operating by PIN number, and it is possible to now
1397                 add a text label to the backup tar filenames.
1398         - added the device names to the device selection dialog
1399 2008/08/26
1400         - updated TODO list with i18n opensync bug and general i18n support
1401         - added test suite to TODO list
1402 2008/08/23
1403         - renamed libbarry to libbarry0 in rpm/barry.spec
1404         - added %dump to rpm/barry.spec to match the OBS version
1405                 Makes it easier to track variable changes across
1406                 various distros.
1407         - added note to NEWS regarding binary package renaming
1408 2008/08/22
1409         - fixed logic error in breset that displayed error on success
1410                 Thanks to Richard Esplin for reporting this bug.
1411         - applied commit's from Jose Carlos Garcia Sogo's debian git repo
1412                 git://git.debian.org/git/users/jsogo/barry.git
1413                 - Add binary dependency of libbarry-dev on libusb-dev
1414                 - Rename libbarry to libbarry0, per debian policy
1415                 - Add exact dependency on binary:Version for every
1416                         -dbg and -dev package
1417                 - Bump Standards-Version to 3.8.0
1418         - updated AUTHORS
1419         - clarified barrybackup error message when no records available
1420                 Added a check so that "no databases selected" and
1421                 "no records available" are two distinct error messages.
1422 2008/08/21
1423         - applied ppp chat script patch from Mick Reed
1424         - updated RPM and Debian packages with new tmobileus ppp scripts
1425         - added T-Mobile US to web documentation
1426         - updated AUTHORS
1427         - clarified sync docs regarding slow-sync... avoid it if possible
1428         - tuned doxygen config, and moved generated files to doc/www/doxygen
1429         - added git-release-tar.sh, replacing CVS's make-release-tar.sh
1430                 Also added doxygen to the release tarball creation, so
1431                 the source code's doxygen documentation is automatically
1432                 generated upon release.
1433         - split git-release-tar.sh into reusable component scripts
1434 2008/08/14
1435         - added exception handler for invalid command line options in GUI
1436         - fixed barrybackup man page, removing bad -v option
1437         - added distro section to AUTHORS
1438         - fixed comment and whitespace problems in time.{h,cc}
1439         - Converted Birthday from string to Date, and added Anniversary
1440                 support.  Birthday and Anniversary fields now use a new
1441                 Date struct, and Barry validates the data to some extent.
1442                 - updated example code and opensync plugin to match
1443         - applied Lee Dixon's Location and Description plugin patch,
1444                 with minor whitespace edits
1445 2008/08/12
1446         - added Birthday field to examples/addcontact.cc for testing
1447 2008/08/11
1448         - applied Lee Dixon's Birthday field and opensync patch
1449                 - fixed coding format issues
1450         - updated AUTHORS
1451 2008/08/07
1452         - fixed bug in m_ipmodem.cc that included a null terminator in
1453                 first AT command
1454         - fixed RFC 2426 conformance bug...  RFC 2426, 3.1.1 states that FN
1455                 MUST be present in the vcard object.  If there is no name
1456                 available, then we use the Company name if available.  It
1457                 should be, since the Blackberry requires either name or Company
1458                 in order to create a new address.  If Company is blank too, then
1459                 we insert "(Blank Name)".
1460                 - On the flip side of this same bug, it is possible to receive
1461                         non-conformant vcard data from evolution / opensync
1462                         that does not include FN.  Since the Blackberry
1463                         doesn't require this information, remove the
1464                         exception, and only throw an exception if FN
1465                         or Company are both blank.
1466                 - REVERT: removed the Company and "(Blank Name)" workarounds,
1467                         and just produce an invalid vcard if no full name,
1468                         since with multiple syncing, this will come back
1469                         to bite us with duplicated Company name data
1470         - added sanity check to contact class for blank name and company
1471         - added BadData exception class, and documented it
1472 2008/08/06
1473         - fixed bug in vAttr::GetValue that ignored index for single valued
1474                 attributes... this should fix the endless loop / memory
1475                 exhaustion that some people have been seeing
1476                 Thanks to Lee Dixon for reporting this bug in detail!
1477         - added TODO list item for implementing recurring calendar items
1478 2008/08/01
1479         - version bump:
1480                 - configure.ac
1481                 - src/Makefile.am
1482                 - src/version.cc
1483                 - gui/src/BackupWindow.cc
1484                 - src/Doxyfile
1485                 - rpm/barry.spec
1486                 - debian/changelog
1487                 - opensync-plugin/src/barry_sync.cc
1488         - updated web docs showing how to set the password when using modem
1489         - added section to docs on how to test the modem connection
1491 Release: version 0.13 - 2008/07/28
1492 ------------------------------------------------------------------------------
1493 2008/07/28
1494         - web doc updates:
1495                 - removed extraneous "experimental" wording
1496                 - added section for external links to main index page
1497                 - fixed doc bug about how to install libtar
1498                 - added O2 Ireland to list of modem scripts
1499                 - removed ubuntu80464 and fc6 from binary package list
1500 2008/07/26
1501         - updated AUTHORS
1502 2008/07/25
1503         - applied barry-unbind-storage.sh script from Niels de Vos...
1504                 added to contrib for now, in the interests of getting
1505                 version 0.13 released soon... we can work on integrating
1506                 this better in 0.14, which hopefully won't take so long :-)
1507 2008/07/24
1508         - added g++ (>= 4.1) to Debian build dependency list
1509         - added support to base library and utilities for multiple email
1510                 addresses in Contact records
1511         - added opensync support for multiple contact email addresses
1512         - applied ppp chat scripts for O2 Ireland from Simon Kenyon
1513         - updated AUTHORS
1514         - integrated O2 Ireland scripts into binary package installs
1515 2008/07/16
1516         - applied David Mansfield's opensync module password patch (ported
1517                 manually to latest upcoming 0.13)
1518         - updated AUTHORS
1519         - added password documentation to sample barry-sync module config
1520         - updated web docs with new password sample config
1521 2008/07/05
1522         - removed old, unused spec file and scripts for bcharge-only release
1523         - fixed rpm build instructions in web docs
1524         - reduced minimum password retry level from 6 to 3... Reinhold Schoeb
1525                 reports that his 8800 device only lets him set a password
1526                 retry range between 3 and 5, instead of the usual 10 that
1527                 most devices have.
1528 2008/07/04
1529         - added "known issues" section to main www doc page
1530         - fixed virtual function mis-name bug in btool's null parser
1531         - added -i option to brecsum, to include record IDs in the sums
1532         - applied Ashley Willis's btool 0.12 null parser patch to CVS, which
1533                 required some manual porting changes...
1534                 - removed bool reference argument in GetParser()
1535         - updated AUTHORS
1536         - applied Ashley Willis's perlbarry package, putting it in the
1537                 new contrib/ directory
1538                 - updated AUTHORS
1539                 - now that btool patch is applied, don't need it in contrib
1540         - removed openssl from dependencies documentation, as barry now
1541                 has its own sha1 code
1542         - added libtool to dependencies documentation
1543         - rpm/barry.spec file now assumes gui and opensync, with conditional
1544                 checks depending which system it is being built on...
1545                 --with gui and --with opensync are no longer needed.
1546         - updated release scripts to build RPMs with the new spec file
1547 2008/06/26
1548         - updated udev rules to recognize devices with the 8004 Product ID
1549         - fixed bug in test/buildtest.sh when opensync is not pre-built
1550         - fixed more lintian warnings on Ubuntu
1551         - fixed tiny subheadings in modem web document
1552         - added syncing howto web document
1553         - updated TODO list, adding Troubleshooting item, and morphing
1554                 the modem item into the RPC daemon item
1555         - moved old doc/TroubleShooting.txt document to web, and updated
1556                 it in the process
1557         - added tip to sync web docs, for using DebugMode on hangs
1558 2008/06/23
1559         - changed test/buildtest.sh so it is safe to run from outside
1560                 the directory that contains it
1561         - added note to patch webpage regarding testing patches to the
1562                 build system
1563         - removed mis-configured 'make dist' check from buildtest.sh
1564         - added missing 'scoped_lock.h' to src/Makefile.am's non-installed
1565                 headers, as it is an internal header only
1566         - improved buildtest.sh: speed, accuracy
1567                 - added -j option to make to speed builds
1568                 - moved cleanall check above 'make dist' as dist doesn't
1569                         clean up after itself
1570                 - commented out 'make distcheck' for now, as it doesn't work
1571         - added DISTCHECK_CONFIGURE_FLAGS to root Makefile.am, similar to
1572                 David Everly's patch in tracker # 1973536
1573                 Thanks David!  'make distcheck' now works, but only in
1574                 an environment like buildtest.sh creates.
1575                 Also, buildtest.sh passes all tests now, including distcheck.
1576         - updated AUTHORS
1577         - removed unused src/controllertmpl.h
1578         - added ppp and test directories to Makefile.am EXTRA_DIST
1579 2008/06/21
1580         - added beginnings of a build system test script
1581         - fixed sha1.h so it is installed by src/Makefile.am
1582         - removed old Makefile.orig from src/Makefile.am
1583 2008/06/20
1584         - updated modem web documentation page with Sprint option, as
1585                 well as listing some network security concerns
1586 2008/06/19
1587         - added modem reset workaround to web documentation page
1588         - applied Andy Herkey's ipmodem password patch, round 1
1589         - applied Andy Herkey's ipmodem password patch, round 2
1590         - cleaning up some rough edges to the ipmodem patches:
1591                 - removed commented out code in pppob.cc
1592                 - added BXLOCAL to private member SendPasword()
1593                 - added try/catch in IpModem destructor
1594                 - removed FIXME comment about endian issues
1595                 - added data size checks to SendPassword()
1596                 - removed catch(...)
1597                 - renamed class variable session_key to match others
1598                 - added check to skip password if "" is passed in
1599                 - added the m_filter for ipmodem PPP 0x7e filtering
1600                   back, since the 8320 w/ rogers seems to need it
1601         - updated AUTHORS
1602 2008/06/06
1603         - added timeout argument to Device::BulkDrain()
1604         - added mozilla's sha1 code from git
1605         - removed openssl dependency due to license issues
1606                 Debian and Ubuntu have checks in their lintian tool that
1607                 check for GPL+OpenSSL linkage.  In order to remove any
1608                 potential obstacles to future inclusion in those distros,
1609                 the dependency is removed here in favour of the small
1610                 mozilla implementation which is GPL.
1611 2008/06/04
1612         - added notes to web documentation for OpenBSD
1613         - documentation updates:
1614                 - changed git patch command to use format-patch
1615                 - added instructions for building from tarball
1616                 - added bugs.php and contact.php pages
1617         - fixed missing and mis-dated copyright notices in src/
1618         - added ppp options and chat script for Sprint, based on
1619                 Andy Herkey's mailing list report
1620 2008/05/30
1621         - added Ubuntu 8.04 to release build scripts
1622 2008/05/29
1623         - fixed compile errors in gui when compiling with gcc 4.3.x
1624         - added ppp options and chatscript files to RPM build
1625         - updated docs with binary package default PPP scripts
1626         - added -P option to pppob to specify password
1627         - updated pppob manpage with -P option
1628         - fixed missing -P option in btool manpage
1629         - updated rpm spec file history
1630         - added pppob manpage to rpm spec file
1631         - added manpages for brecsum, breset, upldif, and barrybackup,
1632                 and updated the build process to support them.
1633                 Also updated date for pppob manpage.
1634         - updated rpm spec file with new manpages
1635         - added ProductID code 0x8004 to breset.cc
1636         - minor whitespace and usage text fix in upldif.cc
1637         - deleted old src/Makefile.orig
1638         - updated Debian binary package:
1639                 - added manpages for brecsum, breset, pppob, upldif,
1640                         and barrybackup
1641                 - added ppp options and chat scripts, with postinit
1642                         script to set permissions
1643                 - fixed descriptions in control file to avoid lintian warnings
1644 2008/05/27
1645         - fixed missing #includes in src/data.cc
1646         - fixed compile errors in library, utils, and plugin when compiling
1647                 with new gcc 4.3.x... gui not yet finished
1648 2008/05/24
1649         - added minimum g++ version to website dependency docs
1650 2008/05/23
1651         - added ppp/README
1652         - reorganized sample ppp options files so they are easier to compare,
1653                 enabled "usepeerdns" in both, and disabled the speed
1654                 setting in barry-verizon
1655         - updates to website documentation
1656                 - added FC9 to distro list
1657                 - added page for BarryBackup
1658                 - added page for USB modem / pppob
1659 2008/05/22
1660         - added sample ppp options files for Verizon Blackberries
1661                 Sample files from Michael L. Stokes
1662         - updated AUTHORS
1663         - renamed sample ppp peer files, in preparation for installing
1664                 them automatically in binary packages
1665         - modified verizon options file to use pppob
1666         - split the sample rogers options file into options and chat files
1667 2008/05/16
1668         - put sequence packet check directly in the SocketZero::RawReceive()
1669                 function, which now localizes all sequence packet
1670                 handling and checking, as well as avoids packet
1671                 order problems when multiple sockets are in use,
1672                 such as with pppob...
1673                 FIXME - this localized sequence checking may make all
1674                 the calls to CheckSequence() obsolete which
1675                 should probably be cleaned up someday, if so.
1676         - reorganized src/socket.cc to match class private/public
1677                 order (no code change, only move)
1678         - added verbose log message to Controller constructors, so it is
1679                 possible to determine whether a program is using
1680                 threaded or non-threaded sockets
1681         - added -z and -Z command line options to btool to control
1682                 the non-threaded/threaded behaviour, respectively;
1683                 and updated the man page
1684         - removed debug sleep() calls from pppob
1685         - added SIGINT signal handler so pppob shutsdown gracefully when
1686                 pppd is killed
1687 2008/05/15
1688         - mention CVS and git on main documentation "how to" list
1689         - moved PPP filter logic into its own class
1690         - enhanced PPP filter class to support prepending of
1691                 empty bytes if needed, in order to reduce data
1692                 copying, and clarified why there is no GetBuffer()
1693         - added ProbeResult::HasIpModem() to determine whether
1694                 IpModem endpoints are available
1695         - added pure virtual Modem base class for common
1696                 modem-oriented API (only Open and Write so far)
1697         - Mode::IpModem is now derived from Barry::Modem
1698         - experimental implementation for Mode::Serial,
1699                 which is now derived from Barry::Modem,
1700                 and uses PppFilter
1701         - pppob now supports IpModem and Serial modes, and logging
1702                 to file instead of stderr
1703         - added man page for pppob
1704 2008/05/10
1705         - modified the planned version numbering scheme in doc/VersionNotes,
1706                 so that a 1.0 is possible, with 1.50 as the devel series
1707 2008/05/09
1708         - continuing to update html documentation in preparation for
1709                 0.13 release
1710 2008/05/02
1711         - removed -fvisibility-inlines-hidden compile options since some
1712                 distros have old or broken compilers or libraries where
1713                 the build breaks looking for STL templates (Ubuntu 7.10,
1714                 I'm looking at you...)
1715         - changed brecsum so usage information is displayed automatically
1716                 if no command line arguments are specified
1717         - added opensync-plugin to maintainer test scripts, and added
1718                 ubuntu710 to the test build sequence
1719 2008/05/01
1720         - updated doc/TroubleShooting.txt
1721         - removed usb_control message check from IpModem endpoint probing
1722                 in src/probe.cc, since some devices, like the 8700
1723                 have both RIM_UsbSerData mode and IpModem mode.
1724         - fixed serialization code for Calendar record class, in s11n-boost.h
1725         - made UnknownField's data member into its own type,
1726                 so that when building records, it doesn't get processed
1727                 like a null terminated string... also added more
1728                 BuildField() helper functions for accuracy
1729         - fixed missing fields in the Calendar record build process
1730         - added Calendar to list of Builders in tools/btool...
1731                 it is now possible to run: btool -s "Calendar" -f datafile
1732         - added tools/brecsum program, which calculates SHA1 checksums
1733                 on database records, for testing
1734         - added brecsum to debian and rpm builds
1735         - added recurrence builder function to Calendar record builder code
1736                 which completes builder support
1737                 Checksums from the following commands now match:
1738                         brecsum -d Calendar > sum1.txt
1739                         btool -d Calendar -f calendar.dat
1740                         btool -s Calendar -f calendar.dat
1741                         brecsum -d Calendar > sum2.txt
1742                         diff -u <(sort sum1.txt) <(sort sum2.txt)
1743 2008/04/29
1744         - applied Jason Thomas's ACLOCAL_FLAGS patch to make autoreconf
1745                 work again... Thanks!
1746         - applied Jason Thomas's debian build dependency patch
1747         - updated AUTHORS
1748 2008/04/26
1749         - started documentation overhaul in doc/www, putting the commonly
1750                 asked questions right on the front page, and making it more
1751                 goal-oriented, so it is hopefully easier to use
1752 2008/04/25
1753         - updated NEWS file
1754         - fixed error messages in m_desktop.cc that still referred
1755                 to Controller
1756 2008/04/25
1757         - major merge of barry-b1-socket-arch-branch into MAIN.
1758           The following is the changelog from that branch, which is now MAIN.
1760         2008/04/25
1761                 - added thread-safe logging mechanism
1762                 - added preliminary IP modem support... requires a recent
1763                         device... serial mode is not yet supported
1764                 - merged HEAD changes
1765         2008/03/27
1766                 - changed Barry::Init() so programmer can choose where
1767                         debug and exception information goes, instead of
1768                         always to stdout
1769         2008/03/22
1770                 - merged HEAD changes
1771         2008/03/20
1772                 - fixed bug in probe class, which missed storing the PIN
1773                         number in ProbeResult
1774                 - also added ProbeResult constructor
1775                 - merged changes from visibility branch:
1776                         - GCC visibility support, limiting what symbols are
1777                           visible in the shared library, libbarry... this makes
1778                           a drastic reduction in the symbol table, and should
1779                           avoid future name clashes with other libraries such
1780                           as opensync
1781                           See: http://gcc.gnu.org/wiki/Visibility
1782                         - vformat_() function name changes
1783         2008/03/07
1784                 - merged HEAD changes
1785                 - added threads library to new bs11nread build
1786         2008/02/28
1787                 - fixed variable size issues in btranslate.cc, evident with
1788                         some compilers on 64 bit systems
1789                 - merged HEAD changes
1790                 - added comments for threaded usage in usbwrap.h
1791                 - changed router to use SocketId typedef, for clarity
1792         2008/02/22
1793                 - fixed const char warnings from newer gcc compilers
1794                 - controller object now saves a copy of the probe result
1795                         and provides an API to retrieve it
1796                 - added sanity checks to m_serial.cc
1797                 - fixed probe behaviour so that a USB probe on an endpoint
1798                         that doesn't respond won't halt everything
1799                 - refactored some of the probe code, and added checks for
1800                         IP modem endpoints
1801                 - added Probe::DumpAll()
1802                 - added Open() call to pppob.cc (not yet complete)
1803         2008/01/30
1804                 - implemented dataqueue.{h,cc}... looks ready for testing,
1805                         once things compile again
1806                 - changed free list copy in router.cc to use
1807                         DataQueue::append_from()
1808                 - finished packet.{h,cc} implementation, ready for testing
1809                 - finished controller.{h,cc}, ready for testing
1810                 - finished m_desktop.{h,cc}, ready for testing
1811                 - added skeleton m_serial.cc
1812                 - the base library and utilities compile again!
1813                 - added constructor for SocketZero(queue)
1814                 - fixed ErrnoError::GetMsg()
1815                 - updated GUI and opensync plugin to compile with new API
1816                 - moved Raw Send/Receive socket functions to private
1817                 - fixed packet header size bug in socket that caused
1818                         socket ID override to be skipped
1819                 - fixed incorrect use of gettimeofday()
1820                 - fixed race condition where Controller could destroy
1821                         the Usb::Device object before the SocketRoutingQueue
1822                         was done with it
1823                 - fixed segfault in SocketZero::RawSend() when a router
1824                         was in use
1825                 - fixed Open() bugs in btool... Open() must be outside of loops
1826                 - btool uses the router thread now, for testing
1827                 - partially implemented m_serial.{h,cc}... needs testing
1828                 - added automatic buffer allocation to SocketRoutingQueue
1829                         constructor
1830                 - made AllocateBuffers() a little smarter, so it was not
1831                         pure appending
1832                 - added a context data pointer to the SocketRoutingQueue
1833                         RegisterInterest callback
1834                 - added RegisterInterest functionality to Socket class
1835                 - added exceptions on router read errors in socketzero
1836         2008/01/26
1837                 - implemented router.{h,cc}... looks ready for testing,
1838                         once things compile again
1839         2008/01/25
1840                 - merged HEAD changes
1841                 - added router.cc and continued work on new arch
1842                 - merged HEAD changes for 2008 copyright statements
1843                 - added scoped_lock.h
1844                 - added ErrnoError exception class
1845                 - documented Controller / SocketRoutingQueue behaviour
1846                 - more router implementation
1847                 - simplified pppob
1848                 - audit and cleanup of socket.{h,cc} code... looks ready
1849                         for testing now, once things compile again
1850                 - removed FIXME in router.*
1851                 - removed pthread header from pppob as it is not needed
1852         2007/11/22
1853                 - merged HEAD changes
1854         2007/10/25
1855                 - merged HEAD changes
1856         2007/10/19
1857                 - branch started, to track development of the new socket
1858                         architecture, and new mode architecture, needed
1859                         to support GPRS modem support, and threaded
1860                         USB access
1861                 - committed work-in-progress... does not compile
1863 2008/04/10
1864         - added Tasks and Memos to TODO list
1865 2008/03/27
1866         - added support for Blackberry 8120, which has a unique Product ID
1867                 Sourceforge tracker ID: 1829537
1868 2008/03/22
1869         - removed TimeZones from TODO list, as it is done
1870 2008/03/21
1871         - version bump:
1872                 - configure.ac
1873                 - src/Makefile.am
1874                 - src/version.cc
1875                 - gui/src/BackupWindow.cc
1876                 - src/Doxyfile
1877                 - rpm/barry.spec
1878                 - debian/changelog
1879                 - opensync-plugin/src/barry_sync.cc
1880         - added GCC visibility support, limiting what symbols are visible
1881                 in the shared library, libbarry... this makes a drastic
1882                 reduction in the symbol table, and should avoid future
1883                 name clashes with other libraries such as opensync
1884                 See: http://gcc.gnu.org/wiki/Visibility
1886 Release: version 0.12 - 2008/03/21
1887 ------------------------------------------------------------------------------
1888 2008/03/21
1889         - changed maintainer script to use CVS export instead of checkout,
1890                 to avoid the CVS directories
1891         - added support for building Debian source packages with proper
1892                 diff.gz and dsc files
1893         - fixed find warning in maintainer/make-rpm.sh
1894         - added support for Ubuntu binary packages to the maintainer build
1895                 scripts
1896 2008/03/13
1897         - renamed all vformat_ and VFormat symbols in opensync plugin's
1898                 copy of vformat code, so they don't conflict with the
1899                 real opensync libraries
1900 2008/03/07
1901         - updated the install.php web page with Paul Dugas's notes on
1902                 building RPM's from CVS
1903         - fixed problem in tools/Makefile.am where bs11nread was included
1904                 in build, even if --with-boost was not specified
1905                 on ./configure command line
1906 2008/03/06
1907         - changed format of Boost serialization file output from btool,
1908                 so that the database name is stored as the first line
1909                 of the file
1910         - added tools/bs11nread.cc to read Boost serialization file data
1911                 written by btool
1912         - minor adjustments to r_message.h and r_timezone.h
1913         - updated s11n-boost.h header to match record classes
1914 2008/03/01
1915         - applied Time Zone parsing patches from Brian Edginton
1916         - added Time Zones to list of supported parsers in btool.cc
1917 2008/02/29
1918         - changed configure.ac to use bzip2 for "make dist".. thanks to
1919                 Paul Dugas for the tip
1920 2008/02/28
1921         - committed Chris Burgess's update to the roadmap document
1922         - applied Paul Dugas's x86-64 build patch, except the
1923                 tar.bz2/tar.gz change
1924         - updated AUTHORS file
1925 2008/02/22
1926         - fixed configure.ac's --with-boost option, so that without args,
1927                 it defaults to using --includedir and --libdir settings,
1928                 instead of hardcoding /usr/include and /usr/lib... this
1929                 should allow smarter compiling on 64 bit systems
1930         - updated RPM spec file to use new --with-boost behaviour
1931         - ahem, fixed configure.ac again... don't use --includedir and
1932                 --libdir, as those are install targets... oops.
1933                 Don't add path overrides at all if not specified.
1934 2008/01/25
1935         - fixed locale issues in src/data.cc
1936         - updated copyright statments for 2008
1937 2007/12/21
1938         - applied wording correction patch to btool from Matt LaPlante
1939 2007/12/07
1940         - changed hard coded databases names in btool to calls to
1941                 <recordclass>::GetDBName()
1942         - version bump:
1943                 - configure.ac
1944                 - src/Makefile.am
1945                 - src/version.cc
1946                 - gui/src/BackupWindow.cc
1947                 - src/Doxygen
1948                 - rpm/barry.spec
1949                 - debian/changelog
1950                 - opensync-plugin/src/barry_sync.cc
1951         - updated TODO
1953 Release: version 0.11 - 2007/12/01
1954 ------------------------------------------------------------------------------
1955 2007/12/01
1956         - fixed null pointer bug in Probe class (bug #1842407)
1957         - added pause to maintainer release script
1958 2007/11/30
1959         - version bump:
1960                 - configure.ac
1961                 - src/Makefile.am
1962                 - src/version.cc
1963                 - gui/src/BackupWindow.cc
1964                 - src/Doxygen
1965                 - rpm/barry.spec
1966                 - debian/changelog
1967                 - opensync-plugin/src/barry_sync.cc
1969 Release: version 0.10 - 2007/11/30
1970 ------------------------------------------------------------------------------
1971 2007/11/30
1972         - added support to the usbwrap Match class to limit its
1973                 search by busname / devname
1974         - added support to the Probe class to limit its search for
1975                 Blackberry devices to a given bus or device name
1976         - added command line options to btool for the above Probe
1977                 bus/device names, and updated the man page
1978         - updated the www docs with regard to the new usb_storage
1979                 behaviour and the new blacklist files... less
1980                 concern about berry_charge and usb_storage conflicts
1981         - added bidentify tool and accompanying man page
1982         - fixed bug in rpm maintenance script that used the wrong
1983                 spec file for opensuse
1984 2007/11/29
1985         - added better error checking to breset
1986         - commented the sleep() for the 8830
1987         - added code to handle the race condition where usb_storage
1988                 claims the device before bcharge arrives on the scene,
1989                 by asking the kernel to detach the driver from
1990                 the Mass Storage interface... this change makes it
1991                 possible to run bcharge, moving from 0006 to 0004
1992                 to 0001 and back to 0004, all *while* usb_storage
1993                 is loaded!
1994         - changed Probe class behaviour so that it will not throw an
1995                 exception on Device Busy (-EBUSY) but instead
1996                 log the error in an internal array and keep going.
1997                 This makes it possible to use btool and barrybackup
1998                 with two devices plugged in at the same time.
1999                 BACKWARD COMPATIBILITY NOTE: this changes initializaion
2000                         behaviour, but in practice, it should only
2001                         make applications look more capable, not less.
2002         - updated btool to show errors logged by Probe
2003         - added message to specify which PIN device is being used by btool
2004         - added explanatory comments to udev rules files, about why
2005                 they are so verbose
2006 2007/11/27
2007         - added ClearHalt() calls to probe and controller classes, just
2008                 before any communication happens... the 8830 seems
2009                 to need this
2010 2007/11/23
2011         - added usbwrap.cc:GetConfiguration()
2012         - added code to check whether the configuration is the one
2013                 we require, before calling SetConfiguration()... and not
2014                 to call it if unnecessary.  This allows us to run
2015                 at the same time as usb_storage.
2016                 Thanks to Martin Owens for not letting this issue go. :-)
2017         - added sleep to bcharge, before calling usb_reset()... the
2018                 Blackberry 8830 behaves like a Pearl device in that
2019                 it has mass storage support, but behaves like a Classic
2020                 in that it resets itself... the usb_reset() seems
2021                 to reset it back to 0006.  The sleep allows the device
2022                 to disappear via its own reset, and let usb_reset()
2023                 fail naturally on these devices.
2024                 This is not an ideal solution... mainly for testing.
2025 2007/11/09
2026         - added modprobe/blacklist-berry_charge as per Simon Ruggier's
2027                 suggestion.  Thanks also to Niels de Vos for a similar
2028                 suggestion.
2029         - fixed udev rules to work on both old and new distros
2030                 Thanks to Duncan Mak for the bug report.
2031         - AUTHORS update
2032         - fixed string comparison to use case insensitive compare in
2033                 opensync plugin
2034         - updated Debian package to include modprobe blacklist file
2035         - updated rpm spec file to include modprobe blacklist file
2036         - split the maintenance scripts into release and test, so
2037                 that release package builds can be done faster
2038 2007/10/26
2039         - opensync plugin fixes:
2040                 - fixed memory leak in vBase::GetAttr()
2041                 - added support in vformat parser to parse "blocks"
2042                         and keep track of the hierarchy when
2043                         parsing an iCalendar, etc.
2044                 - added support for searching for attributes only
2045                         inside certain blocks (i.e. find first
2046                         DTSTART in VEVENT block, not VTIMEZONE block)
2047 2007/10/25
2048         - fixed bug in Calendar::Clear, missing the Free / Class
2049                 member variables, leaving them uninitialized
2050         - added examples/addcalendar.cc
2051         - added more logging to the opensync plugin, logging the
2052                 ToBarry conversion results
2053         - added code to force struct tm.tm_isdst to -1 before calling
2054                 mktime, in vformat.c
2055                 - fixed typo in previous fix
2056 2007/10/12
2057         - renamed ktrans and translate to bktrans and btranslate to avoid
2058                 file name clashes with libtranslate of Gnome
2059                 Closes bug #1812410 reported by Troy Engel.
2060         - version bump:
2061                 - configure.ac
2062                 - src/Makefile.am
2063                 - src/version.cc
2064                 - gui/src/BackupWindow.cc
2065                 - src/Doxygen
2066                 - rpm/barry.spec
2067                 - debian/changelog
2068                 - opensync-plugin/src/barry_sync.cc
2069         - fixed missing default config file in the debian package for
2070                 the opensync plugin
2071                 Closes bug #1812224 reported by Ariel (adonatti).
2072         - added debian dbg packages for tracing segfaults
2073         - modified maintainer scripts so debug packages would reference
2074                 source code located in /usr/src/barry-0.9, etc.
2076 Release: version 0.9 - 2007/10/12
2077 ------------------------------------------------------------------------------
2078 2007/09/29
2079         - adjusted autosuspend disabling code in bcharge, based on new
2080                 information on how kernels 2.6.21 / 2.6.22 work.
2081                 See bcharge.cc for comments.  If device/power/level or
2082                 device/power/autosuspend exist, charging should now work
2083                 without recompiling the kernel.
2084         - updated website docs with autosuspend info
2085 2007/09/27
2086         - large update to the doc/www web pages, moving some of the
2087                 information in README files to html format, so that it
2088                 is commonly available on the web
2089         - added step in maintenance scripts to automatically build the
2090                 .html files in doc/www when making a tarball release
2091 2007/09/22
2092         - added libopensync 0.22 version requirement to barry.spec file,
2093                 but it doesn't seem to work on OpenSuSE 10.2, where it's
2094                 needed.... hmmmm
2095 2007/09/21
2096         - updated README to mention new tree build configure options
2097         - fixed the configure scripts and makefiles so that when building
2098                 with custom CXXFLAGS and LDFLAGS environment variables,
2099                 it doesn't break the full-tree build mode, when
2100                 using --enable-gui and/or --enable-opensync-plugin
2101         - added config.h.in~ to buildgen.sh clean target
2102         - converted Debian build scripts to use cdbs
2103         - added opensync plugin binary package for Debian
2104         - added "Getting Started" section to web pages, as well as an
2105                 explanatory document for various system requirements
2106         - turned on opensync build in RPM maintainer scripts
2107 2007/09/20
2108         - added filename to power/state error message in bcharge.cc
2109         - adjusted maintainer scripts to automatically adjust barry.spec
2110                 for opensuse rpm builds
2111 2007/09/13
2112         - fixed some of the release build scripts and added support for
2113                 automated opensuse 10.2 builds
2114                 - fixed build target to i386
2115                 - changed scripts to add to PKG_CONFIG_PATH variable instead
2116                         of overwriting it
2117 2007/09/07
2118         - added website docs to doc/www... these are out of date at the
2119                 moment, and hopefully by including them here, they
2120                 will be updated more frequently
2121 2007/09/05
2122         - applied Simon Ruggier's build system patch that allowed a build
2123                 of all 3 components from the root directory and fixed the
2124                 configure scripts to support external build directories
2125         - reordered clean commands in the buildgen.sh scripts, and removed
2126                 the INSTALL files, since they are auto-generated by autoconf
2127         - removed extraneous buildgen.sh calls in maintainer scripts
2128         - added Simon Ruggier to AUTHORS
2129         - added explanatory note to 3 stage test build process in
2130                 maintainer script
2131 2007/08/24
2132         - fixed Category handling in the Contact record class, to
2133                 parse the comma separated string into an array,
2134                 and back
2135                 Note: this involves a change to the boost serialization
2136                         and will affect backward compatibility with
2137                         old serialization datafiles
2138         - added Category to examples/addcontact.cc
2139         - added Category support to the opensync plugin
2140 2007/08/23
2141         - fixed wrong read/write in btool output (oops)
2142         - added BadSize exception, and changed CheckSize() function
2143                 to throw it on error
2144         - changed backup GUI to catch BadSize exceptions on initial
2145                 connect, and try a reset if that error occurs, since
2146                 that likely means the device didn't shutdown properly
2147         - fixed in opensync plugin:
2148                 - some vcard data contains types codes in capital letters,
2149                         so added lower case conversion routine
2150                 - changed the order of address lines, so that address1
2151                         is the street, address2 is the extended address,
2152                         and address3 is the PO Box.  The Blackberry
2153                         doesn't seem to have any PO Box field.
2154 2007/08/20
2155         - added -e endpoint override option to btool
2156         - added status message to endpoint override
2157 2007/08/18
2158         - added configure check for strnlen, and implementation for
2159                 systems that don't have it, or that have it implemented
2160                 incorrectly.  Went a little paranoid here, since
2161                 AC_FUNC_STRNLEN doesn't set a define in config.h,
2162                 so I had to do it manually, and check in case autoconf
2163                 changes in the future... ugh.  See src/strnlen.h for
2164                 the gory details.
2165         - added code in probe.cc to fetch the device's description.
2166                 The description is now part of the probe results
2167                 along with the PIN.  Updates to protocol.h, adding
2168                 a new attribute definition.
2169                 Thanks to Rick Scott for pointing out the code in
2170                 XmBlackberry where he implemented this first.
2171         - fixed header dependency in record-internal.h
2172         - updated the "required autoconf" version to 2.61 for root build
2173         - moved nested structs out of the record classes that contain them,
2174                 in order to better support SWIG and Python
2175 2007/08/17
2176         - changed bcharge to use getopt() for its argument processing
2177         - added options -p and -s to bcharge, to adjust usb suspend
2178                 settings automatically where possible
2179         - updated the udev rules to use the new bcharge settings
2180         - updated the bcharge man page with the new arguments
2181 2007/08/16
2182         - cleaned up Usb exception handling, moving libusb error code
2183                 processing into the Usb::Error exception class.
2184                 error.cc is now an empty shell
2185         - added return codes to the Usb::Error exceptions
2186         - removed aboutdialog.{h,cc} from the backup GUI since even
2187                 Debian stable now has up-to-date gtkmm libraries
2188         - added more user friendly error message for the "device busy"
2189                 case, recommending 'rmmod usb_storage'.
2190 2007/08/09
2191         - added better error checking to bcharge.cc
2192         - version bump:
2193                 - configure.ac
2194                 - src/Makefile.am
2195                 - src/version.cc
2196                 - gui/src/BackupWindow.cc
2197                 - src/Doxygen
2198                 - rpm/barry.spec
2199                 - debian/changelog
2200                 - opensync-plugin/src/barry_sync.cc
2201         - removed usb_set_configuration() check from bcharge.cc, since
2202                 that may fail under normal operation, in this case
2204 Release: version 0.8 - 2007/08/03
2205 ------------------------------------------------------------------------------
2206 2007/08/03
2207         - moved Interface implementation to usbwrap.cc file
2208         - added dout debugging messages to usbwrap.cc
2209         - clarified unhandled packet error message in socket.cc
2210         - added temporary workaround in opensync-plugin environment's
2211                 Reconnect(), for odd message seen on newer Blackberry
2212                 devices
2213         - fixing issues with Brian Edginton's MessageRecord patch (2007/06/29)
2214                 - fixed missing size check in message oriented ParseHeader()
2215                 - fixed endian conversion issues (also found one pre-existing
2216                         endian bug in the process)
2217                 - moved message timestamp converter code to time.cc
2218         - added Barry version number to opensync plugin name
2219         - changed maintainer scripts and rpm.spec to use bzip2 instead of gzip
2220         - added opensync-plugin to configure script build
2221         - added -S option to btool, to list supported parsers and builders
2222         - slight change to opensync-plugin/buildgen.sh to cleanup config.h.in~
2223         - opensync-plugin/README update
2224         - added opensync-plugin/patches for others who may be building and
2225                 testing the plugin with OpenSync 0.22
2226         - added debian package build scripts to maintainer/
2227 2007/08/01
2228         - added entry to doc/TroubleShooting.txt
2229 2007/07/28
2230         - added doc/TroubleShooting.txt
2231 2007/07/27
2232         - opensync plugin:
2233                 - fixed bug in vcard.cc that was using the FN field
2234                         for the broken-down name instead of N
2235                 - added dbId and dbName to DatabaseSyncState
2236                 - added Reconnect() functionality to BarryEnvironment class
2237                         and moved connect logic out of barry_sync.cc
2238                 - changed the batch commit functionality in barry_sync.cc
2239                         to single-change-commit.  Why?  Because opensync
2240                         0.22 groups all batch changes into one group
2241                         and calls one batch commit function, even if you
2242                         registered two.  Moving to single change commit
2243                         mode removes a chunk of unneccessary code
2244                         from the plugin as well, and can in theory
2245                         ease memory pressure in the library.
2246                 - added FinishSync() to perform actions needed on successful
2247                         syncing completion
2248                 - disconnect on successful sync completion, and reconnect,
2249                         since the device's dirty flags don't seem to
2250                         be updated until a disconnect occurs.
2251 2007/07/26
2252         - added ReadDataArray() to data.h, using an istream instead of
2253                 requiring a file
2254         - added raw data version of BuildField() to record-internal.h
2255                 This is so that btool doesn't add extra null terminators
2256                 to unknown data, when restoring with option -s
2257         - fixed bugs in r_contact.cc:
2258                 - fixed bug that caused a LastName/FirstName swap
2259                         if FirstName was empty and you wrote a contact
2260                         record into the device.... First/Last Name
2261                         fields are position sensitive, and the code
2262                         was missing the empty FirstName case on writing
2263                 - fixed bug in BuildFields() and Dump() where they
2264                         were not updated to handle the new field
2265                         table added for the postal address changes
2266                         on 2007/07/20, oops
2267         - opensync plugin:
2268                 - changed the plugin config file, so it is possible to
2269                         turn debug output on/off without recompiling
2270                 - moved the standalone Map2Uid() function into
2271                         the DatabaseSyncState class, and changed the
2272                         code to produce "contact-#" and "calendar-#"
2273                         UID strings, instead of just numbers
2274                 - changed default PIN to -1, so that if the user doesn't
2275                         configure properly, it will fail... this is a
2276                         safety measure to avoid syncing with different
2277                         devices and corrupting the cache/idmap...
2278                         this should be fixed someday, to handle this
2279                         automatically
2280                         On second thought... is this right?  Perhaps
2281                         it is better to fail if the PIN is not what
2282                         is expected, so a user doesn't accidentally
2283                         sync the wrong device and lose data.
2284                         Actions to take on new PIN:
2285                                 - force slow_sync, or
2286                                 - fail
2287                 - incorporated the new VCardConverter code into the
2288                         main barry_sync.cc plugin code
2289                 - fixed bug that did not clear the devices dirty flags
2290                         in the case where a sync only read data from it,
2291                         and didn't write
2292                 - changed PIN error message number to hex
2293 2007/07/20
2294         - minor wording change in backup GUI prompt: "Backup working..." to
2295                 "Backup in progress..."
2296         - renamed Contact class's Title field to JobTitle for clarity
2297         - added record function ParseFieldString(), which properly handles
2298                 strings from the device that have multiple null terminators,
2299                 and changed the record parsing code to use this new function
2300         - moved FullName() function from ldif.cc to r_contact.cc since it
2301                 is generally useful in areas outside of LDIF processing
2302         - refactored postal addresses in the Contact record class into
2303                 a new class called PostalAddress
2304         - renamed Address class in record.h to EmailAddress
2305         - moved Contact::GetPostalAddress() to record.cc as part of the
2306                 new PostalAddress class and renamed it
2307                 PostalAddress::GetLabel()
2308         - opensync plugin:
2309                 - refactored vformat helpers into separate base class
2310                         called vBase
2311                 - added vCard converter class
2312                 - commented out the code that skipped over the adding
2313                         of empty attribute values and parameters,
2314                         since VCARD depends on some of this behaviour
2315                 - movified vformat.c:vformat_find_attribute() to take
2316                         an extra nth argument, in order to search
2317                         for multiple attributes with the same name...
2318                         the way this is coded is a bit inefficient...
2319                         but we're moving away from vformat when we move
2320                         to OpenSync 0.3x / 0.40, so this is just temporary
2321                         pain
2322 2007/07/19
2323         - added SUBSYSTEM=="usb_device" to example udev rules, in order
2324                 to avoid running bcharge for each endpoint that is
2325                 added by udev, when first plugged in.  Running bcharge
2326                 back-to-back multiple times can crash some
2327                 Blackberries.
2328 2007/07/14
2329         - opensync plugin:
2330                 - fixed ID mapping bug in the case of a non-numeric UID
2331                         from syncing external -> Barry, and then the
2332                         new Barry ID would look like a new change
2333                         when syncing back from Barry -> external.
2334                 - added support for slow sync
2335                 - added clear() to idmap class
2336                 - added vformat attr parameter extraction class
2337                 - added more trace logging during vformat/Barry conversions
2338                 - added Notification time support
2339                 - handled "all day" vformat special case, when DTEND
2340                         does not exist in a vformat data block
2341         - changed the min1900_t time conversion functions to handle
2342                 the 0xffffffff special case, when notifications
2343                 are turned off on a calendar event (src/time.cc)
2344         - also made the calendar data dump output clearer for
2345                 disabled timestamps, and added debug output
2346                 for the raw min1900 value, in case there are more
2347                 special cases in the future
2348 2007/07/13
2349         - fixed null pointer access in opensync's HasMultipleVEvents()
2350 2007/07/12
2351         - upper management directive: revert all OpenSync 0.3x changes
2352                 and proceed with OpenSync 0.22.  Reverting the
2353                 opensync-plugin/src tree to Barry 0.7 status.
2354 2007/07/06
2355         - reorganized exception and trace code in opensync plugin
2356         - added XmlToCalendar() function, based on unfinished opensync
2357                 library API that is not yet finished... will be
2358                 committed to opensync svn tree when complete
2359         - added OSyncXMLField logger to plugin trace class
2360 2007/06/29
2361         - applied email MessageRecord patch from Brian Edginton (thanks!)
2362         - updated Message::Dump() to output more valid mbox data...
2363                 the goal is to be able to do:
2364                         btool -d "Messages" > email.mbox
2365                         mutt -f email.mbox
2366         - changed some TODO's to FIXME's to keep it grep-consistent
2367         - applied Folder support patch from Brian Edginton
2368         - fixed pedantic compile warnings, and changed order in src/Makefile.am
2369         - removed unneeded cast in src/r_folder.cc
2370 2007/06/28
2371         - minor adjustment to ctags building in buildgen.sh
2372         - applied patch from Brian Edginton for better boost detection
2373                 in configure.ac
2374         - added boost usage message to btool -h output
2375 2007/06/21
2376         - more porting of OpenSync module to 0.30
2377         - added ctags build for opensync source tree to buildgen.sh
2378 2007/06/14
2379         - changed PKG_CONFIG_PATH setting in rpm script, so that systems
2380                 like SuSE that have an extensive PKG_CONFIG_PATH
2381                 in general use will not break on build
2382         - added PKG_CONFIG_PATH to debian script too, just in case :-)
2383         - added debian/changelog to doc/ReleaseChecklist.txt
2384         - added comment to rpm/barry.spec regarding SuSE RPM builds
2385 2007/06/08
2386         - applied patch from Niels de Vos fixing debian package build
2387                 dependency
2388         - applied Brian Edginton's Saved Email Messages patch
2389         - updated r_saved_messages.cc comment to match header
2390         - added GetRecType()/GetUniqueId() to r_saved_messages.h, since
2391                 SetIds() is already there
2392         - removed Address version of operator<<() from message related headers
2393                 and moved into record.h
2394         - added std::hex to message related dumps, and changed output to
2395                 be more mbox-like
2396         - updated doc/CodingStyle.txt to cover switch() statements
2397         - opensync compiles again, with 0.30!  (not functional yet)
2398                 - moving closer to more modular and reusable plugin functions
2399         - updated release checklist for opensync version number
2400 2007/06/07
2401         - added doc/CodingStyle.txt... preliminary version
2402 2007/06/06
2403         - applied Brian Edginton's PIN message patch
2404         - changes to PIN message patch:
2405                 - fixed missing backslash in src/Makefile.am
2406                 - fixed tab alignment throughout
2407                 - removed typedef from Address struct
2408                 - added clear() to Address... might as well, if it it is
2409                         going to be a standalone type
2410                 - fixed missing comma in PINMessageFieldLinks table
2411                 - changed MessageRecordId in PINMessage to load from a new
2412                         uint32_t field in CommonField, instead of piggy
2413                         backing on a field for other use
2414         - did some testing and found that PINMessage's MessageRecordId
2415                 is the same as the RecordId given through the SetIds()
2416                 API... but these Id's are duplicated in the protocol...
2417                 RecordId is stored in the protocol header, while
2418                 MessageRecordId is stored in the record it self as
2419                 a common field... added RecType and RecordId to
2420                 PIN Message so that we store both of these
2421         - updated AUTHORS
2422 2007/05/27
2423         - added item to gui/TODO
2424         - applied Brian Edginton's s11n-boost.h patch
2425 2007/05/25
2426         - renamed template values to more consistent naming scheme
2427         - applied memos and tasks patch from Brian Edginton, slightly
2428                 modified to split into the new separate files system
2429         - changes to memos and tasks classes:
2430                 - reformatted the code to match coding style
2431                         (come on Brian) :-)
2432                 - added copyright notice
2433                 - changed class to singular (Memo, not Memos)
2434                 - placed in Barry namespace
2435                 - added #ifdef header protectors
2436                 - added new files to Makefile.am
2437                 - added new r_*.h headers to record.h
2438         - added support for Memos and Tasks to tools/btool.cc, based on
2439                 Brian Edginton's patch
2440                 (currently commented out, for Boost library reasons):
2441         - added doc/CommitPolicy.txt
2442         - updated AUTHORS
2443 2007/05/24
2444         - added ctags generation to buildgen.sh
2445         - applied record.{h,cc} fix patch from Brian Edginton
2446                 - ClassFlag
2447                 - FreeBusyFlag
2448                 - Clear() fixes
2449         - fixed broken formatting in above patch
2450         - refactored record parser classes into separate files for each
2451         - changed the ConvertHtoB<> template to inline, as it caused
2452                 linker errors with the new file layout
2453 2007/05/17
2454         - fixed bug in Debian packaging that put util commands in
2455                 /bin and /sbin instead of /usr/bin and /usr/sbin
2456         - commited byteswap.h replacement code from gm2net
2457         - backup gui:
2458                 - removed unneeded debug messages on stdout
2459                 - changed the default for debug output to "off"
2460                         and added a command line option to turn
2461                         it on if necessary  (--debug-output)
2462                 - command line option --help now also works
2463         - fixed bug in Calendar class where it didn't initialize
2464                 RecType properly... and cleaned up other RecType
2465                 code to use the GetDefaultRecType() functions,
2466                 localizing the constants in one place
2467 2007/05/11
2468         - applied patches from Brian Edginton, parsing more
2469                 fields in Contact and Calendar records
2470         - added Brian Edginton to AUTHORS
2471         - reformatted record.{h,cc} to match the rest of the code,
2472                 removed commented out code, and removed mention of
2473                 Outlook from the comments.
2474         - updated udev/10-blackberry.rules.Debian for Debian Etch
2475         - updated debian/rules to use new udev rules file
2476         - removed debian/postinst, as stable versions of Debian now
2477                 have a recent udev, and don't need the special handling
2478         - updated Debian build scripts to build separate packages:
2479                 libbarry
2480                 libbarry-dev
2481                 barry-util
2482                 barrybackup-gui
2483         - added menu support to Debian barrybackup-gui package
2484         - made the buttons bigger in the backup GUI, as they were too
2485                 small on Debian Etch
2486         - opensync plugin:
2487                 - more progress in porting to opensync 0.30, heavily
2488                         based on the example plugin in the opensync
2489                         svn tree...  this is a work in progress, and so far
2490                         is incomplete
2491 2007/05/04
2492         - opensync plugin:
2493                 - partial porting to opensync 0.30 (in progress!)
2494                 - fixed bug in sync_done where it reported context error
2495                         and then success afterward
2496         - checking in new INSTALL files based on Etch's autoconf run
2497         - added item to gui's todo list
2498         - bumped version numbers to 0.8 in:
2499                 - configure.ac
2500                 - src/Makefile.am
2501                 - src/version.cc
2502                 - gui/src/BackupWindow.cc (about dialog)
2503                 - src/Doxygen
2504                 - rpm/barry*.spec
2506 Release: version 0.7 - 2007/05/02
2507 ------------------------------------------------------------------------------
2508 2007/05/02
2509         - added rpm building to maintainer/release scripts
2510         - added "HEAD" feature to tarball creation script, for easier testing
2511         - updated maintainer/README
2512         - updated maintainer/release.sh to use new HEAD feature too
2513 2007/05/01
2514         - added pppob to rpm barry.spec
2515         - bumped release number in barry.spec
2516 2007/04/30
2517         - opensync plugin:
2518                 - fixed size check bugs (strlen() == 0 when empty)
2519                 - finished refactoring calendar conversion routines
2520                 - started timezone parsing, but this may go away
2521                         if we use opensync 0.30's time functions and
2522                         xml data format...
2523                 - added development note to README
2524 2007/04/29
2525         - updated README and opensync-plugin/README with more current
2526                 build instructions
2527         - opensync plugin:
2528                 - refactored some calendar conversion routines
2529                 - added Barry->vCalendar conversion for recurring appointments
2530 2007/04/27
2531         - opensync module:
2532                 - removed some unneeded trace logs
2533                 - fixed VEventConverter constructor bug, with uninitialized
2534                         m_Data pointer
2535                 - eased up the requirement that every calendar event
2536                         must have a summary... defaults to "<blank subject>"
2537                         if empty
2538                 - added more VCALENDAR fields to match Barry::Calendar record
2539                 - fixed case sensitive compares in vformat.c
2540 2007/04/26
2541         - opensync module work:
2542                 - added id map class to map string uid's from OpenSync to
2543                         numeric ID's from the Blackberry
2544                 - fixed bug in CommitChange() where it was still using
2545                         a hard coded calendar record state table
2546                 - added lots of logging throughout
2547                 - fixed bug where newly added records didn't use the
2548                         change object's uid, but created a new ID,
2549                         causing another sync on the next run
2550                         i.e. (CommitData_t was missing an argument)
2551                 - fixed bug where uninitialized notification time was
2552                         written to the Blackberry
2553         - more opensync module work:
2554                 - refactored the environment class into another subclass
2555                         called DatabaseSyncState, and moved some stand-
2556                         alone functions from barry_sync.cc into
2557                         the environment classes
2558                 - added a tagged constructor to the trace class
2559                 - fixed idmap::Load() to clear map before loading
2560 2007/04/20
2561         - renamed barry-config to barry-sync, the default configuration
2562                 file for the opensync module... and filled it with
2563                 a sample configuration
2564         - added code to update the calendar cache, and write it to disk
2565                 on success (opensync module)
2566         - added code to clear dirty flags in the device (opensync module)
2567         - allowed comments in the config file
2568         - added vformat.c from libopensync 0.22, since the vformat
2569                 routines are not available from the plugin side
2570 2007/04/19
2571         - updated gui/TODO
2572         - added -d switch to bcharge to switch back from 0001 to 0004 mode,
2573                 changed the auto-detection logic to ignore iProduct and
2574                 only use idProduct, and updated man page
2575         - updated breset to recognize the Pearl in 00004 mode as well
2576         - changed src/probe.cc logic to assume that the second endpoint
2577                 pair is the one needed for database communication, instead
2578                 of doing a reverse search from the end... newer Pearls
2579                 in Dual mode seem to have at least 3 or 4 endpoint pairs,
2580                 and the old search didn't always work
2581         - applied sourceforge patch #1696884 from Peter Silva, updating
2582                 the Debian build for Etch, and including all files in one deb
2583         - added Peter Silva to AUTHORS file
2584         - uncommented the "make distclean" in debian/rules, and removed
2585                 the reliance on /tmp when installing 99-barry-perms.rules
2586         - applied bb_task_format.txt patch from Peter Silva
2587         - fixed each misspelling of "recurrance" to "recurrence"
2588         - tweaked src/probe.cc again for paranoia's sake... start at
2589                 offset 1 if more than 1 endpoint pair, otherwise start
2590                 search at 0
2591         - split up opensync module into multiple source files, and started
2592                 using the opensync vformat routines for parsing and building
2593                 the vevent20 data (experimental)
2594 2007/04/04
2595         - more incremental work on the opensync plugin, adding ADDED
2596                 and MODIFIED functionality... (experimental!)
2597 2007/03/30
2598         - added code to dump extra descriptors during device discovery,
2599                 if found
2600         - bumped opensync version number in configure.ac, and made
2601                 the configure scripts more consistent with the rest
2602                 of the project
2603         - fixed printf-format size bug in opensync module
2604 2007/03/29
2605         - applied patch from Niels de Vos, fixing deb udev rules for Pearl
2606         - updated AUTHORS
2607         - fixed extra space bug in LDIF output (added space when creating
2608                 FullName, even if there was no last name)
2609         - fixed Address Book record parsing in Contact class... the
2610                 Blackberry database uses field id 0x20 for both the
2611                 first and last names, and if only a last name exists,
2612                 the first name will be empty.  Fixed parser to handle
2613                 this special case, without relying on string length.
2614                 Thanks to Troy Engel for reporting above two LDIF bugs.
2615         - added a few more constants to bcharge.cc
2616         - renamed opensync's configure.in to configure.ac
2617 2007/03/17
2618         - fixed bcharge to avoid endless reset loop... oops
2619 2007/03/16
2620         - reorganized bcharge.cc to make it possible to switch between
2621                 Pearl modes 0004 and 0001
2622         - added flag to BadPassword exception class, to signal whether
2623                 the library considers the device "out of retries" or not
2624         - updated socket.cc for new BadPassword exception
2625         - added special case to Controller class destructor to reset the
2626                 device if being destroyed in a half-open state... this is
2627                 a temporary fix until we understand how to handle
2628                 the "already open" message we get when opening the Desktop
2629                 in some cases
2630         - added password prompt dialog to the backup GUI
2631         - fixed possible memory leak in GUI's DeviceInterface::Connect()
2632 2007/03/08
2633         - committed Troy Engel's bbrules_mass_symlinks.patch, fixing
2634                 udev rules for the Pearl
2635         - updated 10-blackberry.rules.Debian to match 10-blackberry.rules's
2636                 functionality
2637         - applied Troy Engel's barry.spec patch to generate all required
2638                 RPM's... Thank you!  Notes in the README taken from
2639                 the sourceforge tracker entry containing the patch.
2640         - added libusb lib flags to tools/ and examples/ makefiles,
2641                 and tweaked configure.ac with a better default,
2642                 to build cleanly on RHEL 4
2643         - modified rpm/barry.spec:
2644                 - does not create doc-only barry base package anymore
2645                 - fixed "barry-backup" typo
2646                 - removed the patch step, as version 0.7 shouldn't need it
2647                 - added license file to each package
2648                 - commented out console perms scripts, pending mailing list
2649                         discussion
2650         - updated AUTHORS
2651         - applied Troy Engel's barry.spec patch to fix RHEL4 compile issues
2652         - fixed 80 column wrapping error in barry.spec, thanks to Troy Engel
2653                 for the bug report
2654         - applied Troy Engel's udev permissions patch for Redhat/Fedora
2655                 systems, which automatically set the ownership of a
2656                 newly plugged in device to the currently logged in console
2657                 user.
2658         - added udev/README to document what all those files are for...
2659                 part of the text comes from the sourceforge comment
2660                 on the above udev permissions patch from Troy Engel
2661         - uncommented the console perms scripts for rpm/barry.spec
2662         - added libglademm-2.4 to gui/README's dependency list
2663         - made usbwrap.* calls more threadsafe
2664         - added Usb::Timeout exception for timeout errors
2665         - added preliminary UsbSerData support to library for GPRS modem
2666                 functionality, using Rick Scott's XmBlackBerry's serdata.c
2667                 as a guide
2668         - added overloaded Socket::Send() for sending without receiving
2669         - added preliminary pppob command line tool
2670 2007/03/02
2671         - version bump in:
2672                 - configure.ac
2673                 - src/Makefile.am
2674                 - src/version.cc
2675                 - gui/src/BackupWindow.cc (about dialog)
2676                 - src/Doxyfile
2677                 - rpm/barry.spec
2678         - build system tweaks for opensync-plugin, and added a buildgen.sh
2679                 for it
2680         - added better debug messages in probe.cc and usbwrap.cc's
2681                 device discovery code
2682         - changed error handling for null interface->altsetting pointers
2683                 when doing device discovery in usbwrap.cc.  Seems that
2684                 some devices report a higher number in bNumInterfaces
2685                 than are really available... in this case, let's
2686                 just ignore the missing data and assume success
2687         - applied udev script patch #1663986 from Troy Engel
2688         - applied barry-bcharge.spec patch #1672178 from Troy Engel
2689         - ReleaseChecklist update
2690         - added rpm/README based on Troy Engel's patch notes
2691         - updated new barry-bcharge.spec for version 0.7, removing patch
2692                 dependency
2694 Release: version 0.6 - 2007/02/28
2695 ------------------------------------------------------------------------------
2696 2007/02/28
2697         - fixed size checks for device database records larger than 64K
2698                 Thanks to Michael Brown for the bug report.
2699         - added initial release maintainer scripts
2700         - fixed odd backup success message in GUI when doing a backup with
2701                 no databases selected in configuration
2702                 Thanks to Michael Brown for the bug report.
2703         - added udev permissions file patch from Michael Brown
2704         - added Michael Brown to AUTHORS
2705         - updated README, gui/README, and doc/USB-capture.txt
2706         - added -o command line switch to bcharge.cc, and updated man page
2707 2007/02/23
2708         - changed library behaviour so it only turns on libusb debug output
2709                 if in data dump mode.  In btool, -v controls this output.
2710         - minor stream formatting fix in btool
2711         - added OpenSSL dependency to build for password hash support
2712         - made debug dout() output conditional on Init() flag... In btool,
2713                 -v now controls this as well
2714         - reverse engineered more of the initial probe packets, and
2715                 implemented probing in struct based code... changes include:
2716                 - added support for "attribute fetch" packets, used at
2717                         the beginning of USB conversations
2718                 - defined object/attribute id codes for the PIN number
2719                 - made Protocol::SocketCommand more robust, and implemented
2720                         its sequence number behaviour
2721                 - moved ModeSelectCommand into SocketCommand, as it is a
2722                         socket 0 level command
2723                 - added initial protocol struct: PasswordChallenge
2724                 - renamed Barry::Packet to DBPacket
2725                 - added ZeroPacket for socket 0 packet creation and analysis
2726                 - Barry::Packet is now the base class for the above
2727                 - implemented socket 0 behaviour in socket.cc
2728                 - changed return values for Send/Receive/Packet/NextRecord
2729                         members in the Socket class from bool to void, as they
2730                         don't generate errors themselves, but only can
2731                         have an error if Usb::Device throws an exception.
2732                         Cleaned up all code that called these members as well.
2733                 - removed "last status" from Socket class as it was unused
2734                 - updated probe.cc to use new socket 0 implementation
2735                 - removed two of the hard coded packet handshakes in favour
2736                         of socket 0 packets
2737                 - updated controller.cc:
2738                         - uses new socket 0 implementation
2739                         - removed "flag" hack when opening sockets and
2740                                 selecting modes, as it should use the
2741                                 socket 0 sequence number
2742         - added initial, incomplete prototype header for the C API
2743         - updated some .cvsignore files
2744         - updated TODO
2745         - updated ReleaseChecklist.txt, adding rpm spec file
2746         - added the following to ZeroPacket:
2747                 - ChallengeSeed()
2748                 - RemainingTries()
2749                 - SocketResponse()
2750                 - SocketSqeuence()
2751         - moved Command() to base Packet class
2752         - added comments to protostructs.h and size constants for the
2753                 new PasswordChallenge struct
2754         - added password support to Socket and Controller classes
2755                 Thanks to Rick Scott's XmBlackBerry for the openssl
2756                 password hashing logic.
2757         - updated btool to use new password support, and updated its man page
2758 2007/02/22
2759         - updated Doxygen input files and version, and added to ReleaseChecklist
2760         - fixed btool PIN output for LDIF mode, now commented in output
2761         - major LDIF overhaul:
2762                 - split LDIF specific code out of the record class and
2763                         into its own
2764                 - fixed "full name" behaviour that added an extra space
2765                         in dn attributes, as reported by Troy Engel
2766                 - added support for mapping of LDIF attributes to Barry
2767                         contact field names
2768                 - fixed base64 handling, so attributes are only so encoded
2769                         if necessary
2770                 - fixed base64 attribute reading inconsistency... some
2771                         notes fields were missed in old version if not
2772                         encoded
2773                 - added support for specifying alternate attribute for
2774                         constructing a FQDN, instead of just "cn"
2775                 - updated btool and upldif to use new features
2776         - large update to btool manpage
2777         - fixed initialization bug in Contact constructor (missed RecType)
2778 2007/02/15
2779         - added ktrans.cc to make reading of kernel usbfs_snoop logs easier
2780         - removed commented code from translate.cc
2781         - added Pearl handshake support to bcharge.cc, which resets the
2782                 Pearl so that the vendor specific 0xFF class exists.
2783                 This should allow use of btool on the Pearl.
2784         - added Data::AppendHexString to data.cc
2785         - added better probing support for the Pearl, so it detects the
2786                 Product ID 0x0004 mode, and does a search for class 0xFF
2787                 instead of hardcoding it.
2788 2007/02/10
2789         - applied README patch from Ian Darwin
2790         - minor tweaks to README
2791         - added missing errno.h header in src/usbwrap.cc for AMD64
2792                 Thanks to Jonathan Hudson for reporting the bug.
2793         - tightened up size checks in Data::ReleaseBuffer()
2794         - stable libusb *does* return the actual length of the USB packet...
2795                 fixed this in usbwrap.cc to set the actual size of read data,
2796                 and removed the size hacks elsewhere in the code:
2797                 probe.cc, protocol.cc, socket.cc, usbwrap.cc
2798 2007/02/09
2799         - added proper return codes for error conditions in btool.cc
2800         - clarified some stream output code in the library, for hex/dec numbers
2801         - removed old, non-working connect.cc test program
2802         - added iomanip to debug.h
2803         - changed usbwrap to call libusb again if EINTR and EAGAIN
2804                 This should fix one of the OpenBSD issues
2805 2007/02/04
2806         - updated AUTHORS
2807         - fixed bug in barrybackup GUI that didn't create the target path
2808                 if the user didn't do Edit | Config first.
2809                 Thanks to Ian Darwin for reporting the bug.
2810         - applied gui/src/ConfigFile.cc header fix patch for OpenBSD
2811                 from Ian Darwin
2812 2007/02/03
2813         - added initial btool.1 man page from Ian Darwin
2814         - updated man/Makefile.am for new btool.1
2815         - updated AUTHORS
2816         - applied btool -h help clarification patch from Ian Darwin
2817 2007/02/02
2818         - reworked exception hierarchy, so applications can handle all
2819                 Barry related exceptions, including Usb errors, with
2820                 one base class: Barry::Error
2821         - fixed all the ripple changes this caused throughout the codebase
2822         - added BadPassword exception
2823 2007/02/01
2824         - version bump in:
2825                 - configure.ac
2826                 - src/Makefile.am
2827                 - src/version.cc
2828                 - gui/src/BackupWindow.cc (about dialog)
2829         - updated doc/ReleaseChecklist.txt
2830         - added usb-level breset.cc command line tool
2831         - fixed bug in gui/src/tarfile.* for systems where
2832                 sizeof(int) != sizeof(void*)
2833                 - TarFile class now uses a plugin style for the compression
2834                         operations, to allow for threadsafe versions if needed
2835                         in the future.
2836                 - also fixed leaked file handle bug in open_compressed()
2837                 - Thanks to Jonathan Hudson for reporting this for 64bit systems
2838         - minor signed comparison fixes in the library
2839         - added better protocol data dumping code in probe.cc
2840         - added Usb::Device::BulkDrain(), to prevent Barry from hanging
2841                 due to pending reads
2843 Release: version 0.5 - 2007/01/26
2844 ------------------------------------------------------------------------------
2845 2007/01/26
2846         - added missing errno.h header to gui/src/util.cc
2847         - lots more endian fixes after testing on iMac
2848         - iostream output size fixes
2849         - added option to btool to reset the device via software
2850         - beefed up exception handling in barrybackup
2851         - checked in opensync work-in-progress: trace logging, pointer bugfix
2852                 this is still experimental
2853         - added aboutdialog.* files from gtkmm24 2.10.6, so we have a dialog
2854                 class for systems running older versions of gtkmm, like
2855                 Debian stable
2856         - uncommented the about box menu handler
2857         - added "cleanall" option to root buildgen.sh script
2858         - update ReleaseChecklist.txt
2859         - removed CVS auto-history strings from aboutdialog.*
2860 2007/01/25
2861         - found a link between the unknown field in tagged protocol headers
2862                 and the unknown field in RecordStateTable entries.  This
2863                 field matters when uploading certain databases, such as
2864                 Browser Options.  It is unknown what this field really
2865                 means, but we're calling it RecType.  Updated the API
2866                 to use this in all parser objects and builder objects
2867                 and record objects that use it.
2868         - changed some uses of uint64_t to uint32_t, in Contact and
2869                 Calendar record objects... unique IDs only seem to be
2870                 32 bits
2871         - added new static function to record classes: GetDefaultRecType()
2872                 This returns the default rectype that should work
2873                 for that record.  Ideally this should be retrieved from
2874                 the device, but in the case where a database has no
2875                 records, this info would be good to know.
2876         - updated convenience template function Controller::AddRecordByType()
2877                 to use GetDefaultRecType()
2878         - documented the recurrence data and how to use it in Calendar objects
2879         - added data debug output for incoming USB packets in the
2880                 socket class... when we ported to the stable libusb
2881                 we lost some of the verbose output... this should get it
2882                 back.  (In the official release, you need to uncomment
2883                 ddout() in debug.h for the full blast of debug output).
2884         - backup GUI updates:
2885                 - changed error_done signal into a pure error signal,
2886                         and changed the logic so the restore continues
2887                         even if there was a protocol error on one database
2888                 - changed status bar messages to show what's happening
2889                         i.e. Backup or Restore
2890                 - default to not restore the "Handheld Agent" database as
2891                         it appears to be read-only on the device
2892                 - added temporary Restore & Backup mode for debugging
2893                 - added extra hyphen to backup files to show date/time better
2894                 - updated GUI to save and restore the new RecType field
2895                         supported now by the library
2896 2007/01/21
2897         - added future considerations to doc/ReleaseChecklist.txt
2898         - applied big endian patch from Jonathan Hudson
2899         - changes to patch:
2900                 - removed endian.h include from barry.h, since applications
2901                         using the library should not care about endianness
2902                 - hard coded the path to config.h in endian.h
2903                         so that endian.h never makes it into the final
2904                         install
2905                 - removed DEFAULT_INCLUDES setting from src/Makefile.am
2906                         for the same reason
2907                 - removed config.h dependency in btool.cc and used library
2908                         Version call instead
2909         - added big/little endian text to the Barry::Version call
2910         - updated AUTHORS
2911         - fixed install location of bcharge when building with ./configure;
2912                 now goes to sbin/ for both source compile and binary packages
2913                 Thanks to Jonathan Hudson for reporting this bug.
2914 2007/01/20
2915         - added smarter timeout values to controller, and allowed
2916                 timeout overrides in the packet, socket, and usbwrap code...
2917                 extra timeouts are needed for erasing databases for
2918                 some older devices
2919         - added an explicit DataDumpParser class to btool.cc, as the
2920                 library doesn't always have extreme verbose debugging on...
2921                 this makes sure anyone can always get raw database packets
2922                 through btool, for development
2923         - added thread callback signals for error finishes and erase_db
2924                 operations, so the GUI is updated properly
2925         - more GUI cleanups (status bar updates, etc)
2926         - finished implementation of GUI restore
2927         - fixed gtkmm/glibmm exception handling when the exceptions
2928                 occur in sigc signal handlers... in that case,
2929                 exceptions need to be handled with
2930                 Glib::add_exception_handler()
2931         - added filename-only reading support to TarFile class
2932         - added pending gui/TODO items
2933 2007/01/19
2934         - backup GUI now properly shows progress
2935         - the buttons become insensitive when backup is busy
2936         - refactored directory check code, and added mkdir check
2937                 when to the backup setup (so the directory exists
2938                 when we try to write to it)
2939         - updated code to use Barry::Data in new namespace
2940 2007/01/18
2941         - moved Data class into Barry namespace
2942 2007/01/13
2943         - updated copyright dates for the new year
2944         - clarified exception message in controller.cc
2945         - fixed pointer initialization bug in controller.cc
2946         - added documentation comments to parser.h and builder.h
2947         - updated ReleaseChecklist.txt
2948         - updated README
2949         - changed Barry library configure scripts to make better
2950                 use of pkg-config for autodetecting dependencies
2951         - added initial Barry Backup GUI (gui/ directory), capable of making
2952                 backups only at this point
2953 2007/01/11
2954         - added doc/ReleaseChecklist.txt
2955         - added version API, returning version number and string
2956         - added Troy Engel to AUTHORS
2957         - added special case to bcharge.cc for the Blackberry Pearl,
2958                 which doesn't reset itself after the charge handshake
2959                 Thanks to Troy Engel for testing.
2960 2007/01/05
2961         - added pkg-config support for the library (libbarry-0.pc.in)
2962         - fixed compile error on g++ 3.3 systems (missing stdint.h
2963                 in probe.h)
2964         - fixed protocol hang at end of Controller operation... in
2965                 controller destructor, it was deleting the USB interface
2966                 before closing the socket at the BlackBerry level, thereby
2967                 leaving the device in Desktop mode
2968 2007/01/04
2969         - support the newer udev packages on Ubuntu, which need slightly
2970                 different rules
2971         - modified bcharge.cc to search for Pearl devices too.
2972                 USB product ID 6
2973         - added Pearl product ID to probe code, but likely not functional
2974                 yet until we find someone able to get a USB capture for us
2975 2006/12/29
2976         - version bump in configure.ac and src/Makefile.am
2978 Release: version 0.4 - 2006/12/29
2979 ------------------------------------------------------------------------------
2980 2006/12/29
2981         - added bcharge.cc to the tools/ directory (whoohoo!)
2982         - added initial release version of rpm/barry.spec (aka bcharge.spec)
2983                 This begins the barry binary release, currently only
2984                 including the bcharge utility, but possibly more in
2985                 the future.  Future binary packages will likely include
2986                 libbarry, libbarry-devel, etc, which barry will then
2987                 depend on.
2988         - added udev rule script for BlackBerry devices
2989         - added man/ directory and bcharge.1 manpage
2990         - added debian/ directory for building deb packages, with initial
2991                 package scripts
2992         - added rpm/make-rpm-tarball.sh for building RPMs
2993         - split out technical docs into separate libbarry.docs file for
2994                 a future Debian install
2995         - added more cleaning to buildgen.sh
2996         - added new udev rule file for Debian stable
2997         - hardcoded g++ to 3.3 in debian/rules as I have multiple versions
2998                 on my system and need to compile releases with stable
2999 2006/12/21
3000         - ported Barry to use the stable branch of libusb
3001                 NOTE: no longer depends on the devel libusb tarball!
3002                         Just use your distro's libusb packages.
3003         - fixed more endian issues
3004         - minor update to TODO
3005 2006/12/15
3006         - moved Exceptions, Hacking, and VersionNotes to doc/
3007         - added doc/USB-capture.txt
3008 2006/12/08
3009         - added Controller::AddRecord() and template helper
3010         - added beginning version of generic RecordFetch<> template
3011         - set default of Barry::Init() to false (no data dump mode)
3012         - added examples/ directory, with first addcontact.cc example
3013 2006/12/07
3014         - added autoconf support based on Peter McAlpine's patch
3015         - renamed Makefiles to Makefile.orig and added script to turn
3016                 on old build system if wanted
3017         - fixed boost-specific error path in btool
3018         - moved platform specific code out of time.h and into time.cc
3019         - moved btool.cc, translate.cc, and upldif.cc out of src/ and
3020                 into their own tools/ subdirectory
3021         - added NEWS file to make autotools happy
3022         - added a "clean" option to the buildgen.sh script... maintainer's
3023                 use only
3024         - reworked autoconf and automake files, to support
3025                 barry as a library, to move the programs into their
3026                 own tools directory, and support a proper installation
3027         - fixed headers in parser.h, btool.cc, and upldif.cc to work
3028                 properly when installed standalone
3029         - added tools/Makefile.plain for testing compiling against
3030                 installed barry library
3031         - added commentary on version number system
3032         - removed Makefile.conf and Makefile.orig, as new autoconf
3033                 system supercedes it
3034         - added support for boost serialization library in autoconf build
3035         - added library version number to autoconf build
3036         - changed boost flag to __BARRY_BOOST_MODE__ to avoid collisions
3037         - removed debug.h dependency from btool.cc
3038         - removed libusb check in favour of specific --with-libusb
3039                 option... may need to revisit this later
3040         - quick installation update in README
3041 2006/12/01
3042         - fixed some missed endian conversions in record.cc and added
3043                 some size checks
3044         - fixed endian issues in time.h
3045         - added 2 more functions to the time zone API, and adjusted
3046                 the time zone table for better defaults in North America
3047         - added btool and upldif to the make install sequence
3048         - added support for Calendar recurrence data
3049         - small doc/TimeZones.txt update
3050 2006/11/24
3051         - added BlackBerry time zone code list, reverse engineered from a 7750
3052         - added GetTimeZone() to convert device time zone codes to useful data
3054 Release: version 0.0.3 - 2006/11/24
3055 ------------------------------------------------------------------------------
3056 2006/11/23
3057         - added return code check to Controller::SaveDatabase()
3058         - fixed Data() class constructor, so it doesn't auto-convert
3059                 from any int
3060         - fixed size checking bug in Packet::ReturnCode() that caused
3061                 uploading to device to fail
3062 2006/11/10
3063         - added Exceptions doc file, documenting the C++ exceptions used,
3064                 and their hierarchy
3065         - fixed small bug in 'make install' which didn't build first
3066         - minor documentation and cleanup in upldif.cc
3067         - added utility functions to the RecordStateTable class,
3068                 GetIndex() and MakeNewRecordId()
3069         - changed btool so that the -d command modifiers can be
3070                 specified multiple times to work with multiple records
3071                 at once
3072         - added Calendar sync code to the opensync module (not complete)
3073         - cleaned up exception handling in the opensync module, making
3074                 more use of the base exception to make sure no
3075                 exceptions leak into the C library code
3077 Release: version 0.0.2 - 2006/10/12
3078 ------------------------------------------------------------------------------
3079 2006/10/12
3080         - fixed casting error in opensync module
3081         - minor updates to documentation to prepare for release
3082 2006/09/29
3083         - added stdint.h to parser.h for uint32_t.  Thanks Ron Gage for
3084                 the bug report
3085 2006/09/08
3086         - large refactoring of the packet parsing and building code,
3087                 splitting the code into 3 groups:
3088                 - record: handles record specific parsing and building...
3089                         this is mostly subfields with CommonField structs
3090                         as their headers, but sometimes has a specific
3091                         header of its own, in the case of email
3092                         Note: email's header is as yet undecoded.
3093                         Record does not know the details of the packet
3094                         formats, only the formats of its own record data.
3095                 - packet: handles building of complete command packets
3096                         and handles parsing of commonly used header values,
3097                         providing an API for it... packet does not know
3098                         the record format details, but does know the
3099                         details of each Database Operation (protocol.h)
3100                         packet format.
3101                         So far, it seems that there is a real separation
3102                         of operation formats and record formats, with the
3103                         record formats being the same even with different
3104                         database operation codes (GET_RECORDS /
3105                         OLD_GET_RECORDS), which was not confirmed before.
3106                         See the header size of the email record after
3107                         refactoring.
3108                 - controller: handles device state, and the management of
3109                         sockets, commands, and checking for response values.
3110                         The Controller object does not know the format
3111                         of either the record or the packet it is sending,
3112                         but does know the protocol handshake logic used
3113                         to talk to the device.
3114         - implemented SetRecord (SET_RECORD_BY_INDEX)... syncing, here
3115                 we come!
3116         - spelling correction in opensync-plugin/AUTHORS
3117 2006/09/01
3118         - added sample hotplug scripts
3119         - added .cvsignore files for doxygen and opensync directories
3120         - added src/endian.h... still need to add configure support to
3121                 handle non-little-endian machines
3122         - added exception handler in opensync plugin commit_change()
3123         - removed the device reset code in probe.cc, as resetting a device
3124                 can renumber the devices in /proc on kernel 2.4.x,
3125                 and cause a failure to reach the device...
3126                 FIXME - this should be changed someday to reset if probing
3127                 fails, and restart the probe on reset, as sometimes
3128                 the blackberry devices respond differently when not reset
3129                 Ideally, the probe protocol should be properly reverse
3130                 engineered.
3131         - added support for retrieving record state table, which is needed
3132                 for smarter syncing
3133         - added support for retrieving, deleting, and clearing the dirty
3134                 flags of individual blackberry device records
3135         - added endian macros throughout the code
3136 2006/07/13
3137         - added opensync-plugin to root Makefile's clean
3138         - updated time conversion calls to match opensync's latest SVN
3139         - added opensync_change_set_changetype() (only add for now,
3140                 for development)
3141         - removed slow sync functions for now
3142 2006/07/07
3143         - added quick "install" makefile target, to src/install by default
3144         - added static library target... this is temporary until autoconf
3145                 stuff is added properly... needed for the opensync plugin
3146         - documented in comments that Barry::BError is intended to be
3147                 the base classes for all exceptions
3148         - added first round of implementation of an opensync plugin, based
3149                 on the example plugin code from the opensync sources
3150 2006/06/22
3151         - added to Contact record class:
3152                 - Clear()
3153                 - ReadLdif() to load and parse LDAP data
3154         - added fragmented send support to Socket class
3155         - added Probe::FindActive() to make client programs more streamlined
3156         - fixed hex/decimal printing of record counts in btool
3157         - added upldif.cc, a utility to take ldapsearch output on stdin
3158                 and upload it to a blackberry
3159         - updated src/.cvsignore
3160 2006/06/16
3161         - added parsing of service book fields:
3162                 - old and new name
3163                 - old and new unique ID (UID)
3164                 - content ID (CID)
3165                 - old and new description
3166                 - DSID
3167                 - bes domain / domain
3168         - date change in legal.txt
3169         - added initial parsing of ServiceBook field 0x09, and calling it
3170                 ServiceBookConfig for now, for lack of a better name
3171         - added parsing for ServiceBook field 0x02 on 72xx Blackberries...
3172                 seems to be a name or description, but doesn't appear
3173                 in the device's own GUI... called "Hidden Name" for now
3174 2006/06/09
3175         - added ServiceBook record class and parser code, based on some
3176                 of Ron Gage's reverse engineering... code is by Chris Frey
3177         - added AUTHORS file
3178         - fixed the libusb set_configuration/claim_interface order
3179                 bug in controller.{h,cc}... already fixed in probe,
3180                 but not controller.  Thanks Ron Gage for finding this.
3181 2006/05/25
3182         - renamed Changelog to ChangeLog in preparation for autoconf
3183         - renamed Todo to TODO in preparation for autoconf
3184 2006/05/18
3185         - make clean cleans up tests properly now
3186 2006/03/31
3187         - turned source code browsing on in Doxyfile
3188         - added LoadDatabaseByName() and LoadDatabaseByType() template members
3189                 to the Controller class
3190                 - new file: controllertmpl.h
3191         - documentation fixes in builder.h
3192         - added static GetDBName() functions to all record classes, in
3193                 support of the template Controller functions
3194         - fleshed out DatabaseDatabase::GetDBNumber() and GetDBName(),
3195                 returning errors properly
3196         - documented sample btool.cc code better, and added example
3197                 of Controller template member usage
3198 2006/03/29
3199         - copyright dates updated for 2006
3200 2006/01/05
3201         - backed out update to latest libusb DEVEL tree, since it is buggy.
3202                 Stick with libusb 2005/11/26
3203 2005/12/30
3204         - added clean target to convenience Makefile
3205         - added Boost to list of dependencies in README
3206         - fixed minor compile warnings in base64.cc
3207         - fixed new USB discovery code, and changed endpoint usage to use
3208                 it, instead of the READ_ENDPOINT and WRITE_ENDPOINT
3209                 constants... constants are now removed
3210                 common.h, controller.cc, probe.cc, probe.h, usbwrap.cc
3211         - added ClearHalt() to Usb::Device (usbwrap.cc)
3212         - updated usbwrap.h to match latest libusb CVS devel tree
3213         - updated README to refer to 2005/12/30 libusb CVS devel tree
3214         - added roadmap to Todo list
3215 2005/12/29
3216         - added convenience Makefile in root directory
3217         - added Hacking document
3218         - minor touchups to README
3219         - added caution warning to README, since this release will support
3220                 delete / overwrite / upload functionality
3221         - minor compile order change in Makefile (speed reasons)
3222         - added dynamic endpoint discovery to probe.cc
3223         - changed claim_interface/set_configuration() function call order in
3224                 probe.cc based on feedback on the libusb mailing list
3225         - added USB discovery code to usbwrap.{h,cc}
3226 2005/12/23
3227         - fixed packing bug in new upload header struct
3228         - renamed CommonField union from data to u to be consistent
3229         - added return_code field to DBAccess struct, for error checking
3230         - added response checking during upload: if response is non-zero
3231                 throw exception in controller.cc
3232         - added sorting operators to record parser classes... when writing
3233                 contact data to the device, it may be important to write
3234                 group link items last, since they reference other contacts...
3235                 This needs to be tested, and if not required, removed.
3236         - added GROUP_FLAG field code to Contact parser class
3237         - fixed offset bug in Contact and Calendar Build() functions
3238         - fixed name bug in Contact::Build(), now output only with data
3239         - added appointment type flag support to Calendar record parser
3240                 class, and "all day event" flag support
3241 2005/12/22
3242         - added autoconf to Todo list
3243         - refactored the protocol structures so that record structs can
3244                 be reused for upload and download
3245         - with new protostructs, more header control is handled by
3246                 controller.cc instead of record.cc parsers and builders
3247         - parser code now accepts an offset, to govern start of record data
3248         - changed Data sizes from int to size_t and removed casts
3249         - removed unneeded Parser::GetHeaderSize() (new protostructs make
3250                 this obsolete)
3251         - added Calendar::Build() for calendar uploads
3252 2005/12/10
3253         - added s11n-boost.h serialization templates for boost::serialization
3254         - added boost::serialization to build
3255         - minor change in usbwrap.cc to display error codes in decimal
3256         - added SizePacket special case code to Socket::Send()... this is
3257                 required when uploaded packet size is a multiple of 0x40,
3258                 a special 3 byte size packet is sent
3259         - moved some record class variables to public: so they can be
3260                 properly serialized
3261         - fixed variable name but in RecordBuilder template
3262         - added -f switch to btool, for saving and loading of record data
3263         - added -s switch to btool, for uploading saved data back to handheld
3264         - added Controller::SaveDatabase()
3265 2005/12/08
3266         - fixed potential casting / pointer bug in controller.cc
3267         - added builder.h, to support uploading
3268         - minor comment fixes in parser.h
3269         - added preliminary Contact protocol record building support
3270         - fixed field order bug in ContactRecord protocol struct
3271         - Contact record.h class now saves unknown Group Link field,
3272                 for later saving
3273 2005/12/07
3274         - added -fno-strict-aliasing to compiler flags so gcc-4.0.x won't
3275                 optimize away protocol struct casts
3276                 see:
3277                 http://gcc.gnu.org/bugzilla/show_bug.cgi?id=25235
3278                 http://mail-index.netbsd.org/tech-kern/2003/08/11/0001.html
3279                 http://groups.google.ca/group/comp.lang.c++.moderated/ \
3280                         browse_thread/thread/e7bf096832526f8e/5714701b \
3281                         02a2a3cc?hl=en#5714701b02a2a3cc
3282         - changed headers so that any low level protocol-specific sizes and
3283                 structs are completely hidden in the library...
3284                 this adds library-only header: protostructs.h
3286 Release: version 0.0.1 - 2005/11/25
3287 ------------------------------------------------------------------------------
3288 2005/11/25
3289         - added barry.h for documentation purposes and application usage
3290         - updated README for release
3291         - renamed SBError exception class to BError
3292         - updated Doxyfile to version 1.4.5
3293         - added more doxygen comments
3294 2005/11/24
3295         - added conversion routines (and tests) between time_t and min1900_t
3296         - added -v option to btool to dynamically control protocol dumping
3297         - removed duplicated database database table display in controller.cc
3298         - minor spelling corrections
3299         - added copyright to usbwrap.{h,cc} as per earlier meeting
3300         - added support for Old protocol Calendar entries
3301 2005/11/20
3302         - added legal.txt, to save typing when adding new source files
3303         - ignore test-base64 file (cvsignore)
3304         - added contact-to-ldif generation, and updated supporting code
3305         - added argument to btool to support contact-to-ldif operation
3306         - added Contact::GetPostalAddress()
3307         - added README documentation in preparation for future release
3308 2005/11/19
3309         - added parser.{h,cc} virtual wrapper to generalize LoadDatabase()
3310         - added code to socket.cc's Packet() command to re-receive on
3311                 reception of empty packets... this seems to be a signal
3312                 from the device that it needs more time for long transfers
3313                 Current limit: 10 blank packets before exception is thrown
3314                 Observed maximum blank count: 1
3315         - added MessageRecord and OldMessageRecord to protocol.h
3316         - changed common record field structs to one CommonField struct
3317         - increased default USB timeout to 10 seconds (some loaded devices
3318                 seem to need more time...)
3319         - reorganized record.{h,cc} to try to reduce the code duplication
3320         - record.h classes now "know" the sizes of their corresponding
3321                 protocol structs... this may cause trouble down the line
3322                 with Python, if used(?)
3323         - added Message class for Email records
3324         - removed the "Get*" database functions and replaced with
3325                 general LoadDatabase() call, which loads any database
3326                 available, and parses it with a Parser object
3327         - added GetDBID() for searching for database numbers via name
3328         - added test code to retrieve and display all email
3329         - cleaned up comments
3330         - renamed blackberry.{h,cc} to controller.{h,cc}
3331         - renamed bbtool.cc to btool.cc
3332         - added Makefile.conf
3333         - added copyright notices to source files
3334         - added COPYING file with GPL
3335         - put parser in Barry namespace, and added auto_ptr-like mode for
3336                 store object pointers
3337         - added doxygen docs
3338         - added header comments to convo.awk script
3339         - removed Test() function in Controller object, and made class
3340                 better suited to its general API purpose
3341         - changed OpenMode() so it loads command table and DBDB... it is now
3342                 a public API function
3343         - moved Controller test code to btool.cc and made tool more
3344                 generically useful... can now download any DB by name on
3345                 the command line
3346         - added mode checks to Controller
3347         - added -t and -d command line options to btool
3348         - added base64 routines from John Walker / Fourmilab and Citadel/UX
3349         - converted base64 routines into an API, instead of hardcoded
3350                 file based
3351 2005/11/18
3352         - changed project name to Barry, including namespaces
3353         - renamed sbcommon.* to common.*
3354         - increased USB default timeout to 2 seconds
3355         - fixed formatting bug in Data operator<< output
3356         - cleaned up the protocol packet structs, getting rid of the
3357                 confusing param/simple split... param is now the tableCmd
3358                 from the Command Table
3359         - moved protocol structs from record.h to protocol.h
3360         - added support for older version of the USB protocol, which matches
3361                 the Cassis spec more closely
3362         - fixed the hardcoded offsets in blackberry.cc's protocol parsing
3363         - fixed Socket::Close() so on error, socket flags are reset.
3364                 This stops Close() from being called twice on exception
3365                 destructors
3366 2005/11/17
3367         - added Doxyfile to the project
3368         - tuned Makefile
3369         - added mode selection support to Blackberry class (RIM Desktop,
3370                 RIM Bypass, and RIM_JavaLoader)
3371                 Mode selection governs which socket is used in subsequent
3372                 data transfers.
3373         - added Command Table parsing and protocol support
3374                 Blackberry class, and CommandTable record class
3375         - added Database database parsing and protocol support
3376                 Blackberry class and DatabaseDatabase record class
3377         - added Address book retrieval support - dumps data to stdout for now
3378         - fixed bug in CopyOnWrite mode in Data class, where could allocate
3379                 less buffer than data copied
3380         - added "easy exception" debug output macro
3381         - fixed minor spelling error in protocol.cc
3382         - fixed ModeSelectCommand protocol structure - it is not a parameter
3383                 command, but uses the unknown slots for socket and flag
3384                 data
3385         - removed hardcoded socket numbers from protocol.h
3386         - fixed bug in socket.cc:Open() where packet size was not properly
3387                 saved
3388         - implemented socket::Close()
3389         - fixed sequence number checks, so it is reset properly on socket 0
3390         - added Socket::NextRecord() for multiple record data transfers
3391         - fixed input handling bug in translate.cc
3392 2005/11/11
3393         - added .cvsignore files to project
3394         - added README notes to document the source architecture
3395         - added dbsetup data script, which shows how to get into database
3396                 mode, using the RIM Desktop mode, and open a socket
3397         - added blackberry.{h,cc} class
3398         - added command line parameters to bbtool.cc
3399                 -l = list only
3400                 -p = specify pin of blackberry device
3401         - added blackberry test code in bbtool.cc - debugging the initial
3402                 opening protocol: sockets, modes, etc... see dbsetup for
3403                 results
3404         - added copy-on-write functionality to Data class, so it can be used
3405                 with plain data buffers with little performance impact
3406         - added eout() and ddout() debugging - to separate:
3407                 - regular debug output
3408                 - exception debug output (should probably be logged to
3409                         syslog someday, and never turned off)
3410                 - raw data dump output
3411         - changed errno SBError exception handler to try to decode the error
3412                 numbers into english (limited success)
3413         - fixed probe and socket USB Bulk message handling, so they don't
3414                 use PollCompletions(), but use IO::Wait() (libusb_io_wait())
3415         - added common packet size checker in protocol.cc
3416         - fixed unpacked protocol packet structs... using gcc's
3417                 __attribute__ ((packed)) ... see protocol.h
3418         - added ModeSelectCommand structure (protocol.h)
3419         - finished Socket::Open() call  (Close() not yet implemented)
3420         - moved Socket::Send/Receive() out of private, as they can be used
3421                 for socket 0 operations.
3422         - cleaned up pointer management with macros:
3423                 MAKE_PACKET()
3424                 COMMAND()
3425                 IS_COMMAND()
3426         - added IO::Wait() and IO::Cancel() to correspond with libusb API
3427         - added datadumping in usbwrap for easy protocol capture
3428         - added preliminary record.{h,cc} classes
3429         - added Contact record parsing, and test code
3430 2005/10/20
3431         - syncberry tree started