** KPILOT CHANGELOG ** ====================== TODO: Figure out why archived records are bad. [23:07] Now i'm hunting why new entries on the palm are dropped and deletes from the palm as well. [23:44] [ade]: Hm, I delete a task on the palm, sync, and the record->isDeleted() is false, on sync, but it is modified and updated on the pc, although that does not change anything. TODO: store map of pilot-id <-> uid elsewhere (not in the .vcf file) TODO: don't make ActionQueue auto-delete the actions in it. TODO: provide template-based, interpreted databases much like the AppInfo classes now have. TODO: give the knotes conduit a decent test mode. TODO: only re-write a local database if it is changed. 2007-12-30 Jason 'vanRijn' Kasper * Fixing bug reported by Pablo Yepes on tdepim-users mailing list. We did severe goofiness with middle names... The Palm can't handle them, so we blindly tacked firstname + " " + lastname and stuck it into the Palm's firstname field. The problem is that whenever a copy from palm->pc is done, the kludged first name is transferred to kabc ("firstname middle"). And, it's compounded by every change in either direction. It's an ugly hack and I've removed it. The only way to work around it would be to add an additional check for !firstname.endsWith(abEntry.additionalName()), but that's even sillier. Stop the insanity! 2007-12-17 Jason 'vanRijn' Kasper * Woot! Fixing major breakage for funky usb devices. pulled back some removed code from KDE 3.5.6's kpilot for usb workaround code and fit it into the new threaded model. This fixes syncing for me on my Palm Treo 700p. * Reformatting and cleaning up kpilotdevicelink.cc. * New Private.h to hold the bits of kpilotdevicelink.cc that should not be exposed via kpilotdevicelink.h. Also, DeviceCommThread extends QObject and QThread, so we need to have automoc run on it. * Switching from using QCustomEvent to using QEvent for device tickle thread to match what is done in kpilotdevicelink. 2007-04-15 Jason 'vanRijn' Kasper * merging all development and bug fixes from tdepim-3.5.5+ branch into stable branches/KDE/3.5 in preparation for KDE 3.5.7 * cmake cleanups * namespacing and cleanups in sysinfoconduit * lots of debugging cleanups. remove #ifdef DEBUG from much of the code. * cleanups in memofile conduit. now try to use new (OS5) database (MemosDB-PMem) if it's found, otherwise fall back to the legacy one (MemoDB) * as a first step to combatting the "kpilot ate my future" e-mails (read: data loss), we now use a CUDCounter (Create/Update/Delete). step 1 is to track these and report on them to the user in their sync log. step 2 is to catch ill behavior and prompt the user as to whether or not to allow kpilot to make the large amount of changes. step 3 is to allow the user to configure the count or percentage of changes that kpilot can make without his/her confirmation. step 1 is done. we'll approach steps 2 and 3 post kde 3.5.7. * new strings related to the above * bug fixing in popconduit... making sure we always have a sent date * Bertjan has the start of knotes cleanup going on * bug fixing in vcalconduit... long-time bug that existed in libkcal that caused every calendar resource save to mark every calendar event as modified. now kpilot won't have to sync every record every time. * bug fixing kabc resource problems in abbrowser conduit. although it's not documented in kabc, it looks like we should be removing a local resource from the address book before we delete it. * bringing mal conduit back alive again. none of our small band of merry men use it, though, so it may or may not actually do what it's supposed to. * fixing bug where we were saving conduit databases to DBBackup instead of conduits/ directory. * changing KPilotDeviceLink to use a separate thread, dedicated to doing device communication. this is much better design as a start, but fixes the problems kpilot was having (and widely talked about) where kpilot would hang and crash if our user was using "usb:" or "net:any" devices because of how these new "device"s operated (allowed immediate opening, even though there is no physical device connected, and then hung indefinitely until the real device connected). * bringing in design documents (jpegs) for memofile conduit from 2004-12-12 (they're not installed, but are valuable for documentation and insight) * icon naming error bug fix 122582 2006-10-24 Jason 'vanRijn' Kasper * Getting rid of FastSync. The only difference between it and HotSync was that HotSync did a Backup and FastSync did not. Having a third permutation because of not having a way to set it in the Backup settings seems wrong. Also, if one of them is to go, I think that HotSync is much more recognizable and widely used than FastSync. * Allowing finer-grained control around when database backups are done. This is so that users can choose when they want a backup to be done. The problem I need to solve for myself is that since I'm now syncing between 2 PCs, I need a full sync to be done whenever I switch. But I do not EVER want an automatic backup to be done. Currently, this is not possible. Fixing it. =:) This will also allow for schedule backups to be done, which is also of interest to me. 2006-01-30 Adriaan de Groot * Updated pilot-link to today's CVS, with one change - use of pl_socklen_t in inet.c changed back to socklen_t. * Added --loop to kpilotTest to repeatedly run the same action. Only works for --list right now. 2006-01-23 Adriaan de Groot * Gosh, where to begin. KPilot moved SVN repositories, changed build systems, had the guts of the device link class refactored, bumped the plugin API version again, and tons more. The commit logs are probably the most useful source of information about what's changed. 2005-08-18 Adriaan de Groot * Found out that the PilotAppCategory constructor that takes a PilotRecord * was passing subsequent parameters in the wrong order, which caused Jason's problem below. * Renamed soem icons and fixed up the icon loading code so that the "sidebar" icons in KPilot can now be themed as well. 2005-08-18 Jason 'vanRijn' Kasper * Started fixing bug #103581. Got side-tracked by my discovery that when we change ToDos on the palm, we sync them to the PC and then promptly delete them from the Palm--not very nice of us. I'll try to get the rest working tomorrow, but the end result will be that if our user changes a ToDo category and there is only one category in korganizer for that ToDo, we will change the category for the KCal event. If there is already more than one category that korganizer knows about, then we'll continue to append the Palm's category to the one in korganizer. 2005-08-17 Adriaan de Groot * Promote the new Pilot*Info (template) classes which simplify loading AppInfo structures from a database. Deprecate some AddressEntry constructors to do so, and add one that takes a PilotAddressInfo instead. In kpilot/, replace a bunch of error-prone buffer-handling calls by the use of these template classes. * Use PilotAddressInfo also in the abbrowser conduit. This removes a bunch of tricky encoding handling from the conduit and puts it in the base Info class, where it belongs. 2005-08-16 Jason 'vanRijn' Kasper * Fixed annoyance in vcalconduit (korganizer calendar/todo conduit) that caused it to not clean up duplicates/things that should be deleted from the Palm on a copy PC to Handheld sync. * Fixed some majorly ugly bugs in the addressbook conduit that caused duplicate addressbook records to be generated and not deleted once created. 2005-08-15 Adriaan de Groot * Added lots of null-pointer checks so that it may become possible to run conduits without a device link soon. This would be good for testing. * Noticed that the factory code needs refactoring into templates. Did so, and ported the abbrowser factory to it. Basically, this removes a lot of cut-and-paste from the whole thing. Same for the timeconduit. 2005-06-05 Adriaan de Groot * I learned to make Chinese dumplings yesterday. That's a much better use of a saturday afternoon than bug hunting, don't you think? * Put lots of effort into the dox for PilotDateEntry, normalized a lot of things, gave things slightly more sensible names. This is work towards implementing the DatabaseInterpreter for appointments, so you can treat the data on the Pilot as a sequence of (libkcal) Events instead of as binary blobs. * Patch from Dylan G applied that replaces 15s and 16s in the code with a defined constant (there already was one, just not used consistently). Did some more rationalizing, finally removed the CATEGORY_COUNT define which was just a duplicate. 2005-05-27 Adriaan de Groot * Start of the PIM meeting! Way! * Committed some critical data-loss fixes yesterday. Too late for the KDE 3.4.1 release. Argh. I think it would have been better not to touch BRANCH at all and leave it at the same buggy state as in KDE 3.4.0 * Fairly large-scale deprecation of functions in lib/, finally factored out the shared attributes/category/id stuff from records and AppCategory objects. 2005-05-26 Jason 'vanRijn' Kasper * Fixing nasty little bug (#106324) causing data loss in memofile conduit * isFirstSync() is true for both copyHHtoPC and copyPCtoHH. memofile conduit only wants to do copyHHtoPC if we're either told to, or we don't have any local memos in the filesystem 2005-05-22 Adriaan de Groot * Gratuitously update the version number, call this one "kind" (Dutch for "child", or otherwise short for "kind of liable to eat your data"). This sort-of makes me wish we'd just left BRANCH totally unchanged since the last release. KDE 3.4.1 tomorrow. 2005-05-20 Adriaan de Groot * Split PISOCK_LIB into PISOCK_LIB and PISOCK_LDFLAGS. This makes it possible to slip the include and library dir for pilot-link right in front, which in turn makes it possible to build against development pilot-link versions even if there are installed copies in standard locations as well. * Extended the AppInfo template class with a pack function as well, so that reading and writing AppInfo blocks can be delegated there. * Ported the ToDo conduit to use the PilotToDoInfo template instantiation. 2005-05-16 Adriaan de Groot * Added yet another constructor to the local databases, this time hopefully one that doesn't have a horribly convoluted semantics -- it just opens a file (or not). * Added more tests for lib. These will always fail unless you have a copy of Aesop's fables in /tmp . 2005-05-13 Adriaan de Groot * Friday the 13th! I merged HEAD to BRANCH and am now working in BRANCH (branches/KDE/3.4/tdepim/kpilot) to do bugfixes. New features and strings go in HEAD, and we'll forward-port bugfixes at some point. The cutover is revision 413061. 2005-05-11 Adriaan de Groot * Wasted much time trying to get generic FreeBSD USB support for non- Visors working in pilot-link-0.12 before I found out that ColdSync doesn't support that either. * Removed non-working calendar conduits (calendarbaseconduit/ and calendarconduits/) from the conduits dir; restore them w/ SVN commits near 412528. These were recordconduit-based conduits by Reinhold, but I broke the RecordConduit in the meantime. 2005-05-07 Adriaan de Groot * After tweaking pilot-link 0.12-pre3 so that KPilot will with it (has to do with API consistency) the AppInfo template class works again, and i've extended it a little to make setting and getting category names nicer. * Applied the new template to the memofile conduit. 2005-04-22 Adriaan de Groot * Fixed (I hope) bug in notepad conduit related to having zero records in the database. * Added some more dox. 2005-04-20 Adriaan de Groot * Finally added a general test() function to sync actions to mirror the exec() call. By default, this calls exec() and logs a warning. Removed it again because it won't work -- SyncAction doesn't _have_ a SyncMode set. * Started doing a little bit of test code in the KNotes conduit. 2005-04-18 Adriaan de Groot * Being on vacation doesn't mean I'm not on the job. Doxied a lot, did some cleanup. * Renamed PilotLocalDatabase::writeID() and changed its signature, since it was kind of stupid. Doxied it, too. 2005-04-12 Adriaan de Groot * For a lark, and for David, re-added some KDE 3.2 compatibility code. * Template madness! An easy way to create the right appinfo's from any database. 2005-04-11 Adriaan de Groot * Bumped KPilot version. * Added a test program for some parts of the library. Woo! A first! Finally something resembling actual software engineering in KPilot. * Cleaned up headers that weren't including all required (system) headers. * Moved all the conduits to the new SyncMode. 2005-04-10 Adriaan de Groot * Some useful patches from Philip T. to the vcal conduit committed. * Made the sync mode a full-fledged class and ported lib/ and kpilot/ to use it. Disabled all the conduits for the time being. Bumped the conduit API because of this. This might cause some serious breakage for the time being. 2005-04-09 Adriaan de Groot * Geez, can we switch to Subversion yet? * Committed the weird-ass record conduit template changes. This makes the RecordConduit a fully templated "container". You plug in 5 other classes to get a working implementation. This is similar to what the record conduit already. The main difference is that it is easier to re-use the things you plug into the recordconduit template. I have a KNotes partial implementation that wraps KCal::Calendar, so that is immediately reuseable for the other 4-button ones. * Ripped out test mode from KPilotTest and elsewhere, since it wasn't working at all. I think the "mode" setting for conduits needs a lot more structure. Just having an enum doesn't cut it (what about doing a test-mode local PC to HH sync? Such a sync could be used to produce .pdb files from Kontact data, which is just what the doctor ordered sometimes). 2005-03-22 Adriaan de Groot * Long drought in doing any KPilot work or updating the ChangeLog. * Meddled in lib/ some to add modifiedIDList() and sanitize some types. * Prepared to make fFirstSync private, though it has getters and setters so that doesn't really do much for OO'ness. * Wrote a template class for doing syncs generically, to replace the RecordConduit. This one I understand, at least. It's not done yet though, by a long shot, though I have classes to plug in to it for KNotes. 2005-01-30 Adriaan de Groot * Fixed one nasty random crash thanks to vanRijn, probably fixed the KNotes HHtoPC problem, tagged 4.4.7, released it. This is the last version to support KDE 3.2 at all, since KDE PIM moved to KDE 3.3 ages ago and KDE 3.4 is at the door. 2005-01-12 Adriaan de Groot * Made KNotes conduit work when KNotes is embedded in kontact, too. * One branch of the check-username code wasn't setting the username properly. * More debugging niftiness, major NO_CAST cleanup. * Fixed sysinfo conduit, which didn't read its config file. 2005-01-11 Adriaan de Groot * Added a workaround for buggy Zire USB behavior. It works most of the time. * Fixed memory leak when reading AppInfo. * Updated website with some more OS-specific information. As always, I am in dire need of workable explanations for OS (usually Linux-distro) specific quirks. * Worked on debugging output a little, normalized more output. * Verified that copy PC to HH works on Addressbook, ToDo, Calendar. 2005-01-05 Adriaan de Groot * Pilot-link 0.12, when it comes out, is source incompatible with 0.11, but KPilot is already ported to it. * Fixed up silly conflict resolution question in the datebook, but really it needs the field-by-field resolution that the addressbook has. * In KPilotDeviceLink, move around check for unconfigured device to notice earlier, before doing any work. Minor coding style fixes. * Revamped debugging (again) so it's now much more 7 * 191; the call trace is pretty readable now. 2004-12-27 Adriaan de Groot * Quitting and having the daemon go with you works now. 2004-12-07 Adriaan de Groot * Tried to make conduit descriptions more consistent. Remember: "handheld", not "Pilot". Removed ugly const_cast. Added depth indication to the call trace -- this is a pretty big change, it makes the output from kpilot with --debug 1 more tree-ish, so it's easier to see what is being called from where. 2004-12-06 Adriaan de Groot * Imported memofile from vanRijn. 2004-11-30 Adriaan de Groot * Having a second child .. puts a dent in development time. * Make the daemon's next-sync match the one in KPilot, added tooltips and whatsthis. Make the daemon tell KPilot what the next sync is, so that changes from the tray menu are visible. This removes some strings. 2004-11-29 Adriaan de Groot * Waiting for second child .. puts a dent in development time too. * Ported KPilot to pilot-link 0.12 (unreleased) which adds support for newer devices and saves memory in the process. * Data-loss on restore bug fixed by Will Stephenson. 2004-11-23 Adriaan de Groot * Squashed several silly bugs in wizard and startup code. 2004-11-17 Adriaan de Groot * Hiatus in KPilot due to working upstream on pilot-link. * Patches from Olivier, merci. 2004-10-11 Adriaan de Groot * Made an actual CVS tag for KPilot, kpilot_4_4_6. Uploaded new 4.4.6 tarballs. Updated the site. Posted more developer's notes. * Added initial encoding-selection boxes to the doc conduit, to indicate that the input text files are not UTF-8 but something else. * Started revamping PilotLocalDatabase so we can get rid of the must- sync-to-delete-new-(memo|address|whatever) in the internal viewers. * All the bugs in the database really need a "can you check this again"? added. Till Adam has been messing with recent code and is reporting new crashes and bugs. 2004-10-07 Adriaan de Groot * Started adding encoding support to PalmDOC conduit dialogs. Not sure how to proceed there. * Closed some more bugs, generally confused about some of the bugs remaining in the database -- I need cooperation from the folks reporting the bugs. * Went on a str*cpy() hunt to avoid bad copies; converted most to strlcpy(). Not the ones in the docconduit, though, since there, the strncpy()s go to a data structure that doesn't necessarily expect NUL termination (note to self: need to check that _extracting_ data from the structure doesn't rely on NUL). 2004-10-05 Adriaan de Groot * I wonder if the codec() stuff shouldn't move from the PilotAppCategory to the device link -- after all, it's the _device_ that knows what the encoding is (who knows, maybe future versions of Pilots will be able to tell th desktop this). * Added a localBackup action, so we can make ~ backup files of all the database files before doing a sync, just in case. * Merged lots of bugs. * Found out that KPilot uses title instead of prefix for the honorific titles in the addressbook - this means KPilot and KAddressbook got out of sync. Fixed. * New questionYesNoCancel() didn't return correct button codes. * Checked all the codec stuff, added some in relevant places but can't spot any addressbook fields that are not synced. 2004-10-04 Adriaan de Groot * Bail if the Pilot disconnects, but only between conduits. Conduits themselves should still check for disconnect. * Bug maintainence turned up a useful patch for category support in the calendar. 2004-10-01 Adriaan de Groot * Merged nice patch from Adrian S for HotPlug. * Moved tickle stuff into a separate thread, so that it doesn't require a Qt event loop to keep the Pilot awake. * Added tickles in the right (?) places in the abbrowser - around the loading part. * Discovered that UserCheck used KMessageBox::question*() instead of a version with timeouts. Fixed that by adding a qYNCancel() to InteractiveSync, and updated both qYN*() methods there to use KDE 3.3 KMessageBox support. * Merged InteractiveAction with SyncAction, cleaning up the inheritance tree and making it possible to conduits to use the question* methods. 2004-09-26 Adriaan de Groot * Put up new tarballs on kpilot.org. * Patched up the KNotes conduit a little - notes listed as modified but unknown to the Pilot are now added as new. * Bumped version to 4.4.5. Polished the splash a little. * Fixed 71122, finally. There wasn't any code at all in the conduit for deleting memos. 2004-09-22 Adriaan de Groot * Added some cheap RTTI to PilotDatabase, so you can call dbType() to find out if it's really a local or a serial DB. * Stared at the doc conduit for a long time. Did whitespace first. 2004-09-18 Adriaan de Groot & Reinhold Kainhofer * Deprecated a bunch of poorly-named functions in lib/, and moved everything to the new names. Finally, no more getCat(), but just category(). * Detect special case of bad resource headers in file installer. * Rearranged sync enum just a little. Moved eTest out of the way, since it's not really a valid value to pass to the demon and made 0 the value to indicate "default, whatever is stored in the config file". * Fixed up sync-type not honored, clarified next-sync menu (I think so, didn't ask -usability about it though). 2004-08-16 Adriaan de Groot * Was away at a summer school for two weeks. Got no KPilot stuff done except an off-by-one bug in the memo stuff. * Split the CopyHHtoPC code out in the knotes conduit, ready for QThreading (maybe). 2004-07-27 Adriaan de Groot * MAL conduit proxy password not loaded properly. Reported by Olivier D. * Clean out ancient cruft in fileInstaller.{h,cc}. Run file installer twice, to allow conduits to create files to install. Determine list of files at ::exec() time, not at object creation time. * Added some docs to the conduit configure.in.in. * Give PERL conduit more information to work with. 2004-07-19 Adriaan de Groot * In kontact, if the daemon gets started it shouldn't complain loudly about messed-up configurations. 2004-07-14 Adriaan de Groot * Joyeux quatorze juillet! Spent most of the past week totally ignoring KPilot, working on personal websites, KDE-FreeBSD, and porting k3b to FreeBSD (breaking it on Linux only briefly). 2004-06-29 Reinhold Kainhofer * Fix the bug that todos that were marked finished on the handheld lost that state when synced to the PC. * A few layout adjustments for the perl/python conduits (QTextEdit instead of QLineEdit) 2004-06-29 Joern Ahrens * Corrected the behavior of the configuration dialog, when the screensaver option is changed. * Moved the tickle code from InteractiveAction to SyncAction. Now it can be used in ConduitAction subclasses as well. * Ahh, got Adriaans m100, now I'm able to test without destroying my data on the palm. Thanks Adriaan ! 2004-06-27 Joern Ahrens * Filled the notepad conduit with life. The notepads are saved as png files in a configurable directory. 2004-06-21 Adriaan de Groot * Disable editor buttons when 'internal editors' is disabled (Carlos) and fix up the tooltips when they are disabled. Also update some copyright lines. Work on the docs. 2004-06-16 Adriaan de Groot * Disposed of foolish file installer bug. Updated tarballs on website before fixing it, so now we're stuck :) Looked at 71122 again, testing with my m500. * Corrected finaly layout problems in some conduit config pages. 2004-06-10 Adriaan de Groot * Much delay in getting back to work on KPilot, even after a new mobo arrived for my primary devel system. Useful patches were received in the meantime, and commited by Joern. Olivier D. has started improving the MAL conduit, wrt. proxy and password support. 2004-06-02 Joern Ahrens * Improved the wizards whatsthis text, thanks to David Bishop 2004-05-30 Adriaan de Groot * Handle first-time startups more gracefully by just running configure or the config wizard. Better reporting of non-running daemon. Fix some copyright headers. Add icons to next-sync menu in daemon. 2004-05-28 Adriaan de Groot * Make the tarballs available on the site; still no resolution for memo bug, or timezone bug. Change strings in the applications to point ot the new kpilot.org. 2004-05-20 Adriaan de Groot * Tested new tarballs for 4.4.3, and they seem ok. Put their md5s up on the website. Note that the memos-not-deleted-on-palm bug still exists, as do 60 others by last count. 2004-05-16 Adriaan de Groot * Put up the new KPilot.org website. * Updated docs about net: syncing, thanks to Miles Sabin. * Patch from Joern probably closes 4 bugs at once. 2004-05-11 Reinhold Kainhofer * Deprecated the JPilotProxy and expenses conduits, moved to nonbeta. 2004-05-07 Adriaan de Groot * PilotDatabase was a QObject. I wonder why, it didn't have signals or slots. * PilotDatabase creation and destruction is now tracked (counted, at least, so you can see if there's a leak there). 2004-04-30 Adriaan de Groot * Vrolijke koninginnedag! * Finally updated the site some. * Removed deprecated files, started using KDevelop, fixed random stuff. 2004-04-28 Adriaan de Groot * [kpilotConfigDialog] Added UI for screenlockSecure option. Docs, too. * [kpilot] Changed hotSync button to one with a little dropdown menu, thanks to Joern. [kpilotConfig] String fix for outdated config. [probeDialog] Fixed up comments. [hotSync] Normalized debugging output. [pilotDaemon] Fixed backwards logic. 2004-04-26 Adriaan de Groot * [kpilot.kcfg] Added [a68k] as default skip in the database list. * [pilotDaemon] Use standard names for sync actions. Queue sorry when sync type is bad. * [hotSync] Change signature of backup action, lose the confusing int mode parameter. * [syncStack] Took out the mode stuff, replaced with SyncAction::SyncMode. This simplified a lot of things, actually. Removed extra changed-PC check in ConduitProxy, on the assumption this is already checked elsewhere. 2004-04-21 Adriaan de Groot * [hotSync] Made skip-database work properly, with wildcard support and proper checking again, so you can now backup your Pilot and specify that FATFS and *a68k can be skipped. Even did docs for it. * [syncAction] Added function to return standard names for the (enum) sync actions. 2004-04-19 Adriaan de Groot * Cleaned up header comments, copyrights, body comments, indentation, brace style, and unused code in all kinds of files. Normalized use of magic constant 0xffff in PilotRecord::APP_BUFFER_SIZE. Removed some * in char *buffer[] where char buffer[] was meant, reducing KPilot's stack memory usage there by a factor of 4 or more. * Patch from Joern Ahrens to close another Bugzilla bug. 2004-04-18 Reinhold Kainhofer * Finish the autodetection of the handheld for the wizard. You *CAN* pi_bind to multiple devices, so I just create a bunch of device links and wait for connected signals... This also means we can get rid of page one of the wizard. There is one problem left: If /dev/pilot or so is a symlink to a real device, a connection on /dev/pilot and the actual device will be detected, and kpilot will lock up. I guess I'll have to keep a (static) QStringList of real devices we are bound to in KPilotDeviceLink and disallow binding to the same real device again. 2004-04-18 Adriaan de Groot * Default debug_level to 0, so it doesn't print the call trace, but just the (sometimes) useful debug output; use --debug 1 to print the call trace. * [pilotDaemon] Add more useful warning output when conversation with screen- saver fails. Add human-friendly way to request a specific sync type. Factor out a whole lot in the startHotSync() to clear up the actual logic. * Massive damage inflicted to factor out the one set of sync-enums and use them everywhere, while cleaning up the setup-sync logic too. Remove leading 'e' from enum type names (not the elements). 2004-04-16 Adriaan de Groot * Fixed double dialog when cancelling a change in the selection in the config dialog. Took patch from Joern to fix resize problem in abbrowser resolution dialog. Minor constructor mod in pilotMemo.h, and a much more nasty problem in pilotMemo.cc, which seems to use a wrong memo length. Added some docs. Removed a warning in addressWidget.cc. * [conduitConfigWizard] Can't assign copyright except in writing, and even then in the EU you can't renounce your copyright. Added a "None" sync setting, for the use-case described on 4-11. 2004-04-11 Adriaan de Groot * Testing, testing, 1, 2, 3. Let's look at a use case: someone who doesn't want to sync his or her palm with KDE apps, but does want a convenient application to install files and keep a backup of their palm. How can they use KPilot? Well, uncheck all the conduits except install files, set the daemon to auto-start, and do nothing more than drop the pilot inthe cradle occasionally and hit the HotSync button. Use kpilot's viewers to check the state of the backup. * [conduitConfigDialog] Use the CE macro for general config pages. Tighten typing on handleGeneralPages. Add names to the viewers tabs. Make unsaved-changes message make sense. 2004-04-11 Reinhold Kainhofer * Fix the codec handling to use TDEGlobal::charsets. * Implemented the startListening and stopListening methods of the daemon. * Fixed the config dialog so that just showing a conduit's config widget doesn't trigger the modified signal. * Some cleanup in the daemon 2004-04-10 Reinhold Kainhofer * Split kpilot's configuration into several files, one for each conduit. Also wrote a tdeconf_update script so the old settings are preserved. We still need to sort out the remaining settings written to kpilotrc. * Corrected all path variables in the .kcfg files from type String to Path * The configuration wizard now also sets the conduits' settings to sensitive defaults for the chosen application (kde pim, kontact, evolution) 2004-04-10 Adriaan de Groot * Move about in config dialog to sensible spot. Follow suggestions by Carlos to simplify the config dialog a bit. Default general setup to open, even if the message says it it for esoteric stuff. 2004-04-09 Adriaan de Groot * Work on docs. Accept patch from Joern for broken config in abbrowser conduit. Receive docs patches from Carlos. 2004-04-05 Adriaan de Groot * Work on the Kontact plugin for KPilot, make daemon's installedConduits DCOP call return human-readable names instead of internal stuff. 2004-04-04 Adriaan de Groot * Split out the general settings pages so that no tab widgets are needed. Joern's title patch for those pages made the tabs weird anyway, and now things are consistent, at least. We could move the backup page to "Actions", if we want. 2004-04-01 Adriaan de Groot * Happy birthday to Mira, who has now managed to watch a whole year of KPilot development, and has learned to sit up and say "aya!" appreciatively when Daddy fixes a bug. Or something. 2004-03-28 Adriaan de Groot * Added a "reset daemon" button. Added whatsthis help to toolbar. * Added a "suppress confirm" option to the notes conduit, partly for 71122. * Suppressed some more warnings. Fixed little buglets. Put off testing 71122 as long as possible. 2004-03-26 Adriaan de Groot * Another day, another fix from Joern. * Backported the fix for backup settings being ignored from Sebastian V. (Actually, just used his original patch, which didn't use kcfgXT. * Prevent sync when screen locked, as a security measure. * Still haven't tested 69595 or 71122. Ugh. 2004-03-24 Adriaan de Groot * 71122 has been top of the list for over a week - not getting around to it at all. Fixes elsewhere; working on getting a Linux machine up and running to be able to run POSE with a null-modem pseudo-device. * Another patch from Joern; arr, it's a learning experience! * Removed logging weirdness in the fileinstall action. 2004-03-19 Adriaan de Groot * Discovered that the daemon's DCOP interface disappears after one HotSync. Man, that's weird. Removed QString(CSL1()) constructs - CSL1() returns a QString already. Using DCOPClient::attach() in the pop conduit is a really bad idea! * Picked bug 72251 to work on tonight. Closed another one related to settings not propagating properly as well. * Minor cleanup in the log on the pilot, get conduits to start on new lines. Use correct name for icon. Handle FastSync correctly, don't queue all the extra checks for it based on the sync settings (or do we want to deprecate fastsync as a fNextSyncMode entirely?). At end of sync reset next sync to normal. 2004-03-17 Reinhold Kainhofer * Implemented a first version of the config wizard. The code to autodetect the device is not yet finished, though. * Extended the daemon DCOP interface to stop listening and start listening on the configured device (needed e.g. if some other application wants to bind to that device for some time, like the autodetect dialog needs to). Here, also the code for really (de-)attaching to the device is not there yet, just the interface to the functions. 2004-03-17 Adriaan de Groot * Ripped out all the dead and broken and useless code in the mail conduit, fixed up the code that was left, reduced the size of the setup dialog, and ended up with something that actually works again. Fixed bugs 60579 and 77948. * Yet another patch from Joern, added him to credits, too. 2004-03-15 Adriaan de Groot * Patches from David Mott and Joern Ahrens today. Excellent! * Worked on the docs and website some. 2004-03-14 Reinhold Kainhofer * Make sure the config is really read in in the vcal conduit's setup dlg. * also the conduit version number of the vcal conduit needs to be really written to the cfg file to make sure categories are really synced. So far, the version number was not written to the config, which resulted in a full sync every time! 2004-03-13 Adriaan de Groot * Stared at the screen for a while trying to think of how to test syncing with my spare m100 without breaking my existing stuff from my m500. And I realize that it means I need a second monitor and to run X dual-head. * Some minor rearrangements in the config dialog again. * Added configuration widget to perl conduit. 2004-03-12 Adriaan de Groot * Received patches from Joern Ahrens and Sebastian Voitzsch for various issues. Thanks guys! It's contributions like this that really inspire me to keep working on KPilot. Reinhold and I can't do everything by ourselves. * There will be tarballs of KPilot 4.4.2 soon; this will make it possible to get the bugfixes from Joern and Sebastian - and others - on your system now without waiting for another KDE release. 2004-03-08 Reinhold Kainhofer * Ported all conduits' setup dialog to the new style and remove all old code * First steps for the config wizard. * Updated the malconduit to work with libmal 0.4, too (using configure checks, as the code is source-incompatible) * Moved the kpilot config page to the correct place in the kontact setup dlg hierarchy * Fixed a crash in the old-style conduits' setup code (widget was removed in favor of some other, but code still tried to access it) 2004-03-08 Adriaan de Groot * Wow, lots of activity by Reinhold. I hope he updates the ChangeLog sometime as well. * Revert the variable timeout, just do a straight 5 second wait, that should just fix it, and save us a lot of trouble too. Anyway, who wants to sync again within 5 seconds of the previous one finishing? It's just as well that the value wasn't saved anywhere anyway. 2004-03-05 Adriaan de Groot * Spent most of the day putting together new tarballs, so I can push KPilot improvements out the door again when needed. 2004-03-02 Adriaan de Groot * Add a variable timeout after the sync, specially for some T3 users. Thanks to Alec Mitchell for pointing that out and providing an initial patch. 2004-02-25 Adriaan de Groot * In the KNotes conduit: Coding style fixes. Cleanup doubled strings. Improved status reporting. Probably dealt with the memo viewer issue. * Imported another patch from David Mott, for drag-n-drop file install. * Added a config option and UI for running conduits during a backup. Default to not, in order to fix bug 7xxxx. 2004-02-21 Adriaan de Groot * At FOSDEM, not much hacking was done, but it was fun and boozy. 2004-02-03 Adriaan de Groot * I see lots of spelling fixes have been introduced in HEAD. Thanks, TLs. * Plans for a photo conduit (Zire71) and a NotePad conduit are forming. pilot-link has the relevant code already, it just needs to be fit into KPilot's form. * Worked on the KNotes conduit some more. Remember to update the local database copy, and non-CopyHHtoPC code needs work. 2004-01-31 Adriaan de Groot * Finished up the KNotes conduit, I think. The copy to PC part was a little over-enthusiastic. 2004-01-25 Adriaan de Groot * Fixed up copyright notices here and there. Dan is listed as copyright holder in lots of files he's never worked on; since copyright cannot be assigned except in writing, I'm going to have to take responsibility for my parts. * Fixed up conduit modes in kpilotTest. * Removed compile warnings in the vcal conduit. * Moved 72342 to top of list, since now I got HHtoPC copy working in kpilotTest I can actually _see_ the bug. It seems to be in PilotMemo. 2004-01-20 Adriaan de Groot * Added experimental A-A-P build system. * Cleanups in conduit config, added stub buttons for wizards. 2004-01-16 Adriaan de Groot * De-tabified ChangeLog again. * Updated version. Hope that \374 makes sense (it's a ΓΌ). * Added explanation for "Actions" page in config. Ditto for "Conduits". Prevent user from collapsing the tree. * Fixup layout for popmail conduit when including it in the config dialog. * Experimental stab at separating the config into separate bits in the new KCM config dialog. 2004-01-02 - 2004-01-11 Reinhold Kainhofer * This was work done in osnabrueck_branch, at the 2004 tdepim meeting and the week afterwards. This issue is one of the feature targets for the tdepim 3.3 release in Q1 2004. * Moved the general setup dialog from a separate dialog to a page of the conduit config dlg. Combined the kpilot setup and conduit config dialog to one dialog. * Implemented the kontact plugin for KPilot (showing status information) * Added three DCOP functions to the daemon for querying status information * Hotsync log is written out to a file (~/.kde/share/apps/kpilot/lastsync.log) * Converted all conduits to TDEConfig XT (mail und kroupware still missing) * Converted the config dialog to a KCM module * KPilot plugin for contact: shows status in summary and makes config available * kpilotDaemon sends a DCOP signal when its settings/state are changed * New DCOP functions in the daemon to query its state and settings * the kontact plugin also detects if the daemon is quit * Use a QSplitter in the config dialog instead of the QHBox layout * implemented the tdeconf_update scripts to move groupless entries to the [General] group * Still missing: o) TDEConfig sync between the three processes working on the kpilot config: kpilot, kpilotDaemon and possibly kontact with the kpilot plugin o) Wizard to setup kpilot correctly for kontact (the defaults should suffice, just in case someone played around and messed them up) 2004-01-02 - 2004-01-04 Adriaan de Groot * This was work done in osnabrueck_branch, at the 2004 tdepim meeting. * Fixed the TODO_I18N -> they're all i18n() now. * Discovered ttypatch, which is da bong. Thanks to Dan Clemmensen for writing it, and Bernhard Reiter for showing it to me. All of a sudden, POSE actually looks usable. 2004-01-02 Adriaan de Groot * Non-functional commits all over; split off osnabrueck_branch. * Naming changes in todo conduit. * Fix sync race in knotes conduit. 2003-12-29 Adriaan de Groot * Reenabled the popmail conduit, but in severely limited form. 2003-12-28 Adriaan de Groot * Committed the knotes stuff, since it does do HH->PC properly. OTOH, I don't think the mode code is right in that conduit either. * Stared at various bugs that I can't reproduce. * Looked into #69987, changed some names in the todo conduit. * Changed the parts of the changelog to real changelog format (dates must be yyyy-mm-dd, with leading zeroes if needed). 2003-12-23 Adriaan de Groot * Added recent hardware reports. If you reported something and I've forgotten it, please send me a gentle reminder. * Added IrDA howto from Stuart, who failed to provide an email address that I can respond to. * I think I got the KNotes conduit working again, but it needs some testing so that change hasn't been committed yet. 2003-12-12 Adriaan de Groot * Reduce warnings in vcalconduit. 2003-12-10 Adriaan de Groot * Fix for #66321 - fill in a default value for the vcal file. 2003-12-05 Adriaan de Groot * Het heerlijk avondje is gekomen. Damn right it is. 2003-12-02 Adriaan de Groot * Removed #if 0'ed code; moved some deprecated code to #if 0; removed use of deprecated stuff. Fixed up includes. 2003-11-23 Adriaan de Groot * Minor string fixups that don't affect TL. 2003-11-22 Reinhold Kainhofer * Fixed the broken conduit config dialog (wasn't able to show config widgets of more than one conduit. If you configured one conduit, and switched to another, its config widget couldn't be added to the stack). * Configure conduits dialog now has an apply button. 2003-10-21 Adriaan de Groot * Updated the website some with lots of new hardware. Thanks to everyone who reported new stuff. 2003-10-10 Adriaan de Groot * Sure, we let the ChangeLog slide, but didn't do much, I don't think, over the summer. Main point is that AAP can pretty much build KPilot now, suck to be auto* and make. 2003-07-30 Reinhold Kainhofer * The addressbook conduit now uses a different algorithm to find the type of address on the PC to sync with. First, if there is a preferred address (no matter if home, work or whatever), this one is synced to the handheld. If no preferred address exists, either home or work (depending on the setting in the conduit config dialog) is used for the sync. If that doesn't exist, either, the other one (work/home) is tried. If that also doesn't exist, and the address is copied to the PC, its type is set to preferred+the setting from the config dialog. This fixes both bugs #50560 (conduit should sync with preferred address) as well as bug #60659 (conduit should use the existing address from the PC, even if the type is not the one chosen in the config dialog). (also backported to BRANCH) * Allow two addressbook entries with the same name and organization, but different phones, addresses etc. Actually, it allows entries which are equal up to at least one entry. This fixes bug #59569. * Fixed bug #60691 where events recurring monthly on a given weekday were shifted by one day. (also backported to BRANCH) * Also, when initializing a LocalCalendar, you are not supposed to give a time zone... * Also, fixed infinite loop glitch by Cornelius. * If the user chose to sync to an iCalendar file instead of the standard (resource) calendar, and he gave an empty or invalid file name, an error message is now written out to inform him/her about the problem. I don't want to ask him for a file name, because one of the guidelines of conduit development is that a sync should be able to run without user intervention. this should probably also be backported, but it introduces two new i18n strings, so it is not possible. Thus the bug will remain in 3.1 branch. * Fixed the toolbar configuration. 2003-07-27 Reinhold Kainhofer * The internal editor action now displays the contents of the conflicting records and lets the user decide which one overrides (Fixes bug #61103). * For this I added a function getTextRepresentation(bool richText) to PilotAppCategory, PilotAddress, PilotMemo, PilotDateEnty and PilotTodoEnty, which returns the contents of the record as a string that can be displayed to the user. Moved that code from the internal viewers to the classes. * If there is no nice-text representation, I now use KHE::KHexEdit to show the raw contents, so the user gets an idea of the conflicting records. 2003-07-26 Adriaan de Groot * Time flies when you're having fun and mucking with other bits of KDE. Worked on meinproc, build fixes, dependencies, etc. 2003-07-26 Reinhold Kainhofer * Changed a few accelerators (duplicates reported by Dr.Klash) * Also show items marked as deleted in the GenericDB viewer. * All conduits now have their own copy of the handheld's database in $TDEHOME/share/apps/kpilot/conduits/UserName/*.pdb. This was needed so that backup runs don't break the conduit's algorithm to detect changed records on the PC. So far, we compared each entry to the corresponding entry in the backup database. It that changed, basically we are screwed. For this new feature I extended the constructur of PilotLocalDatabase to take an additional boolean parameter useConduitDBs. If that is set, the db will be opened in ..../conduits/Username/ * Do not return "Unfiled" or "Nicht abgelegt" as category label if no category is set. Instead return an empty string. * Added isArchived() and makeArchived() methods to PilotAppCategory to set the dlpRecArchived flag. * Changed the way how the DBBackup/username/ and conduits/username/ directories are created (now I'm using TDEStandardDirs::makeDir and TDEStandardDirs::exists). * FirstSync now also means PC->HH or HH->PC directions (which is clear intuitively, as with these direction, nothing that's on the other side should matter at all). * Added eDelete to the sync actions in the SyncAction class 2003-07-15 to 2003-7-26 Reinhold Kainhofer Complete rewrite of the addressbook conduit (for the, umhh, third(?) time). * NEW FEATURE: custom fields can now also be synced with birth date, URL, ICQ, etc. (bug #50871) * Conflict resolution shows the whole conflicting item and all conflicting fields (so far, every conflicting field was shown on its own, bug #59222). The conflict resolution is done completely independent from the addressee object and might so be reused later in other conduits as well. * Separated the mechanism to detect changes from the mechanism to sync/merge addressees. This makes the whole thing a lot easier to understand and maintain, and there are far less cases you have to consider. * the conduit now obeys the global conflict resolution (ask, PC overrides, HH overrides, last sync overrides, duplicate) and sync direction (fast, full, only PC->HH, only HH->PC) settings. Bug #59220. * The "only HH->PC" and "only PC->HH" sync directions first copy all existing entries to the receiving end, and only then remove all other entries from there. This avoids data loss if the connection breaks while such a special sync is running. * Added a crash handler to clean up the addressbook if the conduit crashes. 2003-07-11 Reinhold Kainhofer * Records in the PilotLocalDatabase with ID 0 (i.e. new records added by KPilot's internal editors) will always be treated as modified records and found by readNextModifiedRecord, even if they don't have the dirty flag set. This ensures that all new records from KPilot will be added to the handheld * Finished the internal todo editor: Entries can be maked completed and edited directly in the check list view. Moved the editor dialog to a designer ui file instead of a manually created layout * Finished the sync action that copies the changes done in the internal editors of KPilot to the handheld. So, finally, the internal viewers/editors of KPilot are working again, unlike the last few years, where they were in a terribly broken state. 2003-06-01 to 2003-7-10 Reinhold Kainhofer * I was busy with a lot of stuff from KPilot, none of which is actually in a state where I can commit it. In particular, I'm working on -) Custom field sync of the addressbook conduit -) Make the conflict resolution of the abook conduit more intuitive (ask just once for each conflicting address) -) Finish up the todo editor -) Make the generic DB viewer an editor (more or less finished, but the KHexEdit widget is not yet publically available, so I can't commit that part either) -) Implement the InternalEditorAction which syncs the changes done in the internal editors/viewers to the handheld KPilot Developer's notes for July 9th ===================================== 2003-7-9 Adriaan de Groot * Ditched spurious code in KNotes conduit config. Updated copyrights, still assigned to Dan. Updated the notes interface stubs. 2003-7-7 Adriaan de Groot * Added a conduit description to PalmDOC. Well, fixed the "Conduit" vs. "Comment" typo in the .desktop file. 2003-7-6 Adriaan de Groot * Made the bugreport and question and help links in the about pages clickable through KActiveLabel. Made the credits text scrollable with a QTextEdit. * Weird redraw bugs reappear in the conduit config dialog, fixed again. * Added sorryVersionOutdated() to KPilotConfig to notify user that the configs are old, and telling what's changed. Used in kpilot and the daemon. Includes cleanup. Use getDebugLevel() properly. 2003-7-5 Adriaan de Groot * Upped the config version number to 440. * Worked on the docs (really!), so the HEAD docs now reflect _some_ of the reality of KPilot 4.4.0. Noted lots of inconsistencies. Put in lots of TODO's, and the whole thing needs going over. * Using the trademark HotSync in the GUI might not be a good idea. Removed where I could, added a trademark reference in the about pages. 2003-7-5 Adriaan de Groot * Renamed all conduit plugins from libconduit (and variants) to conduit_, so that they're easier to identify in $TDEDIR/lib/trinity. Of course, this doesn't work right. Feh. * Removed listCat again. * Implemented a notion of "internal conduit", so that we can move the "install files" and "kroupware" stuff to the conduit config dialog and out of the general stuff, where it looks weird. 2003-7-4 Adriaan de Groot * Removed the words "KPilot", "KDE" and "Conduit" from all the conduit names. * Removed double logging in NULL conduit, added message for explicit fail. Use the generic config dialog implementation. I see now that the NULL conduit isn't built or installed anymore. Fixed its .desktop comment. * Disabled the expenses and popmail conduit from compiling. * Made new-style config for the vcal conduit. Made new-style config for the todo conduit. Stripped out lots of extra #includes. Stripped out extra Q_OBJECT macros. Reduced space in widget some. Fixed void return 0; Fixed improper AboutData in todo conduit. * New-style for abbrowser. Minor == vs = mixup. * Shrunk margin for kpilot config dialog. Use the available charsets from KDE instead of our own list. Added a quit-after-sync option. 2003-6-29 Adriaan de Groot * Added some code validation support to plugin.h * Messed about with popmail's config. What was the firewall stuff for? Created new-style configs, didn't complete the load/save code, and then sortof gave up because is there really any point to doing this conduit without switching to the SMTP ioslave? And using identities then? 2003-6-26 Adriaan de Groot * Removed stupid comment in popmail/Makefile.am 2003-6-25 Adriaan de Groot * Be consistent about naming the sysinfo conduit "System Information" in user-visible strings. * Remove "conduit" from the name of the Palm DOC conduit, and add a new-style config panel to it. Made it resize properly. * Note that ConduitConfigBase::load() and its overrides should set fModified to false. 2003-6-22 Adriaan de Groot * Turn off NO_CAST_ASCII when doing DEBUG_CERR, because ostream is lacking an operator << for QString. (Nicer is probably to add such an operator, but hey.) * Removed uselessly virtual conduitName() function from conduit classes. No-one was overriding it anyway. * The vcal and abbrowser conduits shouldn't be compiled if you're building KPilot HEAD on older systems. 2003-6-21 Adriaan de Groot * Fixed up the layout of the sysinfo conduit. * Documented ConduitConfigBase::isModified() and made it virtual. * Fixed up the sysinfo conduit and saving modified entries. * Moved the --debug argument to all apps individually. 2003-6-20 Adriaan de Groot * Updated the hardware lists on the website. * Updated some "What's This?" texts. * Removed evil static QStrings in kpilotConfigDialog.cc. * Discovered that the "start at login" functionality has been broken forever. * Added a workaround for KTimeWidget not present in KDE 3.1.x. 2003-6-20 Reinhold Kainhofer * Implemented the dialog to change the database flags and the dates (DBInfo struct) in the internal generic DB viewer. PilotLocalDatabase got a new method setDBInfo for this. * Implemented creating, editing and deleting records in the generic DB editor. * Added the CHexViewWidget from khexedit to the kpilot/kpilot/ directory. There are still several open issues with it (i.e. how do I set the data at all???) 2003-6-19 Reinhold Kainhofer * Implemented the list of records in the generic DB viewer. To be able to sort the records by their index, I had to write my own compare method of the QListViewItem, which compares the numerical representation of the column entries. For large DBs (>300 records) this is way too slow (QString::toULong for each comparison, increasing with n*n), so I had to implement some caching. Now even large databases are sorted very fast. 2003-6-16 Reinhold Kainhofer * First layout of the internal calendar viewer/editor. The KDatePicker poses a big problem to me as it swallows all toolbar buttons. * Implemented a InternalEditorAction to sync changes done to the databases in the internal viewers. Every PilotComponent that changes a database needs to mark it as dirty (e.g. markDBDirt("AddressDB")) so the Action knows which databases need to be considered. 2003-6-15 Reinhold Kainhofer * Implemented a first layout of the generic database viewer. To view the records, I'd need a hex editor, which is not available in KDE, yet. I tried using the widget that khexedit uses, but somehow I can't get it to work :-(( KPilot Developer's notes for June 15th, 2003 ============================================ 2003-6-15 Adriaan de Groot * Yay, father's day. Which includes me. Mira drew me a wonderful card. * Fixed some TL problems in debug output, and added documentation. 2003-6-14 Adriaan de Groot * Fixed the conduit config dialog's repaint and behavior problems by ditching the .ui file and implementing it by hand again. I'll look into a switch back to .ui later. 2003-6-12 Reinhold Kainhofer * Tracked down why the handheld crashes with Invalid UniqueID error message (bugs #59313 and #51216). RecordIDs are supposed to be 3 bytes, and the handheld will crash if they are longer. For some reason, several entries in the calendar or the addressbook were assigned longer Record IDs, so I added a check for invalid values before sending them to the handheld. This fixes the symptoms (i.e. these crashes won't appear in the future again, and new valid ids will be assigned), but there is still another bug that assigned the wrong values in the first place... 2003-6-9 Reinhold Kainhofer * Fixed crash from bug #59315. I used the value of a char as a char*, in the code for extension cards in the sysinfo conduit. pilot-link doesn't detect my Clie's memory stick as extension card so this code was never executed on my machine, and I didn't detect the bug myself. 2003-6-1 Reinhold Kainhofer * Fixed several (possible and really occurring) null pointer crashes * Submited most of the items in our TODO list as bugs or wishes on bugs.kde.org 2003-5-31 Reinhold Kainhofer * Restructured the setup dialog of KPilot. Several per-conduit settings were moved to global settings. The conduits now have isFullSync(), isFirstSync(), getSyncDirection(), and getConflictResolution() members for these settings. I think I fixed all conduits to use these new settings and didn't miss anything. * The Backup works again (fast sync doesn't do a backup, hot sync does conduits and a fast backup, full sync does a full backup where the modified flags are ignored). Also added a fast backup where only modified records are retrieved. 2003-6-1 Adriaan de Groot * pilotComponent.cc Another fix for 52138 - I'd missed the category drop-down box. * Woo. After months of wrestling, I actually managed to run KPilotTest and list the contents of my m500. Sometimes, there is something to be said for Linux and a working USB stack. This means I have limited testing hardware available again. * Minor fixups to make HEAD compile with 3.1.x again. 2003-5-31 Adriaan de Groot * Updated my build environment to HEAD. This will leave some people in the dust, for sure, since 4.4.0 will thus have an address conduit that requires HEAD, not 3.1.x. Perhaps we can ship two tarballs, but that's going to start to be messy again. * Talked to lioux about conduits and categories on IRC. It seems that PC->Palm syncs usually respect categories and such, but Palm->PC doesn't, among other little tidbits. He'll file bug reports. KPilot Developer's notes for May 30th, 2003 =========================================== 2003-5-30 Adriaan de Groot * Spent this week at conferences (Mira at 8 weeks was the youngest attendee of the EEF School on Formal Methods, though I doubt she'll remember how to do protocol verification in PVS). 2003-5-19 Reinhold Kainhofer * This weekend I wrote this new conduit for KPilot, called sysinfoconduit. It writes all important Palm system information to a text or html file. For an example, see http://reinhold.kainhofer.com/Linux/KPilot/KPilotSysInfo.html. The output is completely customizable via templates. Currently, txt and html templates are available, but the user can provide his/her own template in the conduit configuration dialog. The current html template uses css for the markup, and passes the w3c html validator without warnings. Hopefully, the debug output section will help us kpilot developers track down problems easier (the users can send us the output of this conduit, and we can let it write out all important stuff we need/want to see). 2003-5-11 Adriaan de Groot * kpilotDCOP.h Changed enum values so that you can distinguish between call failed and normal operation. * conduitConfigDialog.cc When closing config dialog, release last selected conduit. 2003-5-9 Adriaan de Groot * Fixed up some config issues in the NULL conduit. * Added conduitName() to conduit config things and their actions, to provide a user-readable name for the conduit. 2003-5-5 Adriaan de Groot * plugin.{h,cc} Added a maybeSave() function for the new conduit config style. Removed some unused variables. * conduitConfigDialog.{h,cc} Using maybeSave() to save or cancel selection changes. 2003-5-3 Adriaan de Groot * Spent lots of time panicing my system and causing fatal exceptions on my Pilot by playing with pilot-link 0.11.7 and FreeBSD's USB stack. * kpilotlink.cc Suppress printing the "accidentally in acceptDevice" more than once. Try to escape from the infinite socketnotifier loop. 2003-5-2 Adriaan de Groot * Aiming for bi-weekly notes this month again. * Looks like I reverted the PRETTY_FUNCTION printing. * I'm working from an everything-HEAD-except vcal and abbrowser checkout, because the new resources framework breaks everything. * Next KPilot tarballs will be 4.4.0 (HEAD) release. KPilot Developer's notes for April 30th, 2003 ============================================= 2003-4-25 Adriaan de Groot * Updated resizing action in the conduit config dialog. * Added a ConduitConfigBase to the knotes conduit. * Changed a bunch of Name[] entries for the time conduit. We need shorter names; most of them are horribly redundant. * Noticed that the conduit checklist items don't always get painted right. Added a workaround. 2003-4-24 Adriaan de Groot * More work on the conduit configuration stuff. * Make FUNCTIONSETUP print PRETTY_FUNCTION instead of just FUNCTION. * Added a ConduitConfigBase object to the time conduit. 2003-4-22 Reinhold Kainhofer * Cleanup of several cout and other debug messages * In the addressbook and todo conduits, after the sync the AppInfoBlock is written back to the databases so that adding categories to the database finally works. 2003-4-21 Adriaan de Groot * Changed the description for the KPilot NULL conduit to just "NULL", since both "KPilot" and "conduit" are redundant in this context. * Messed around a little with the types of plugin code, created a class ConduitConfigBase which is supposed to supplant the current config widget stuff. 2003-4-21 Reinhold Kainhofer * Implemented different ways to convert the bookmarks in the doc conduit when doing Handheld->PC sync. * Some tab order fixes in several conduit setup dialogs. * Improved the question when the handheld and the KPilot user names don't match. 2003-4-20 Adriaan de Groot * Added the sources for a generic DB viewer and a datebook viewer. These don't show up anywhere yet though. The datebook viewer has no functionality yet. * kpilot.cc Minor change to detect non-functioning daemon better. * Restored the tooltip code to the conduit config dialog. Removed the "description" column again. * uiDialog.{h,cc} Moved the addAboutPage() code to a static function so that it can be reused elsewhere. * plugin.{h,cc} Added a new base class ConduitConfigBase for deriving the configuration widgets for conduits from. This will make them more generically pluggable. 2003-4-19 Reinhold Kainhofer * Fixed the categories sync in both the addressbook and the todo conduits. 2003-4-18 Adriaan de Groot * Laurent Montel did some compile fixes for restrictive (NO_ASCII_ ...) compile environments. And I fixed them to match the coding guide. * Make file installer emit a [] message like the conduits do, to give the "No files to install" message context. Tell the user how many files will be installed. * Tell the user if the daemon can't be started. Tell the user what charset is selected. 2003-4-17 Adriaan de Groot * Finished moving the conduit config to checklist items. Worked out a sensible compromise with the command buttons. The conduit descriptions (comment lines in the .desktop files) need work. 2003-4-16 Reinhold Kainhofer * Tried to add a logMessagePart slot which would append some words to the last line of the sync log (but would not start a new paragraph, and more text could be added to the last paragraph). Realized that this is not possible in a QTextEdit with LogText, and using RichText is too buggy to be useful. However, I found a way to get rid of the pseudo- progressbar in the libmal output, so this is not an issue any longer. 2003-4-16 Adriaan de Groot * Moved conduit config to a list of QCheckListItems, finally. This was easier than I thought. Took a bit of time to polish, though. This change introduces a new class ConduitConfigWidget which could be placed in a tab elsewhere if needed. 2003-4-15 Reinhold Kainhofer * Finally fixed the configure.in.in check for libmal in the malconduit * calendar conduit had wrong RadioButton IDs, so the Resource and LocalCalendar settings were messed upt 2003-4-14 Adriaan de Groot * Made some reasonable mock-ups, see my kpilot page, mulled over the non-editing by the viewers. I'm now working in HEAD only. * kpilot.{h,cc} Fixed up backwards compatibility. 2003-4-12 Adriaan de Groot * Mucking about with KPilot's UI again. Trying to remove dialogs and to make the viewers just viewers. 2003-4-1 Adriaan de Groot * My daughter, Mira Annelie Engel, was born this evening and is a bouncing healthy girl. But she's going to put a crimp in KPilot development, that's for sure. KPilot Developer's notes for March 26th, 2003 ============================================= 2003-3-26 Adriaan de Groot * pilotLocalDatabase.cc [BOTH] Qt 3.0 compatibility. * More merging: lib/ just spacing fixes. * kpilot/ In HEAD, muck about with the toggle actions that were removed from kpilot.cc. This stuff is supposed to build in all KDE 3.x. * I've been thinking about _where_ to hack next. HEAD is evolving further under Reinhold's influence, and I feel pretty much stymied in BRANCH because I can't touch strings and the like. However, I'm still running KDE 3.1 and dedicated to KDE 3.0 compatibility as well. Since the things I want to change are in lib/ and kpilot/ and affect strings, I'm going to pick up those from HEAD, but stick to BRANCH conduits for the next while. Then I can catch up with HEAD in the conduits one by one. So initial KPilot 4.4.x tarballs will be from a mix of CVS branches. We might consider doing the conduit releases separately from KPilot itself - more 3rd party-ish - since the conduits change far more drastically than KPilot itself. Initial plans for 4.4.0: disable editing in the viewers ; move the configuration things into the JanusWidget, and out of separate dialogs. 2003-3-24 Reinhold Kainhofer * Adapted the layout of the addressbook conduit's setup dialog to resemble the one from the calendar/todo conduit * Addressbook conduit: Implemented the option to sync with an arbitrary vcard file instead of only the standard addressbook. This actually involved quite a lot of dealing with resources, factories etc., so I'm still looking for an easier way to obtain the addressbook from a single local vcard file. 2003-3-23 Reinhold Kainhofer * Lot of work on the docconduit. Finished the KPalmDOC application. It converts text files to .pdb files that can be viewed as ebooks on the handheld. The user can either convert single text files to or from PalmDOC .pdb files, or choose a directory, where all *.txt or *.pdb files will be converted to another directory. I created some icons by just putting the text mime-type icon behind the kpilot icon, so the icons don't look too well. All artists are welcome to improve them. * Tried to implement a configure option for libmal, and use autoconf's built-in functionality to detect libmal. Doesn't work yet, so I haven't committed it yet. 2003-3-23 Adriaan de Groot * More merging .. conduits today: * null/ There's a single string change, "Failure" -> "failure". * expense/ knotes/ Nothing changed - except the Makefile.am, which breaks things in HEAD. * malconduit/ "" -> QString() for QString cleanness. Some authors should have been credits. There's still a spelling fix string change in HEAD. Lots of spacing updates. 2003-3-21 Adriaan de Groot * Heh, noone ever noticed the "Edit Toolbars" menu item called the "Edit Keyboard Shortcuts" dialog. 2003-3-20 Adriaan de Groot * Merging between BRANCH and HEAD. * options.h [BRANCH] Upped the version number again. * lib/ [BOTH] Merged documentation, fixed minor bug in plugin.cc in HEAD. * kpilot/ [BOTH] Merged stuff. * pilotDaemon.{h,cc} [HEAD] The daemon has extra DCOP features and kroupware. * kpilot.h [HEAD] Extra in-use code and Ben's removal of toolbars (supported by standards in KDE 3.2 - this needs backporting and #ifdeffing). * conduitConfigDialog.cc [HEAD] Has all the setup stuff for the checkbox list conversion (a GJJ) but #if 0'ed out. * kpilotConfig{Dialog,}.{h,cc} [HEAD] Adds a GUI for the pilot encoding. * kpilotDCOP.h [HEAD] Extra configure methods from David. * listCat.h [BOTH] One-up the spelling mafia. 2003-3-17 Adriaan de Groot * [fileInstallWidget.cc] Applied file-installer multiselect patch from Ulrik Mikaelsson. * [pilotDaemon.cc] Applied DCOP interface additions from David Mott. 2003-3-15 Adriaan de Groot * The popmail conduit runs in backup mode during syncs. So do all the other conduits. What's going on? Thanks to Tobia Baier for spotting this. Worse still, the bug comes from the difference between & and &&. Fixed. * syncStack.cc [BOTH] Fixed --backup bug. * David Mott is back with more patches, but he's got competition from Ulrik Mikaelsson, who's also doing GJJs. KPilot Developer's notes for March 12th, 2003 ============================================= 2003-3-12 Adriaan de Groot * Lots of administrivia changes, like the FSF address. * Really ought to merge the copyright changes into BRANCH, since they're still being released with weird copyright assignments. * vcal conduit in local-test mode will write out an .ics. 2003-3-4 Adriaan de Groot * Welcome back to David Mott, author of several patches already and ready to dive into the code again for GJJs. Happy distraction, dude. * [vcal-conduitbase.cc] Checked against wrong TDE_VERSION. [BRANCH] * Various merging from BRANCH to HEAD. Layout fixups here and there. * Test mode in the vcal conduit by default uses local databases from /tmp. 2003-3-3 Adriaan de Groot * pilotDatabase.h [BRANCH] Merged additional parameters to findDatabase from HEAD. Merged every other change in lib/ from BRANCH to HEAD. * pilotRecord.{h,cc} [BRANCH] Added instrumentation for alloc/delete count. 2003-3-2 Adriaan de Groot * Continued instrumentation of the vcal conduit. 2003-3-2 Reinhold Kainhofer * the DOC conduit now also finds the correct sync direction if the user only wants PC->PDA or only PDA->PC sync. Also, if a text was deleted on one side, it is also deleted on the other end * The resolution dialog of the DOC conduit now uses a QScrollView instead of a QTable for the list of conflicting texts * In the DOC conduit, regular expressions as bookmark names work now. E.g. a bookmark search string of "return (\S+);" and a bookmark name of "RetVal: $1" or "RetVal: \1" replaces all $i or \i by the i-th subexpression of the match. * DOC databases are now also kept locally if the user set this option (installDatabases has the addidtional argument not to delete the files) * The calendar and todo conduits now use the standard calendar by default. The user can also specify a single file to sync with instead of the whole calendar. * The calendar and todo conduits use identical setup dialogs, so there is no reason for code duplication. Removed the setup dialog of the todo conduit and derived it from the calendar conduit setup dialog. * Updated the copyright lines in the source files as well as in the about tabs of kpilot and the conduits. * Since we have the calendar resource framework, the calendarr conduit can run even while korganizer has the calendar open without causing calendar corruption. So I removed the check for running korganizer and alarm daemon 2003-2-28 Adriaan de Groot * Discovered that the changes from 2003-1-31 to syncAction.{h,cc} had disappeared in some of my periodic CVS screwups. Re-did them. * vcal-conduitbase.{h,cc} [BRANCH] Added more instruments for running test mode. 2003-2-27 Adriaan de Groot * Merged Reinhold's print-conduit-id patch from HEAD. * Continued updating the documentation. Ripped out the revision history, Lauri says I'm the only developer in the history of KDE to actually maintain it in the docs. * Updated version to 4.3.9 now that 4.3.8 is out. * Started work on a real test mode for the vcal conduit. * syncStack.cc [BRANCH] Set conduit action name to the conduit's name. KPilot Developer's notes for February 26th, 2003 ================================================ 2003-2-26 Adriaan de Groot * Finally solved KDE 3.0 build issues, incorporated minor fixes, updated build scripts and RELEASED KPILOT 4.3.8. Get it from the website, possibly in a few hours after it updates or from my personal backup copy (replace pilone by adridg in the URL). KPilot Developer's notes for February 14th, 2003 ================================================ 2003-2-14 Adriaan de Groot * Happy Valentine's Day, eh. Remember guys, today your girlfriend _is_ more important than hacking. Which reminds me .. 2003-2-13 Adriaan de Groot * kpilotLink.{h,cc} [BRANCH] Added a messagesType flag to distinguish error messages from normal once-only messages in shouldPrint(). Print out device name before opening in open(). 2003-2-12 Adriaan de Groot * Applied David Mott's DCOP patches to HEAD. Also applied his RMB patches to HEAD. This takes care of some GJJs. * memoWidget.cc [BOTH] Replaced the label "Memos:" beside the category combobox by "Category:" which is also used by the address widget. Kept the old string around for safekeeping. * Dealing with non-latin1 Pilots again, now in Russian. And it _seems_ to work. I think last week's changes were sufficiently general. Added in the rest of the Pilot languages as well, from the JPilot source. 2003-2-10 Adriaan de Groot * popmail-conduit.cc [HEAD] Did some actual TODO_I18N work, removed printfs from the message construction in the conduit. Added a GJJ for it. * pilotDaemon.cc has lots of Kroupware additions in HEAD and also changes "unix" -> "KDE" in the about box. * conduitConfigDialog.cc has lots of new code for changing the conduit list to a list of checkboxes. * kpilotConfigDialog_base has been edited in HEAD for new Kroupware options. Same with kpilotConfigDialog.cc, kpilotConfig.{h,cc}. * conduitSetup.cc may be deprecated, but there was a minor difference between files. HEAD <- BRANCH (ie. HEAD gets BRANCH version). * hotSync.cc variable names changed, BRANCH <- HEAD. * interactiveSync.cc typos and latin1() fixes. BRANCH <-> HEAD. * logWidgetDCOP.h still had Log: tag in it,. removed [HEAD,BRANCH] * abbrowser conduit has new custom field code. Did BRANCH <- HEAD for the includes, though, just to normalize 'em. But, to quote TMBG, "Who keeps moving my #includes?" The only unmerged stuff that _could_ be merged is minor code beautification in @@ -1496,22 +1563,26 @@ * Should re-add a Pilot*Database constructor that takes a const char * for those places that already have a dbName. * vcalconduit has startOffset() support for alarms. 2003-2-9 Adriaan de Groot (merge status) * Merging. I hate merging. We _definitely_ need a better process for this, like merging every fix into HEAD as soon as it's done. That would save a lot of effort, I think. And I'm going to check out KPilot with -kk for merging efforts from now on. Here's the list of features I found in HEAD that are not in BRANCH: - KPilotDeviceLink::installFiles() extra arguments. - KPilotDeviceLink::findDatabase() extra arguments. - PilotDatabase::createDatabase() and deleteDatabase() added. - Pilot*Database::readNextModifiedRec() extra arguments. - Pilot*Database::deleteRecord() added. - PilotLocalDatabase::PilotLocalDatabase extra arguments. - FileInstallWidget lots of changes. FileInstaller as well. [MERGED] * Managed to revert, prevert, and advert syncStack.{h,cc} all in one go. I think I have it back to normal now. KPilot Developer's notes for February 7th, 2003 =============================================== * KPilot 4.3.7 is released. Tarballs on the website tonight. * Need to backport the changes from 2002-11-10 to BRANCH. * Grep for and destroy latin1() calls in code. These are now in the code to keep KPilot working under QT_NO_ASCII_CAST conditions, but should all be replaced by the proper functions instead - either QFile::encodeName() or by updating other functions to take QStrings instead of const char *, and using the Pilot codec where appropriate. * Reinhold's on vacation for a little while. 2003-2-7 Adriaan de Groot * Updated the website some. * options.h [BRANCH] Version number now 4.3.7. 2003-2-6 Adriaan de Groot * Did a big chunk of merging from BRANCH to HEAD. Discovered two things that didn't work well: - Changes in the abbrowser conduit wrt. getCustomField() - Memo widget optimizations I hope I got them right. I'm going back to work in BRANCH. * Constant strings in the source are now (almost all) marked with CSL1() for Constant String Latin 1. This reduces the number of hits for [lL]atin1. The macro uses a syntactic trick to make sure it's only applied to constant strings. 2003-2-5 Adriaan de Groot * Almost everywhere [BRANCH] Search and destroyed latin1(). * options.h [BRANCH] Handle properly. Um, sort of. The dag-blabbed file is obsolete in KDE 3.2, required in 3.1, and incomplete in 3.0. Ignore it instead. Ignore all the fancy Q* operator < to the kpilotrc file in the top part (ie. after DeviceName). 2003-2-1 Adriaan de Groot * Some time spent tracking down double activations of slowShowMemo(). * memoWidget.{h,cc} [BRANCH] Removed double initialization. Removed heavy-handed initialize() call after memo deletion. Found potential data-loss bug with deleting memos after unselecting one. Decided that extended select in this case is just _evil_. I can't decide which memo to show after deselections, and there's several other problems as well related to slotUpdateButtons(). Reverted the multiple-select. * options.h [BRANCH] Added the TODO_I18N macro to BRANCH as well, where it's more important. * kpilotlink.cc [BRANCH] Reordered ReadSysInfo and ReadUserInfo to copy JPilot's setup, maybe that will help with password issues. * kpilot.cc [BRANCH] Cleaned up deprecated headers. * conduitConfigDialog.cc [BRANCH] Preparing to repair the clumsy conduit selection and activation KPilot Developer's notes for January 30th, 2003 =============================================== * Ugh. Looked at jpilot source. Now I remember why doing C often seemed a little unproductive. But it does give some very useful information: We need a combo box to choose the Pilot's encoding. We can use the list from JPilot. Next, we need to make _all_ the QString::fromLatin1() and QString::latin1() -- also all the implicit ones -- that refer to pilot records use the right codec. This will require some possibly major work on the database classes. * The logging is still lousy for many conduits. I ran the notes and address conduits, and the log was less than enlightening. * We need to sync _all_ databases, not just the conduited ones. * Encoding and decoding non-latin1 Pilots is a priority. 2003-2-1 Adriaan de Groot * memoWidget.{h,cc} [BRANCH] Applied patch from David Mott for the GJJ "Lose QMLE". Good job! ... Ugh, and it breaks on KDE 3.0. Hacked. * pilotDatabase.h [BRANCH] Missing #include fixed. How this ever compiled is a mystery to me. * pilotRecord.{h,cc} [BRANCH] Inlined trivial functions. * pilotRecord.{h,cc} pilotAppCategory.h [BRANCH] Start of codec support. * Put together some scripts to do more automated building and testing in KDE 3.1 and 3.0 environments. This makes tarball delivery a _lot_ easier. 2003-1-31 Adriaan de Groot * Let's do the time-warp again! * syncAction.{h,cc} [HEAD] Added a delayDone() function for use from exec() to avoid possible stack growth as follows: conduitExec() exec() syncDone() SyncStack::conduitDone() delete syncAction // The one whose exec() we're still in! conduitExec() // Another conduit! ... return true; I'm not sure I trust all the pointers to still be OK when this happens. Using delayDone() makes sure that exec() and conduitExec() return first and we get back to the main event loop. * syncStack.{h,cc} [HEAD] Using a stack instead of a queue has some comp-sci chique, but little practical value. Break up the API to make it more easy to use elsewhere and practical to insert extra items (like Kroupware) into the sync order. 2003-1-30 Adriaan de Groot * Removing local8bit() calls in the code. They're not wanted. * Marked conduitSetup.{h,cc} as deprecated and removed from build. * Looked into bug #52138 again, and I just can't see it. My Pilot syncs fine with KAddressbook and KNotes, both ways, with names and memos with any latin1 character. [Update: aha! The bug is about Japanese language Sony Clie's. So it turns out there are Pilots that don't use latin1 at all. I'll take a look at how jpilot deals with them.] * I'd like to change the About box tag-line for KPilot to: KPilot - HotSync software for KDE for a variety of consistency reasons. This can only happen in HEAD, though. * Reversed some confusing accidental commits by me in the debugging department for the daemon. 2003-1-26 Adriaan de Groot * Ugh. Still sick with the flu. Hacking just a little, though. The Kroupware stuff in HEAD needs to be moved. Ugh, it's ugly. It needs to become a conduit of its own, but it's hard to tell just what it's doing. 2003-1-24 Adriaan de Groot * Received a patch from David Mott that removes lots of the Log: tags from the KPilot source (mostly in kpilot/). Finished the job too, committed. 2003-1-20 Adriaan de Groot * For the next little while, I'll be working in _BRANCH fixing bugs as best I can. These will end up in KDE 3.1.x releases. Reinhold will be working in HEAD, adding neat features. BRANCH will be merged to HEAD regularly so that no bug-fixes are lost in HEAD. * Reduced debugging output clutter in PilotAddress by changing to FUNCTIONSETUPL(). Assigned Levels are: 4=PilotAddress. 2003-1-18 Reinhold Kainhofer * Removed several Log: ... tags from the conduits I maintain * started implementing the custom fields sync of the addressbook conduit. I still have problems converting a string to a QDate using a custom format * Cleanup of includes in my conduits. * Some more work on the DOCConduit. There are still several open issues, but the basic functionality works just fine! KPilot Developer's notes for January 17th, 2003 =============================================== 2003-1-15 Adriaan de Groot * Back to BSD. Committed lots of header file changes. Did some fixing for strlcpy() in 3_0_BRANCH for folks with KDE < 3.0.5a. 2003-1-11 Adriaan de Groot * Weirdly, I can list the databases on the pilot just fine with kpilotTest, but at the end of the sync the pilot complains about the password. * Similarly, using the daemon I can back up the pilot just fine (pilot-link 0.11.3, all this) and at the end the pilot complains. The data is backed up just fine, though. * Wow, USB connections are _fast_. * Weirdness comes in threes: after a while the debug output stops printing. Even when it's sent to cerr directly. Hmm .. has something to do with printing NULL QStrings. * [hotSync.cc] Every "Backing up:" message was logged twice. * [logWidget.cc] Added more version information. Discovered that QTextView is obsolete. Fixed log tailing problem. #ifdeffed it to Qt 3.1 and later. 2003-1-10 Adriaan de Groot * [kpilot/interactivesync.cc] Some strlcpy problems when compiling HEAD (or BRANCH) KPilot on a KDE 3.0 system. Since we don't maintain branches, backwards compatibility in HEAD is essential. Added #if TDE_VERSION < 310. * [lib/kpilotlink.cc] Might have found the source of the KPilot-hangs-with-USB problems. There's a note in the QSocketNotifier docs saying not to disable read-notifiers. I did anyway, and it never caused problems before. Added some workaround crud. * I'm currently building tdelibs and base and pim on a Linux box, something I haven't done in over a year. This will allow me access to a USB stack that can actually handle the m500, so I can do some more testing. Primary platform remains FreeBSD, though, for all-the-other-KDE-problems- on-nonlinux. * Made a round of removing , since it's already in options.h. Needed a "using namespace std;" in options to get stuff to work. 2003-1-9 Adriaan de Groot * Made new tarballs of the build system (for 3.0 and 3.1) and the sources. * Decision: I'm going to do bugfixes in _BRANCH. Reinhold can do bugfixes and new conduits in HEAD, and I'll merge from BRANCH to HEAD fairly regularly. I think that's the best balance between getting stuff out the door and sticking to the KDE release schedule. * Decision: Remove all the Log: tags from the source files. The Id: tags stay in, for debugging output. 2003-1-1 Adriaan de Groot * Ho ho ho. Happy new year. KPilot Developer's notes for December 30th, 2002 ================================================ 2002-12-30 Reinhold Kainhofer * Some more work on the docconduit. I'm currently restructuring again, so right now it doesn't work at all, but should be finished really soon now. * Add a method PilotDatabase::deleteDatabase() to delete the database. * Add a warning to the vcal conduit's setup dialog to clear any misconception about conflict resolution. Also changed "Pilot" to "handheld" at several places. 2002-12-15 Reinhold Kainhofer * Added a parameter "bool useDefaultPath=false" to PilotLocalDatabase::PilotLocalDatabase to prevent resetting the dbPathName to the default path (kpilot/DBBackup/UserName) 2002-12-13 Reinhold Kainhofer * Initial import of the docconduit, which syncs text files on the desktop with PalmDOC databases (kind of e-book format for the palm) on the handheld for use with AportisDoc, TealReader, QED, etc. * VCalConduit: yearly recurrence now works correctly (had wrong yearly recurrence type rYearlyDay instead of rYearlyMonth) * Addressbook conduit: _equal also compares the categories to check if an item was changed * Added the new methods createDatabase(..) and deleteRecord(..) to the PilotDatabase classes. createDatabase creates a new database with given type and creator, and deleteRecord deletes either a single record or all records in the whole database * PilotDatabse::readNextModifiedRec has a new optional argument of type int* which receives the index of the returned record. * PilotDatabase::findDatabase has optional arguments int index=0, long type=0, long creator=0 KPilot Developer's notes for november 10th, 2002 ================================================ 2002-11-10 Adriaan de Groot * Is kate acting up? I would have sworn I did some ChangeLog editing last night. Anyway: * Expanded the DCOP interface so the daemon can signal KPilot when the HotSync is done. This causes postHotSync things to be called and unfreezes the FileInstaller. * Adjusted the progress bar during installing files. * Daemon->Quit now still waits til lthe end of the sync. * Display some form of progress during a restore. Reduce verbosity a little. 2002-11-08 Adriaan de Groot * Clear the file installer list after a HotSync. Disable dropping files on the installer during a Sync. * When installing files, the "done" message was printed at the beginning of the last file to be installed. Fixed. 2002-11-07 Adriaan de Groot * only call slotTextChanged() in the MemoWidget when switching memos, and only if the memo is changed. This saves rewriting the database every time you hit a key in the memo edit box. 2002-11-06 Adriaan de Groot * Fix the KNotes conduit's name. 2002-11-05 Adriaan de Groot * Patched up the website again a bit. * Mucking about in libkcal to make it useful for KPilot. * Lots of includes changed in the vcalconduit to reflect that. 2002-11-02 Adriaan de Groot * Regarding the "Hidden config feature", it's in the group for the popmail conduit, called "outboxFolder". Set it to the i18n'ed name of KMail's outbox. Damn KMail's DCOP interface / config. This should make it possible to send mail with KMail again. * Finally got a separate build tree of KPilot working. Can distribute sources again, now, assuming SLAC can suffer the bandwidth penalty. * Most of libkcal's header files aren't installed. Why? Is it really intended to be totally internal to the tdepim module in KDE's CVS? 2002-10-31 Adriaan de Groot * Happy Hallowe'en, eh. 2002-10-27 Adriaan de Groot * Don't you hate code / feature freezes? It always stops KPilot development in it's tracks, if only because fixing the bug related to KMail's outbox requires a new string. Bitch bitch, moan moan. * Added new TODO_I18N macro to flag I18N todos. The popmail conduit is a big candidate for fixups. * Thought of a new starter project: moving the popmail conduit config dialog to Qt Designer. Another one would be to fixup the capitalization of popmail in that conduit. * Added extra undocumented configuration option to the popmail conduit in an effort to save KMail sending capability. KPilot Developer's notes for september 19th, 2002 ================================================= 2002-09-13 Reinhold Kainhofer * Finally, the addressbook conduit is in a shape where I can release it with beta 2. There are still some issues (e.g. duplication as conflict resolution is messed up on the next sync. Also, entries with newlines in an address field are always determined as changed, so the fast sync is not so fast with them.), but they can be targeted later on. 2002-09-10 Adriaan de Groot * Problems related to immediate "Exiting on Cancel" traced back to having two pilot-link versions installed; compile against one and link against the other. 2002-09-02 Adriaan de Groot * Added finer-grained pilot-link version checking in configure.in.in. Removed all support for ancient pilot-link versions. 2002-08-30 Adriaan de Groot * Much mucking about with dlp_ functions in an attempt to discover why syncing wasn't discovering _any_ of my databases. Also handling dlp_ReadUserInfo failures, indicating possible password use. Weird. 2002-08-28 Adriaan de Groot * Mess around a bit with Chris' crashes and the exiting-on-cancel one. * PilotDaemon not passing on correct signals and slots to KPilot. This should finally enable some progress-meter changing. * Ditched the check of dlp_OpenConduit when the device is opened initially, it's returning -18 after the user name is read correctly. The USB support under FBSD is still very patchy, though, since it thinks I have just one database. 2002-08-24 Adriaan de Groot * Add a "Fail Now" mode to the NULL conduit to help debugging. 2002-08-24 Adriaan de Groot * (syncAction.cc) Whoops, forgot to implement the timeout feature in interactive questionYesNo. * One more go through all the sources removing warnings. 2002-08-23 Adriaan de Groot * (addressWidget.cc) Added more debugging output in response to bug #45977. Gosh, it's even a FreeBSD user. This basically means that the database can't be opened, and I have no idea why. * (kpilotlink.cc) Added more debugging output in KPilotLink::acceptDevice() to deal with problems from Chris Cowell and Beat Straehl. * (kpilotlink.cc) (Perhaps) check pilot-link version more gracefully. * (pilotUser.h) bzero() new KPilotUser data structures, just in case. * (interactiveSync.cc) Fix compile warnings. * (knotes-action.cc) Fix bug that causes the KNotes conduit to hang when KNotes isn't running. * (everything dependent on SyncAction) Changed the type of exec() to virtual bool, and removed it from the slots. Added a new slot execConduit() which calls exec(). This makes you return a value from exec(), and false is intended to indicate "processing never started due to errors" and will cause execConduit() to generate a generic error message and emit the syncDone(this) signal, which is otherwise easily forgotten when just doing return; KPilot Developer's notes for august 15th, 2002 ============================================== 2002-08-15 Reinhold Kainhofer * Implemented categories in the todo conduit * Fixed the bug which prevented error messages from being included in the hotsync log (the signals from fDeviceLink were not connected!) * Included the malconduit in the CVS tree (but disabled its compilation for now), wrote several emails asking for permission to either relicense libmal to use MPL 1.1, or to include special permission into KPilot's COPYING to permit linking to libmal. KPilot Developer's notes for july 31th, 2002 =========================================== 2002-07-31 Reinhold Kainhofer * Added a time conduit which syncs the time from the pc to the palm * Also wrote an AvantGo conduit, but didn't add it to the cvs tree yet because it uses libmal, which is MPL (and thus GPL-incompatible). We have yet to figure out a way to make them compatible... KPilot Developer's notes for july 17th, 2002 =========================================== 2002-07-17 Reinhold Kainhofer * A first almost-working version of the address conduit. Chances are, some data will be lost, but most parts work. "Duplicate entries" conflict resolution setting does not yet work. KPilot Developer's notes for july 4th, 2002 =========================================== 2002-07-04 Reinhold Kainhofer * Added a function KPilotDeviceLink::tickle() which prevents a timeout on the palm side if it is called with a timer (e.g. when a dialog is open) * Some more work on the addressbook conduit, which seems to be trickier than I had thought initially. KPilot Developer's notes for june 24th, 2002 ============================================ Moving on past 3.0.2 and trying to sort things out. 2002-06-24 Adriaan de Groot * The config file the daemon allocates is read-only. This is inconvenient when conduits want to save data in the config file. Backed that out, am now worried about what happens when you leave the KPilot UI running during a sync, since both applications have a RW copy of the config file. 2002-06-24 Reinhold Kainhofer Still fighting with the addressbook conduit. The Palm -> PC way already seems to work. Haven't committed anything yet to prevent breaking compilation of the tdepim module with a conduit which won't work yet anyway. KPilot Developer's notes for june 16th, 2002 ============================================ 2002-06-16 Reinhold Kainhofer * backported many fixes in the vcal conduits to the BRANCH for the 3.0.2 release. * For the addressbook conduit I implemented a method QValueList PilotDatabase::idList() which returns a list of all record ids in the database * KPilotDeviceLink::openDatabases now fetches the database from the palm if no backup copy exists on the PC. KPilot Developer's notes for june 9th, 2002 =========================================== Not sure just what Reinhold has been up to recently, but I know I've been sitting in the sun and relaxing. Mostly. H==HEAD, B==Branch in the bracketed notes after the patch description. 2002-06-10 Adriaan de Groot * Using version 4.3.3 in BRANCH for the 3.0.2 release, and 4.3.4 in HEAD for later. 2002-06-08 Adriaan de Groot * Conduits, conduits, conduits and documentation, documentation, documentation. That's what we need. Sigh. 2002-06-07 Adriaan de Groot * Patched VCalConduitBase::cleanup() to be careful about calling functions on objects that may not be allocated. [H,B] * Patched VCalConduitBase to use variables from ConduitBase. [H] * Added tooltip for daemon. Gosh, that's ugly. Should put a nicer message in there. [H] KPilot Developer's notes for may 25th 2002 ========================================== 2002-05-23 Adriaan de Groot * KNotes syncing now really seems to work both ways. * Time to deal with a lot of little administrative files. * Fixed tooltips in config dialog. * KPilotTest now resets after a sync as well. * Added hooks in LogWidget to allow extra buttons. 2002-05-21 Adriaan de Groot * Renamed PilotDatabase::cleanUpDatabase() to cleanup(), this affected the Serial and Local reimplementations and also the abbrowser conduit, which is the only conduit to do the right thing and cleanup the database after a sync. * Added missing close and delete on the databases for plugins. 2002-05-19 Adriaan de Groot * Time to take a good hard look at the conduits individually. We'll start with the notes conduit, since it only does one- way syncing. I suspect this will chime in some more testing instrumentation in the base classes for conduits, too. * Changed lots of bitconstants to hex, for clarity. * Added a FlagLocal to plugin.h with the intent that you can then try to sync two _local_ databases -- so you don't even need a Pilot for testing. * The KNotes conduit now tries to do something sensible with getting notes back to the Pilot, but fails. KPilot Developer's notes for may 18th 2002 ========================================== 2002-05-18 Adriaan de Groot * Bunch of compile fixes. What happened? 2002-05-15 Adriaan de Groot * Updated the version number. * Removed the device type combobox, since it's not needed. * Updated the what's this text for the speed combobox. * Removed the "alpha" warning from the log widget. KPilot Developer's notes for april 28st 2002 ============================================ Hopefully we'll have merged the HEAD version of the vcal conduit -- by Reinhold K. -- with branch so that it actually works. KPilot Developer's notes for april 21st 2002 ============================================ A week when I should have been working on KPilot, and I've been working on the build system instead. Reinhold K. has hinted that he's making tremendous progress on the vcal conduit, which is a good thing. 2002-04-20 Adriaan de Groot * Closed a few bugs that I could verify are resolved. Other conduit- related bugs remain open even if I suspect they're done, since I haven't actually physically tested them. 2002-04-16 Adriaan de Groot * Finally committed all of David B's patches and things. [HEAD] * More modification of configure.in.in and the Makefile.am's to make pilot-link more easily found (I hope). [BRANCH] 2002-04-15 Adriaan de Groot * Cosmetic fix: center splash image under KDE3 as well. * Fixed misleading debug statement when KPilot starts the daemon. KPilot Developer's notes for mid-april 2002 =========================================== 2002-04-13 Adriaan de Groot * Received a patch from Carlo Perassi for handling cases where there is no user name set in the Pilot. * Worked on configure changes to detect pilot-link automatically and properly. [BRANCH] 2002-04-09 Adriaan de Groot * Did some minor debugging in setting flags for the conduits. 2002-04-07 Adriaan de Groot * There are now two real branches of development for KPilot. KDE_3_0_BRANCH gets bugfixes to the existing code, while HEAD gets new features. I imagine I'll merge BRANCH back to HEAD sometime when I feel that the main bugs are out (like next week, I hope). I'll be showing where patches go until we merge again. * Added a message (no i18n) showing KPilot and pilot-link versions. * Still need a workaround for dlp_addSyncLogEntry() for pilot-link 0.10.1 [BRANCH - should go in HEAD as well] * Fixed Makefile.am bug in popmailconduit. [BRANCH] - --test mode wasn't working with kpilotTest (when running conduits) [BRANCH] 2002-04-06 Adriaan de Groot * Applied patch to avoid crash with undefined symbol. I forget who sent it in, though. Thanks to you, anonymous! Wrote a script to catch this kind of situation in the future. KPilot Developer's notes for sometime in march 2002 =================================================== 2002-03-09 Adriaan de Groot * Sanitized syncStack so that nextAction isn't so ambiguous. * Fixed missing default (--list) in kpilotTest. * Some neatness fixes in pilotDaemon.cc and pilotDaemonDCOP.h. * Test syncs shouldn't run conduits or install files. Fixed in pilotDaemon. * The daemon leaked 2 FD's on every sync, which is bad. Added some extra ::close() calls, which fixes this (under p-l 0.9.5 and 0.10.1). * Mucked about with USB devices some more, but it looks like the m500 is going to be unusable under FBSD for some time. This isn't bad, since I can then concentrate on getting things working with the serial PalmV. * It might be a good idea to start using the daemon to do just device tests instead of kpilotTest -- though it doens't make a big difference. 2002-03-08 Adriaan de Groot * Fiddled around w/ getting a broadband connection, for whatever reason. I guess effortless connectivity is the goal. Fiddled with my new m500 USB and discovered that pilot-link 0.10.1pre works perfectly with it under Linux (well, pilot-xfer -l works). Under FreeBSD, though, it seems that there's nothing available for this kind of device. Hmph. So now I need to spend some time to figure out how to get KDE up and running on my somewhat deprecated Linux install. Serve the source by NFS? 2002-03-07 Adriaan de Groot * Finally picked up where I left off, adding yet another message to the startup log window (again, I think this is temporary). The versions of relevant items now appear there. * Messed around with crashes while deleting CleanupActions. 2002-03-06 David Bishop * Lots of work on exporting memos in XML format. It looks like the whole memo viewer widget is going to be reworked, slightly. * Finished off the kdDebug() repairs someone else started. KPilot Developer's notes for february 11th 2002 =============================================== 2002-02-06 Adriaan de Groot * kpilot/listItems.cc lib/pilotRecord.cc - Removed some FUNCTIONSETUPs, since they were really clogging debugging output and not adding anything interesting. Changes some other debug output as well. * kpilot/addressWidget.cc - I *think* I squashed a memory leak, caused by createTitle which was still returning char * instead of QString. Moved to QString anyway. 2002-02-03 Adriaan de Groot * kpilot/Icons/kpilot-hotsync.png - Whipped up a new icon for HotSyncing. This makes all the icons in the Janus view the same size. KPilot Developer's notes for february 2nd 2002 ============================================== 2002-01-26 Adriaan de Groot * Wherever - Invented an icon for the address viewer. - Doubleclick on conduit in active column configures it. - Fixed some compile problems under KDE3. - Messed around with the vcal conduit. - Configuring conduits resets the daemon. - You can't reset the daemon during a sync; replaced fQuitAfterSync. I'm starting to think the logWidget belongs with the *daemon* (and should be showable from the daemon's context menu), not from KPilot (which should be just a viewer). Opinions? 2002-01-27 Adriaan de Groot * Wherever - Got rid of the remaining dlp_ functions in code outside of kpilotlink.cc and pilotSerialDatabase.cc. This leaves the pi_ stuff. Development of KPilot is now done on a 80x25 serial terminal running at 38400 baud. I have no idea what kind of effect this will have, but it means I can sit on the couch and do devel work :) 2002-02-02 Adriaan de Groot * lib/kpilotlink.{h,cc} - Continue moving pilot-link related things (pi_*) into the KPilotLink class, so that Dag might have an easier time of it. * lib/options.cc - Removed some messy #ifdef DEBUG stuff, with debugging enabled call tracing is now default on. * kpilot/logWidget.cc - Added some text stating that KPilot is really alpha. No-one will read this, of course, and it will only piss off the translators. KPilot Developer's notes for january 25th 2002 ============================================== Found my Pilot again, made tea, thought about Dag's and Neil's comments on ColdSync (I still believe that ColdSync has the drawback that it's not meant to be a library you can build on, it resembles the pilot-xfer tools much more than anything else). Grepped for dlp_ in the sources. They seem fairly isolated, which is good -- maybe we *can* move to some other Pilot access method. Looked at some old sources. *uuuuugly*. PilotRecord, PilotAppCategory, PilotTodoEntry, etc. could use a good dose of sanity. 2002-01-21 Adriaan de Groot * conduits/vcalconduit/* - Some serious rewriting going on. * kpilot/hotSync.cc - Removed old KPilotLink code - Moved calls from dlp_OpenConduit to KPilotDeviceLink::openConduit() * lib/syncAction.h lib/kpilotlink.{h,cc} - Added openConduit to abstract the underlying lib interface more. * kpilot/logWidget.cc - suppress empty log lines. * lib/pilotLocalDatabase.{h,cc} - Added a hook for UserCheck to set the default search path for databases opened by name only. It's time to say hi, welcome, and thanks to a couple of new people on the KPilot / kde-pim team. There's Chris Abiad, who has already made his presence felt on the mailing list. Thanks for fielding questions for me, Chris, and stalling on the question of when the next release is. Chris will also be maintaining the website. Next up is Stephanie Bryant, a writer of technical documentation. She'll be helping me document the various files in kpilot/lib so that they actually form an understandable and usable API for third-party conduit-writers. Philipp Hullmann, you should be overjoyed to hear this :) Once she's practiced on KPilot, Steph will be leaving us for tdelibs, where weird and wonderful things await ... 2002-01-25 Adriaan de Groot * *.ui - Danimo was wondering why we use ToolTips everywhere instead of WhatsThis. My answer was "because we knew about QToolTip before QWhatsThis." Anyway, switching over to the correct form of on-line help is a simple search- and-replace thing. So that has happened. David, can you keep that in mind as well? * kpilot/pilotDaemon.{h,cc} kpilot/Icons/ - Minor changes to get the daemon's icons to display properly. - Woo.. the busysync icon is *ugly*. Partly fixed, and I hope Kristof can do something about it sometime. Really we need the icon in 4 rotated states (well, maybe 2) to indicate activity during the sync. - Of course the daemon was exiting after each sync .. I forgot to initialize fQuitAfterSync (which isn't used, BTW, except if you use DCOP to call quitNow()) to false. * kpilot/kpilot.cc - Forgot to inform daemon of changing settings. * kpilot/syncStack.cc - All conduits now put *something* in the Sync log. KPilot Developer's notes for january 20th 2002 ============================================== It's been a slightly sleepy time. Some rocky backporting has occurred, though, as KDE3-isms sneak into the codebase and break my compiles at home. At work, though, I've switched to KDE3 and it's really nice. Now if only I could release a version of KPilot that works before KDE3 comes out and makes all this compatibility effort moot ... 2002-01-15 Adriaan de Groot * conduits/vcalconduit/* - Class Recurrence is the KDE3 name of class KORecurrence. Where the libkcal API has changed, added #ifdefs to use the right one, and #define Recurrence KORecurrence when compiling under KDE2. 2002-01-16 David Bishop * *.ui - Added 's to all tooltips, neatness fixes. 2002-01-16 Adriaan de Groot * lib/options.{h,cc} - Added support for both ostream and kdbgstream << QSize to avoid plugin crashes when the plugin is compiled with different DEBUG_CERR settings from libkpilot. 2002-01-19 Adriaan de Groot * Documentation - Added a warning "Docs out of date" to the docs, adapted all the top-level README &c. files to reflect the current situation. 2002-01-20 Adriaan de Groot * lib/pilotLocalDatabase.{h,cc} - Added new constructor that doesn't take a path, but just uses the application-instance database directory. * lib/plugin.{h,cc} - Added isRunning() to PluginUtility, since several conduits need to know if the application they are syncing is already running or not. * conduits/knotes/knotes-action.{h,cc} - Replaced knotesRunning by call to isRunning(); * conduits/vcalconduit/* - Started a real re-write of the vcal conduit (what??!) * TODO - Updated the TODO list with some concrete stuff. KPilot Developer's notes for december 31st 2001 =============================================== Time to go out with a bang, eh. Fixing the VCal conduits so they actually do a sync was a fair bit of work, partly because it was so weirdly crufty, partly because of the peculiar separation of the todo from the vcal conduit. 2001-12-28 Adriaan de Groot * conduits/vcalconduit/vcalBase.{h,cc} * conduits/vcalconduit/vcal-conduit.{h,cc} * conduits/vcalconduit/todo-conduit.{h,cc} - Well, it compiles now. * lib/plugin.{h,cc} - Added isBackup() so that conduits can now also do their own backups. Note that conduits aren't called (yet) during a backup action. * conduits/popmail/* - Why the heck does this (still) use FILE *? - It compiles and there is a sync action. Next up is checking out kpilotTest and making sure that it does sensible things, like closing the device handle, allowing multiple syncs, and running file install correctly. After that, testing testing testing. 2001-12-28 Adriaan de Groot * kpilot/main-test.cc - Added one-letter cmd-line-options, sanity checking. - Switched to SyncStack integrated syncing (see below). * kpilot/main-config.cc - Removed unused new-style option. * kpilot/syncStack.{h,cc} - New files encapsulating sync sequence knowledge. 2001-12-29 Adriaan de Groot * kpilot/pilotDaemon.{h,cc} - Switched to SyncStack. * lib/kpilotlink.cc - Work around an off-by-one bug in pilot-link versions < 0.9.6. * kpilot/interactiveSync.cc - Added support for don't ask again in the check-user questions. This changes the API of questionYesNo, but only inserts a (defaulted) parameter, so "regular" calls of this should be unaffected. The GUI isn't updated at all (?) during a backup action. Hmph. Well, only between databases, but that's not much. The backup appears to work, which is a good thing. Gonna hafta try the restore action soon ;) 2001-12-29 Adriaan de Groot * conduits/null/null-*.{h,cc} - Fixed some configuration load / restore / use bugs. Moved configuration keys to the factory. * kpilot/syncStack.{h,cc} - The conduit proxy action also needs to proxy the messages from the conduit. I never knew connect(p,SIGNAL(),q,SIGNAL()) worked! Wow. * kpilot/logWidget.{h,cc} - Added missing slot for logProgress. Aieee! I'm becoming a kate user, vi is suffering from abandonment on my devel box. This is troubling -- using the software you write. Heck, next thing you know, I'll be using KPilot to sync my Pilot. Ewwwww. 2001-12-29 Adriaan de Groot * kpilot/conduitConfigDialog.{h,cc} - Removed old Exec= style conduits entirely. They're warned for now. * conduits/abbrowserconduit/* - See conduit run. See DrKonqui. Whee! Oh, and this *one* conduit has a name of the form bla_conduit, while all others are bla-conduit. Yay. See pointer get used before initialization. Cool! It crashes elsewhere. Isn't delayed loading great? __rs__FR11QDataStreamRt5QDict1Z12ContactEntry And ... that was fucking amazing. Greg, you da man. OK, so that one also runs to completion, at least the first time. It looks like FirstTime isn't being turned off like it should, so I'll do that by hand. OK, changes get copied from the Pilot to KAddressbook ok, but the conduit seems to read *all* records from the Pilot, not just the modified ones. That's bad for the batteries. Oh well, I'm just so happy it works that I'll move on to the next conduit and deal with bugs tomorrow. * conduits/expense/* - Seems to work fine. * conduits/knotes/* - Undefined symbols ... man, I (semi) hate libtool libraries. See, I just left some essential code *out* here, and thus libtool thinks it'll be resolved later. Ha! OK, it at least copies new KNotes to the Pilot. That's enough for now. * conduits/popmail/* - Um, does this actually *do* anything? OK, config fixes, dcop fixes ... and voila, a message shows up in the outbox of KMail. So let's call sending via KMail a success and have a cup of tea. * conduits/vcalconduit/* - Now things get hairy / exciting. Let's start with the ToDo conduit: kpilotTest: WARNING: [void ConduitProxy::exec()] : Can't create SyncAction. Very wise. Of course, the code to create a conduit is not in the factory. Brilliant! Nothing a little cut-n-paste can't cure, and configure, and .. DrKonqui. Did some indenting, my brain hurts from trying to (a) understand this (b) fix all the memory leaks. Rewrite? - VCalConduit: it doesn't crash, but it's probably going to read all the things from my Pilot and install them in KOrganizer with a date of 0000/00/00 (from looking at the debug messages as they fly by). And .. whump, KOrganizer now can't read the .ics file anymore. *Every* sync, KPilot tells me that the name in the pilot is different from the name in KPilot. Gotta fix that. 2001-12-30 Aaron J Seigo * kpilot/logWidget.cc * kpilot/kpilot.cc - Paint the KPilot version number in the splash screen. 2001-12-30 Adriaan de Groot * conduits/vcalconduit/vcal-conduit.cc * conduits/vcalconduit/vcalBase.cc - Removed some __FUNCTION__ things, added #ifdef DEBUG to debug code. In some other files, too. - The code in vcalBase.cc is in heavy need of an invocation of indent. It's horrible and ugly in other ways, too, but this is a start. 2001-12-31 Adriaan de Groot Some general polishing of ToolTips &c. * kpilot/* - Added Kristof's icon for the file installer. It's still a preliminary version, though. - TODO: after reconfiguring the username, re-initialize all components in kpilot, to get the new databases. - Switched the ToolTips in the address viewer to use - TODO: ditch the toolbar; perhaps add the select-kind-of-sync functionality to the logWidget. KPilot Developer's notes for december 27th 2001 =============================================== So I never posted the previous notes. And besides Maarten's little comment on the odd jobs, no response either --- but then again, it was Xmas and maybe people had more important things to do. I know I had enough dinners that I can fast & hack for the rest of the week. Things fixed now: * conduits/vcalconduit/ - All the configuration dialogs now look ok, after a little fiddling about with the .ui files, and the configuration is saved as well. A sync is out of the question right now. Yet another odd job: someone (David?) needs to check all the ToolTips in the .ui files for the conduits with Qt *2*'s designer. And we need to check that all the configurations are in fact saved properly. Testers? KPilot Developer's notes for december 23rd 2001 =============================================== HoHoHo. Let's look back in the ChangeLog to see where we were one year ago. Struggling with the vcal conduit (it's *still* wonky); missing the 2.1 release deadine (was it that long ago?); cleaning up code. In these complex modern final days, (to quote Pogo), what's up? 2001-12-18 Adriaan de Groot * conduits/expense/* * conduits/null/* - These two conduits now have a full configure dialog that's sized correctly (afaict without messing around with font settings), that saves the settings, and have a working sync action. Whee! 2001-12-20 Adriaan de Groot * conduits/abbrowser/* - This conduit now has a working config dialog and does a sync, although I haven't really looked at the sync code itself to check for bugs. * conduits/knotes/* - Ditto; it configures and syncs, although the sync is rather sparse. I discovered that const char * const is a useful type, though. It saves an accessor function for TDEConfig entry keys. The bad conduits: * conduits/popmail/* - Still no .ui file and not many tooltips, but you *can* configure this conduit. No sync though. * conduits/todoconduit/ - This one is seriously deprecated and I'll try to remove it soon. * conduits/vcalconduit/* - It's got a .ui file which is used badly and which is missing layouts. Not a hint of saving configurations though. OPEN JOBS: Are you bored? Is your love life lackluster? Do you want to MAKE MONEY FAST? Do you want to FIND OUT WHAT MICROSOFT DOESNT WANT YOU to KNOW? ... um ... back to reality: If you'd like to help out with KPilot but don't really know where to start, and would like to get a little acquainted with the code, the coding style, and some of the conventions used in KPilot, read on! If you have grep and a text editor, read on! The code, and particularly the debugging code, has gone though a number of phases. For a while, there was that --debug 1023 stuff. I've decided that that's actually kinda cumbersome for a GUI program, and debugging has switched back to an all-or-nothing kinda thing. So some things need to be changed all over the source code, and that's just the kind of exploratory job for someone with grep and vi. In particular: * kdDebug() everywhere needs to change into DEBUGCONDUIT, DEBUGKPILOT, or one of the other DEBUG* macros defined in kpilot/lib/options.h. This will send the debugging output to the sensible debug area. Which one you choose depends on where the file lives -- choose wisely. * DEBUG* calls everywhere need to be surrounded by #ifdef DEBUG #endif. This is because some compilers don't optimize away unused strings, leading to big bulky (well, sorta) executables. Adding the #ifdefs makes sure that there's nothing at all left over from the debugging code when debugging is turned off. * __FUNCTION__ needs to be replaced by k_funcinfo. The popmail conduit is bad for that one, at the very least. * if (debug_level) and its cousin if (debug_level & SOMETHING) need to be removed, along with the set of brackets they introduce. The debugging statement (usually just a kdDebug() << whatever << endl;) needs to be out-dented one tabstop, to line it up properly. These are, in one sense, rotten little jobs. But they'll take you to all the corners of the KPilot code, show you some ugly (and some not-so-ugly) code, and give you a feel for "the lay of the land." After that, fixing all the remaining off-by-one bugs in the vcal conduit should be a breeze. KPilot Developer's notes for december 16th 2001 =============================================== Worked on some conduits for danimo, who has UI updates. So more conduits compile now, but I haven't tested them. However, they do get installed if you do make install, and they may eat your Pilot, you Buick, or New York when run. USE EXTREME CAUTION. I think the NULL conduit is safe, though :) Abbrowser Conduit: it compiles, and it has but a setup dialog and a sync part which has not been tested at all. * Makefile.am - Fixed up includes, removed old PISOCK_INCLUDE. * abbrowser-conduit.cc - Changed kdDebug() to DEBUGCONDUIT, applied indent style, #ifdef DEBUGs - Replaced static QString objects by const char * (TDEConfig keys) - Removed old files - Assume FirstTime is always *true*, this is at least partly broken, but it makes the conduit compile at least. The other conduits all compile and have config dialogs but don't do anything. And in other news, little bugfixes and other neat stuff sometimes shows up in my mailbox. Martin Junius is a long-time contributor, and he's volunteered (again) to make new KPilot rpms for RH 7.2 once the system is stable again. * kpilot/addressWidget.cc setupWidget() - Martin Junius found a display bug and sent a patch. * conduits/vcalconduit/vcal-conduit.cc setRepetition() - Philipp Hullmann noticed that the Pilot's week starts on day 0 = sunday, and in KDE day 0 = monday. KPilot Developer's notes for december 2nd 2001 =============================================== More work on the expense conduit. In conduits/expense: * setupDialog.h - Added an #include to make header self-contained. * setupDialog.cc - Disabled MySQL button, since there's no code to make it work. - Disabled "logRotate" stuff, since I can't remember what was wanted there and there's no code for it. * expense.cc - Reordered #includes, removed extra #ifdeffing. Removed extra #includes. - Split up actions into CSV, MySQL and Postgres specific parts. - Made the other-db methods also write CSV files if needed. - Support both overwrite and append modes for CSV. - TODO: create the mysql code. - TODO: patch possible security hole in echo passwd | - TODO: spawn fewer processes for psql. - TODO? use klocale's date formatting, not US-specific code. * expense.h - Changes reflecting the above, and - Documenting what's going on. In other news: * conduits/knotes/knotes-action.cc listNotes() - Removed spurious #ifdef DEBUG. Test mode should always work. And oh, wow, thanks to messing around with the logWidget for KPilot, KPilotTest now also has a funky splash screen :) * kpilot/main-test.cc main() - connect signals from the test action to the log widget. KPilot Developer's notes for november 25th 2001 =============================================== More work on the Expense conduit. In other news: * kpilot/logWidget.{h,cc} Nifty feature for the sync log: clear the log. Save the log. ToolTips. KPilot Developer's notes for november 18th 2001 =============================================== Kudos to Marko Hollomon for spotting a pointer error in the KPilot daemon and fixing it. The patch changes pilotDaemon.{h,cc}. Thanks too to Palle Girgensohn, who made an icon for the internal memo- viewer and the KNotes conduit. This looks really neat in the new IconView mode of the main KJanusWidget. Shuffling the DCOP interfaces and cleaning up the UI, by [ade]: * logWidget.{h,cc} Made the splash more like a splash, removed some ugliness, moved the progress bar into the SyncLog widget. * kpilotDCOP.h Removed the spurious filesChanged() call -- use KDirWatcher instead. * kpilot.{h,cc} Removed the inheritance from kpilotDCOP.h, moved the DCOP interface to LogWidget. Removed the status bar, since it's all in the LogWidget anyway. * pilotDaemon.cc Renamed KPilotDCOP interface, removed filesChanged DCOP signal. * Makefile.am Now logWidget requires kpilotDCOP, so moved that. Now that conduits are .so's, the conduitConfigDialog needs to have some strings changed to reflect that they're not executed anymore [ade]. * conduitConfigDialog.{h,cc} Added a warnNoLibrary function, moved warnings to Qt richtext. The FileInstallerWidget has some lousy strings with \n, and it needs a KDirWatcher [ade]. * fileInstallWidget.{h,cc} Changed the i18n strings to remove \n's. The Watcher remains a TODO. Attacked the expense conduit, finally. Maybe *this* one won't run aground on things like fundamental API changes in the stuff it syncs against. * Makefile.am Removed spurious LIBPISOCK_PATH, moved files around a little. * setupDialog.{h,cc} Ported to UIDialog classes, layout fixups. This is the one conduit that still uses hard-coded layouts. It's possible, see? This isn't really the way to go, I'd much rather have David B. make dialogs with Qt designer. Added a break; in ExpenseDBPage::slotPolicyChanged() to avoid warnings. KPilot Developer's notes for november 11th 2001 =============================================== Much messing-about with hardware, OSsen and the like has delayed many things. I've discovered that the configure.in.in and Makefile.am for KPilot were really badly broken under anything non-Linux. * configure.in.in Possibly fixed all kinds of shell-script breakage (under Solaris) and not-finding pilot-link under FreeBSD. You will have to pass in the --with-extra-libs and --with-extra-includes flags; configure now looks there correctly. * All the Makefile.am's Removed the extra spurious $(LIBPISOCK_PATH) which was breaking things under FreeBSD. * lib/uiDialog.{h,cc} Added a virtual bool function validate() so that when Okaying a dialog, you can check first for valid settings. The default implementation is return true; * kpilot/kpilotConfigDialog.{h,cc} Added validate(), check that string for Pilot device doesn't overflow the buffer for it. Also enforce the length restriction for the device name. This is all conditioned on pilot-link < 1.0.0. * kpilot/kpilot.{h,cc} Use a KJanusWidget instead of a QWidgetStack and deprecate the View menu to make it clearer which views / actions / things KPilot actually *has*. Moved the Spash Screen to the log widget, and made it a real splash. KPilot Developer's notes for october 28th 2001 ============================================== So fun to have distributions release broken versions of an application. It sometimes makes me wish I didn't have to commit stuff to CVS at all until the application is totally right according to me (which is then sure to run into trouble with the KDE release schedule). Another fun thing is wrestling with broken hardware. But it's finally fixed now. So I hope the pace picks up again now. I've been working on the abbrowser conduti sporadically, so we now have at least three conduits partially ported to the new setup. KPilot Developer's notes for october 21st 2001 ============================================== 2001-10-21 Adriaan de Groot Since to do the popmail conduit I first need to learn about IOSlaves and the KNotes conduit is hard, I spent some time playing with the abbrowser / KAddressbook conduit. * conduits/abbrowser/* () Removed all the old files for the setup dialog, now using David Bishop's .ui files with some polish from me (like putting his name in the "Author" field in the .ui file). () Fixed up the Makefile.am to make the library and the test apps. () Added a factory function. () Removed all the palettes from the deconflict dialog. This takes 150k out of the .ui file. Next challenge is to make it respect the KDE system settings. 2001-10-20 Adriaan de Groot Worse is when your AGP bus turns out to be broken instead. * conduits/knotes/knotes-action.{h,cc} () Added method resetIndexes which should be called at the end of every phase of the sync, basically to reset the counter and list iterator to the beginning of the list of KNotes. () Added method modifyNoteOnPilot which does the modified-notes-to Pilot work. It isn't very robust yet, since it doesn't handle weird cases (modified yet unknown on Pilot, for example) at all. 2001-10-19 Adriaan de Groot Dern. Having your video card break and being thrown back to a 4MB SiS card fit only for a firewall with no monitor is *no* fun. Where's a 24-hour computer store when you need one? Not only that, but I realise I'm going to have to put some serious thought into the KNotes conduit and how it is supposed to sync. So since that's hard, I'm going to look at the Mail conduit instead, since the functionality there is pretty much complete. 2001-10-18 Adriaan de Groot * kpilot/Icons/ () Incorporated most of Kristof Borrey's fantastic new icons for KPilot. * conduits/knotes/ () Removed old files setupDialog.{h,cc} * conduits/knotes/knotes-action.{h,cc} () Added new function getConfigInfo that reads the config file for the lists of Ids (matching KNote ids to memo ids). 2001-10-16 Adriaan de Groot * lib/options.h Upped the version number to 4.2.9b just because. * kpilot/kpilot.cc Changed some credits around, copyright notice, etc. * kpilot/Makefile.am kpilot/Makefile-standalone Fixed some breakage caused by all the moving around of files. You may need to make clean ; make in KPilot some time to get things back to normal. KPilot Developer's notes for october 16th 2001 ============================================== 2001-10-16 Adriaan de Groot Well, the b-day party got in the way of actually releasing something, and there's quite a lot of polish still to apply -- ie. the KNotes conduit still does nothing more than install new notes to the Pilot. So I'm going to start keeping the TODO list more up to date, including assignments for various people, and keeping the ChangeLog more up-to-date according to the ChangeLog standard, instead of these long rambling stories. 2001-10-14 Adriaan de Groot Whee! It's KDE's birthday today. What a fitting day to finally release a version of KPilot that actually works, has useful features, and doesn't gum up your Pilot hopelessly. 2001-10-10 Adriaan de Groot * Actually add new KNotes to the memo pad. This means conduit syncing is actually coming closer. Works from kpilotTest. * Renamed --test --list in kpilotTest, added option --notest to force a conduit to *really* run (may be hazardous!) from the tester. * Moved many things into lib/ -- whatever is shared between KPilot and conduits, basically. * Wow! There's stuff in PilotAddress I'd never noticed before that deserves to be moved to a superclass -- like setCategory. Kudos to Greg. * Updated the TODO list. * Added a nicer credits section in the about page of dialogs. 2001-10-09 Adriaan de Groot * nothing! Fixed old compile issues on KDE 2.2 iob Solaris. 2001-10-08 Adriaan de Groot * Added lots of things in lib/ to enforce some kind of uniformity on conduits and factories. Utility functions, too. * Added an app-icon for the KNotes conduit. It's ugly as all get-out. * Added a test-conduits and a list-conduits mode to kpilotTest. * Went back and tested all the stuff we already had, since this re-architecting carries risks. This showed that not everything had gone right: I'd lost track of the pilot socket somewhere. Hmph. Two rounds of re-writing headers, all the parameters finally end up in the right place. * The knotes conduit now lists new knotes but doesn't install them. KPilot Developer's notes for october 7th 2001 ============================================= Ah, post-KDE3-alpha1. And that when KPilot remains completely 2.1 and 2.2 compatible. A new release of KPilot for 2.2 is imminent, say oct. 14th or so. KDE 2.2.2 was just released, but contains no changes to KPilot at all -- all the bugfixes were not of the kind that would fit in the 2.2.2 plan. 2001-10-07 Adriaan de Groot Hmm. Missed a few days. What I remember: * Implemented the Null- and KNotes-conduits setup dialogs in plugin libraries using David's UI files. That was fun and easy to do. * Make the new-style conduit configurator handle plugin libraries. This was less fun, but it works. I haven't had any feedback on which of the two config dialogs is easier to use, but right now I'm leaning towards the new-style one (two columns + some buttons, just like it was *long* ago.) D'nD would be nice though. * The new-style thingy doesn't handle saving which conduits are enabled. * Made a new subdir lib/, since the plugins need to share some code with KPilot and you need a .so to make it link properly. * Wrestled with sensible layout of the about page. 2001-10-01 Adriaan de Groot * Picked up David's new UI file for the conduit configuration dialog and gave that a whirl. The results can be found in kpilotConfig, use --help to find out which options to use. KPilot Developer's notes for september 30th 2001 ================================================ 2001-09-30 Adriaan de Groot Last minute sneak-it-in-for-the-alpha things. More code and layout cleanup, although the big commit changing to tabs & the KPilot style was yesterday. Fixed some minor display bugs, made preHotSync more useful, normalized some strings. The kpilot/Icons/ directory now contains only those icons actually needed and used, and they're all in PNG format. Saves lots of space, in the sense that the KPilot binary is 300k smaller now than it was, due to dumping XPMs. I added a private-d-ptr to kpilot.h, but haven't moved all the data members there. For an app it doesn't matter so much, but this will reduce the amount of recompiling and who knows what the plugin API will look like eventually. The conduit configuration is different -- again -- and easier to understand. 2001-09-27 Adriaan de Groot * Added FUNCTIONSETUP everywhere. * Replaced email addresses with kde-pim@kde.org or groot@kde.org. * Removed tqDebug everywhere. 2001-09-26 Adriaan de Groot * Surrounded much debugging output with #ifdef DEBUG. * Replaced remaining calls to kdDebug() by macros with debug areas. * Applied indent everywhere. * Added some () where needed to resolve ambiguity. 2001-09-25 Adriaan de Groot Wrestled with crashes (cerr << i ; debugstatement ; cerr << i ; gave two different values for i) caused by mixing debug conde and non-debug code. Discovered that qglobal.h defines DEBUG unless NO_DEBUG is set. Hmph. Also found that gcc does a poor job in optimizing away debugging statements with NDEBUG defined. Therefore, debugging statements will be once again surrounded by #ifdefs. The plan is that I'll get all the code formatting and this kind of silly issues out of the way in the next few days and then start to deal with the next problem, namely the existing conduits. 2001-09-24 Adriaan de Groot * kpilot/uiDialog.{h,cc} * kpilot/kpilotConfigDialog.cc * kpilot/kpilotConfigDialog_base.ui Minor changes to get the dialog to size correctly when other fonts / other settings are used. This solves David's complaint about ugly dialogs. * kpilot/hotSync.{h,cc} () Removed lots of commented out code from previous incarnations. () Added a cleanup action. () Removed a heap-corruption bug caused by using QStringList & and then deleting what it points to in FileInstallAction. () Removed deadlock when last file to install couldn't be read. () Moved RestoreAction to interactiveSync.{h,cc}, since I feel it needs to ask "Are you sure?" at the very least. * kpilot/interactiveSync.{h,cc} New files with support for, and some types of, interactive syncing. Used for asking the user questions during a sync, for example confirm dialogs. This means we can now update user settings &c, since we needed some interaction for that. Moved RestoreAction to here. * kpilot/kpilotlink.{h,cc} Made exec() pure virtual for SyncActions, since that makes more sense than having an empty default action. * kpilot/Makefile.am Added interactiveSync.cc to the list of sources. * kpilot/pilotUser.h Squashed a buffer overflow. Squashed several buffer overflows. Yowk! This code has been around since 1996? * kpilot/main-test.h Added some extra code to make the sync cleaner; handled the move of RestoreAction. KPilot Developer's notes for september 23rd 2001 ================================================ My current development platform is RH 7.1 with KDE 2.1.1 -- even so I'm committing things into HEAD. I'm sure this will explode sometime and I'll be forced to upgrade to KDE 2.2 or worse, but for now, that's the platform I'm aiming for. I'd like to take a moment to thank David Bishop, for sending me .ui files, for causing noise on the mailing lists, and for being a pleasure to work with. Together we've wrestled with Qt designer, uic, and replacing the KPilot dialogs with something sensible made with designer. * kpilot/options.h * kpilot/kpilotConfig.{h,cc} * kpilot/kpilot.cc kpilot/kpilotDaemon.cc kpilot/main-*.cc Factored out the --debug flags from each individual app, now in options.cc. This means each file with a main() was modified too. I must say it was a real bitch figuring out exactly which sequence of calls were needed for TDECmdLineArgs::addCmdLineOptions(), and then finding out that ParsedArgs() also needed help. * kpilot/kpilotDaemon.cc Sneaking in the QStack<> stuff just under the wire was a bad idea. Fixed an uninitialized pointer bug. * kpilot/hotSync.cc Fixed missing syncDone() signal in FileInstallAction; added some logProgress() calls, extra debugging. * kpilot/kpilot.cc Added KillDaemonOnExit logic to KPilotInstaller. 2001-09-23 Adriaan de Groot * kpilot/uiDialog.{h,cc} * kpilot/kpilotConfigDialog.{h,cc} * kpilot/kpilotConfigDialog_base.ui New files -- the .ui file is from David Bishop -- re-implementing the configuration dialog using modern technology. uiDialog.{h,cc} are abstract base classes, suitable for reuse. kpilotConfigDialog.{h,cc} contains the behavior of the dialog, and the .ui file the UI. * kpilot/kpilotConfig.{h,cc} Switched around #ifdef and #ifndef. This disabled setting debug levels in code with debugging on. Duh. Getting it right then showed all kinds of bugs in the other code. Added some documentation explaining possible crashes due to missing TDEApplication instance. FINALLY did something sensible about code duplication -- added get and set methods to a subclass of TDEConfig for all KPilot settings. * kpilot/kpilotOptions.{h,cc} Is deprecated and removed. Say hello to the new world of .ui files. * kpilot/kpilot.{h,cc} * kpilot/memoWidget.cc * kpilot/addressWidget.cc * kpilot/conduitSetup.cc Lots of little changes to reflect the KPilotConfig changes. Mostly removing calls to setGroup() and readEntry(), which are now safely encapsulated. * kpilot/pilotDaemon.{h,cc} * kpilot/pilotDaemonDCOP.h Removed cruft, adapted to KPilotConfigSettings, and adapted to SyncActions. Changed silly startHotSync(int) DCOP method to requestSync(int). 2001-09-21 Adriaan de Groot * kpilot/hotSync.{h,cc} Added an InstallFilesAction class, to run during a HotSync. 2001-09-20 Adriaan de Groot * kpilot/kpilotlink.{h,cc} * kpilot/main-test.{h,cc} All these files changed because of yet another re-architecting. Now we have HotSyncActions, which have direct access to the PilotDeviceLink, and which do "something". The test action just lists the databases present on the device. This has been tested with USB and with serial devices. * kpilot/hotSync.{h,cc} Changed again to split the actions away from the device link (really, how I ever decided on that is a mystery to me now). * kpilot/Makefile-standalone A Makefile that can be tweaked, that does not use autoconf, and is useful for making standalone tarballs. 2001-09-17 Adriaan de Groot * kpilot/Makefile-kpilotConfig () New file for building a standalone config program. * kpilot/main-config.{h,cc} () New .h file, new classes for implementing some behavior. The behavior is very minimal right now, but as an illustration for David (hey, now he needs to learn C++ coding) it's fine. * TODO () Thought of lots of new things to do. KPilot Developer's notes for september 16th 2001 ================================================ KPilot now compiles completely again, at least on a KDE 2.1.1 platform. I'll check w/ KDE 2.2 as soon as I get that working here, and then we'll take another look at Qt3 -- I saw Cornelius has already put some changes in. 2001-09-15 Adriaan de Groot * TODO () Added a TODO file. I didn't copy all the TODO's from the ChangeLog into it, though, since many make no sense right now. 2001-09-13 Adriaan de Groot * kpilot/kpilotlink.{h,cc} () Changed fTransientDevice into fDeviceType since we have lots of variants to deal with. () Added functions installFiles() and installFile() to handle the installation (!) of files to the Pilot. * kpilot/pilotDaemon.cc () Finally dealt with all the changed classes and methods of the device link. (slotEndHotSync) No need to tell the link to end the Sync, since it's the one that's telling *us*. 2001-09-08 Adriaan de Groot * kpilot/options.h () I've installed RH 7.1 and gone back to KDE 2.1.1. Whee. They've somehow utterly broken kdDebug() and kdWarning(). Added compile flag DEBUG_CERR to make all the debugging info go to cerr instead. * kpilot/kpilot.cc () Startup notification was added to startService...() in 2.2, so now there's an #ifdef handling that case. 2001-09-07 Adriaan de Groot * kpilot/pilotComponent.h () Fixed up #ifdefs for new style * kpilot/kpilotlink.h () Make many data members private with protected access functions. (statusString) Made into a virtual function. 2001-09-06 Adriaan de Groot * kpilot/Makefile.am () Forgot to add logWidget.cc to kpilot_SOURCES * kpilot/kpilotOptions.cc () Added more tooltips, switched most to rich text. () Changed default value for SyncFiles to true. * kpilot/kpilotlink.{h,cc} () Added new state CreatedSocket and member fRetries (open) Allow for retries on pi_bind(), since it may fail on USB style devices. () Added ASSERT() and member fDeviceLink to enforce singleton=ness. * kpilot/main-test.{h,cc} () Added ASSERT() to enforce singleton-ness. * kpilot/hotSync.{h,cc} () New files, containing most of the old HotSync code from kpilotlink.{h,cc}, now using the new KPilotDeviceLink base class. KPilot Developer's notes for september 5th 2001 =============================================== It's tough keeping this ChangeLog up-to-date, since I'm doing lots of work but not committing much to CVS. But I'll try to keep things documented nonetheless. 2001-09-05 Adriaan de Groot A new application, kpilotTest, has been added. It does a very basic test of the pilot-link library and some device handling for KPilot. It is *not* installed by default, since it's pretty much useless for normal use, but useful to get some feedback about whether the new architecture works as expected. A new widget, LogWidget (logWidget.{h,cc}) is now included for, yup, logging stuff. It's used to long things during a sync. pilotListener is no longer built or needed. A new application, kpilotConfig, has been added. It is not installed by default. It just calls up a config dialog for KPilot, much like kpilot --config does. It's useful mostly because it exercises a clear subset of the code. I've tooltipified (?) the whole hardware setup dialog. I think it really needs more work, since the distribution of options is really unclear. And why are exactly *these* things grouped together? The "Address" tab really should go. The compilation of everything besides kpilotTest and kpilotConfig is now seriously broken (tm). KPilot Developer's notes for september 3rd 2001 =============================================== Hoo doggies. This is a *big* set of changes. I finally sat down to do some of the serious rework that KPilot has been needing for a long time. In essence: * Use DCOP for as much communication as possible, and * Support USB devices and other transient device nodes. Basically PilotDaemon and KPilotLink have been completely rewritten. What more is there to say? Almost every file has changed, even the coding guidelines have been relaxed (I'm not going to put #ifdefs around #include anymore, not since it turns out that the gnu cpp handles this situation efficiently anyway). Comments and documentation in most files have been vastly improved. KPilot Developer's notes for august 27th 2001 ============================================= Hm. Long time no notes. Which is not to say that nothing happened, since while I was away at a conference in Finland I dropped in at Marko G's place (see patches listed way down below) and we had a great time talking about KPilot, hacking, etc. I forget what I patched there, though. 2001-08-27 Adriaan de Groot * kpilot/addressWidget.* Fixed up Martin's patch to make it comply with the KPilot coding style, added some more docs, did a bunch of re-layouting. I read somewhere that there is a direct correlation between shoddy indenting style and bug density. * kpilot/pilotDaemon.h Added a missing class declaration for TDEServerSocket. * kpilot/kpilot.{h,cc} Removed all remaining KPilotLink cruft. KPilot now communicates with the daemon through DCOP only. Still very much on the TODO list: - actually make the daemon quit when that's relevant - ditch pilotListener (backport from kitchensync) KPilot Developer's notes for august 2nd 2001 ============================================ Vacation good. Bugs bad. Received a wonderful patch in the mail from Martin Junius, which proves once again that he's really dedicated to making KPilot look good and work well. Martin's patch "pushes the envelope" udirng the freeze, so it may not get in into KDE 2.2. 2001-08-01 Adriaan de Groot * kpilot/pilotDaemon.cc (PilotSystemTray) Fix for bug #29764 -- I'd forgotten to initialize some pointers in the constuctor again. * conduits/abbrowser/abbrowser-conduit.cc (main) Workaround for bug #28104 allowing abbrowser to start from the conduit. * conduits/abbrowser/Makefile.am Minuscule change enabling --enable-final builds here. 2001-07-23 Martin Junius * kpilot/addressEditor.cc (MakeField, MakeFieldL): removed i18n(), now done in initLayout(). (initLayout): use i18n() for label strings passed to MakeField. This is IMHO a cleaner approach than using I18N_NOOP() as before. (phoneLabelText): new function, get text for phone label, basically fAppInfo->phoneLabels[] featuring some sanity checking. (fillFields): use phoneLabelText(). (initLayout): dito. (initLayout): argument addressInfo removed, no longer needed. 2001-07-21 Martin Junius * kpilot/addressEditor.cc (initLayout): use m_phoneLabel[] for display phone labels because this change from entry to entry and cannot be set to fixed texts. (fillFields): update phone labels for editor dialog. (initLayout): reworked and hopefully ;-) improved spacing. * kpilot/addressWidget.cc (setupWidget): replaced QMultiLineEdit with QTextView for address info widget. (slotShowAddress): function totally rewritten to use QTextView and the Qt pseudo-XHTML code for formatted display of the address entry. The sequence and formatting is more or less what my Palm IIIxe does. KPilot Developer's notes for june 15th 2001 =========================================== The 2.2b1 tarballs are packaged real soon now. Whee! This marks the release of KPilot 4.2.3 (KDE 2.2, third subpackage release (alpha1, alpha2, beta1)). This version scheme makes it much easier to keep track of what was released when. Many bugs were fixed after Cornelius sent a message asking about the KPilot code; the abbrowser conduit has been renamed the KAddressBook conduit (it's still in conduits/abbrowser), some little stuff in the vcal conduit was fixed, much dead code was removed from KPilot and some code was simplified. Cornelius' mail also somehow pushed me into reading the KDE-PIM server suggestions. I'm sure you've noticed how much mail *that* has caused. KPilot Developer's notes for june 5th 2001 ========================================== [ade]: Well, I'm back from my conference -- which was pretty neat -- and lo! In my mailbox are many patches to be applied. Thanks guys. This keeps KPilot moving forward even when all of the "regular" developers are doing silly things (like moving). 2001-06-05 Palle Girgensohn * */Makefile.am I had to tweak some Makefiles to get kpilot working on FreeBSD. KPilot must include LIBPISOCK_PATH in its INCLUDES setup. [Newer CVS versions already did, but I would like to note my appreciation for sent-in patches that aid in portability -- ade] 2001-06-02 Philipp Hullmann * conduits/vcalconduit/*.{h,cc} This is a new version of my large todoconduit/vcalconduit patch, hopefully more suitable for human consumption than the previous one. It mostly splits the large sync functions into smaller pieces, simplifies the code for recurring events a lot, and moves some more code to vcalBase. * kpilot/pilot*Entry.cc ... and one more patch to PilotDateEntry and PilotTodoEntry: replace notes of length 0 with empty ones. 2001-05-23 Philipp Hullmann * kpilot/pilot{Date,Todo}Entry.{h,cc} Many fixes realted to accidental freeing of unallocated memory and some pointer ugliness. Fixes rare crashes on machines where malloc() doesn't zero the memory. 2001-05-25 Adriaan de Groot * *.cc, options.h Simplified the debugging code, no more #ifdef DEBUG if (debug_level &) stuff, just straightforward DEBUGXXX statements which get optimized aay for free when debugging is turned off. KPilot Developer's notes for may 14th 2001 ========================================== Not a lot of movement on the coding front for me [ade]; I did remember mothers' day though. Changes relevant to KPilot: * abbrowser has moved into tdebase, so the abbrowser conduit will now be available to everyone, not just those that also compile all of tdepim. 2001-05-08 Marko Gronroos * conduits/popmail/* Totally revamped the mail conduits with a new, well designed setup. This solves most of the smtp and sendmail problems we've been having. KPilot Developer's notes for may 7th 2001 ========================================= It's been great to receive patches from all over the place in the past two weeks. What has been fixed is listed below; I have the nasty feeling that one set of patches has slipped through the cracks. If you've sent me a patch in the past two weeks and don't find yourself listed here, please let me know. 2001-04-27 Adriaan de Groot * I actually worked on the docs. Stephan Kulow's meinproc HTMLizer was wonderfully useful here. The docs aren't completely up-to-date yet, but they're moving. 2001-04-28 Martin Junius * kpilot/kpilot.cc (initMenu): use KToggleAction and setExclusiveGroup for view menu. (addComponentPage): same here for the other components. (initMenu): setChecked for view_kpilot action. 2001-05-07 Philipp Hullmann * conduits/vcalconduit/todo-conduit.cc (): fixed missing due-date bugs KPilot Developer's notes for april 26th 2001 ============================================ Ahh, spring is in the air; the time when a young man's mind turns to nights of C++ hacking. This has been a great few weeks for open- source collaboration. I've had useful and helpful mail from Philipp Hullmann, Martin Junius, and Marko Gronoos (maybe more -- if i've forgotten you please complain privately) with patches, hints, and offers of help. Thanks guys! * Fixed the non-initialization of the conduitCombo pointer by removing it completely. (Thanks Martin!) At compile-time you can choose between XML and traditional UI style. [19-4] * Greg's abbrowser conduit is (almost) ready for the prime-time! [23-4] * Fixed bug where absent executables could hang the conduit setup dialog. [23-4] * Fixed small UI bug where toggling toolbar didn't resize the contents of the main KPilot window. [23-4] * Removed unnecessary connection to (serial) pilot database when conduits are started in --info or --setup mode. [23-4] * Discovered many i18n bugs in the sendmail conduit. Ouch. Some fixed. [23-4] * In a flash, implemented sending-via-KMail in the sendmail conduit. This is utterly untested and possibly hazardous. I'd appreciate it if some people used a test account for KMail and tried it out. I will too, soon. [23-4] * Looked for the right place to force KPilot conduits to use the KPilot .po file. The TLs are now OK. Thanks to Marko for prodding me to sort this bug out (conduit in Finnish is "siirtokanava"). [24-4] * Added QToolTips and buddies to the NULL conduit setup. [24-4] * Fixed a bug in the KMail sending if you use a different outbox from "outbox". [26-4] * Made KPilotLink::addSyncLogEntry marginally more useful -- this is to work towards a read log window. As a side effect (which obscures what I've done a little) I've reformatted kpilotlink.h according to the coding style guide, and added docs. [26-4] Todo: * Found out why the vcal and todo conduits are so slow -- they really do read in the whole Pilot database through the serial line *twice* each sync. This needs fixing. [19-4] * Add QToolTips to the remaining conduits. [24-4] * Add "buddies" to relevant entry fields (usually QLineEdits). [24-4] * Remove all the UI stuff from KPilotLink and put it somewhere sensible. [26-4] * Split KPilotLink into the client and server ends. [26-4] The following list is stuff from the ChangeLog that was once on the Todo list; I'm repeating it here because it was time we went through it again to see how things stand. I've added comments in [ ] after each. * Split KPilotLink into its separate functionalities: config management, local database management, and link from daemon to conduits. [partly done, but kpilotlink still serves both ends of a client-server link] * Make KPilot and KPilotDaemon communicate only through DCOP. [bad idea - causes extra overhead, and the kpilotlink protocol is pretty good] * Add an extra message concerning NULL user on hotsync. * Make the progress bar show something during a conduit sync. * Should just use the KPilotLink::config object to store all kinds of user settings instead of copying them from the config file to local variables, since this is just asking for inconsistency. [dunno -- as long as KPilot is the app for configuring what the daemon does, we just have to get KPilot to tell the daemon to re- read the config file when something changes.] * Clean up more of the butt-ugly parts of the code base [less of this now!] * KPilot is an i18n nightmare [less of this now!] * The password dialog in the popmail conduit is probably a very bad idea I think tdesud should come into play here. [not looked into] * The messages need validation - Pilot vs pilot, HotSync vs whatever * Actually *doing* a fast sync for Heiko * More and better information in the progress bar * KPilot should display the sync log as well, just like the Pilot does. This is useful for reporting the result of a sync to the user (who then doesn't need to look at the Pilot) * I noticed Thomas Zander has submitted an official wishlist item: DateBk3 (the new date book format in PalmOS3.5) support. I think I'll get back to him on that when Mirko pans out with the free hardware goodies from Palm :) KPilot Developer's notes for april 19th 2001 ============================================ * Martin Junius has contributed an XML GUI framework for KPilot, so it now finally uses the "modern" way of doing GUIs. This *does* mean it's time for yet-another set of screenshots for the docs and yet-another set of menus for users to get used to. [14-4] * Disposed of reported bug: bad category selection. [15-4] * Moved the todo-conduit into the vcalconduit directory. This makes building much simpler. [15-4] * Fixed up more #include shenanigans for --enable-final. (Don't forget the #ifndef conventions from HOWTO-CODE.txt!) KPilot now builds without warnings with --enable-final --disable-debug. [15-4] Things to do: * Fixup the documentation. * Add QToolTips to the conduits setups, KPilot's setup, and the conduit setup. This is already partially done, but someone else needs to finish this off. * Make KPilot installation and run easier -- JPilot seems to work out-of-the box on systems where KPilot doesn't. * Look into bugs #23385 (crash in VCalConduit), #20318 (munged 8-bit chars) and #24291 (doubled appointments). KPilot Developer's notes for april 8th 2001 =========================================== It seems like only yesterday that KDE 2.1.1 was out, and we're already in KDE 2.2b1. Thoreau said "Simplify, Simplify". Anyway, this week's feature creep: * Bugfix for infinite loop when changing categories. [1-4] * Some xpms could profitably be removed, since we use pngs now. [1-4] * I normalized some more header-file #ifdef / #defines. [1-4] * Incorporated patches from Aaron Seigo. [1-4] * The todo conduit didn't compile due to changes in vcalBase. [1-4] * The vcal conduit's test mode has been expanded. [1-4] * KPilot's version number has been upped (again) to 4.2.1 for the KDE 2.2a1 release; I hope we can up the revision number with every release of KDE 2.2 move on to KPilot 4.3 with KDE 2.3. [9-4] * Messed around with some of the icons and images. [9-4] KPilot Developer's notes for march 24th 2001 ============================================ KDE 2.1.1! With bugfixes and translation fixes! So only some of the bugfixes listed under march 10th have made it into there. On the western front though, we have: * Chris Molnar has started work on DB integration for the expense conduit, so that you can actually do something useful with it. The CSV export seems to be done, too. Thanks Chris! * Greg Stern has pretty much finished the abbrowser conduit (which a *lot* of people have wanted for a long time). It hasn't been committed yet, but will be soon. * The memo viewer has been very slightly beautified. * Some work for bugs #22112 and #21908, fixing deficiencies in the todo- conduit and in selecting categories under other locales. This isn't done yet, though -- some attempts have been checking into CVS for testing. KPilot Developer's notes for march 10th 2001 ============================================ This weeks "cleanup" action is to normalize the #ifdef thingies in the header files so that they follow some kind of plan. And then reduce the number of #includes actually included by adding #ifdefs areound most of them, to prevent redundant #includes. This is a pain, but some say it's worth it in compile time. (See Documentation/HOWTO-CODE.txt for info). * Removed yet another silly struct tm issue. [4-3] * Added FileInstaller to KPilotDaemon. [4-3] * Added DCOP to KPilot. Files dropped on daemon show up in KPilot. [4-3] * Added a #define KPILOT_VERSION to unify all the version strings. [5-3] * Added Documentation/HOWTO-CODE.txt for the source code conventions. [5-3] * Fixed a bunch of Solaris compile issues. [5-3] * Factored out a bunch of generic vcal code from the vcal conduit into a new base class VCalBaseConduit; the todo conduit also inherits from there. [10-3] * Yet another stab at the "latin1 chars munged in KOrganizer" bug. [10-3] The double-sync problem still exists though, which is bad. I suspect that some extra bytes are left waiting in the serial port queue after slotEndSync but I haven't got that sorted out yet. The web-site has been updated, finally, which means you can finally check for new releases and info there again: http://www.slac.com/~pilone/kpilot_home/ And, I've started to use KDevelop 1.4 for maintaining KPilot. I'm still making the transition from vi / make / 4 konsole windows, but so far I've been mostly pleased by the effect it has. Bugs that are still open in the bug database: (Dan? you bored?) * Todo conduit doesn't take due dates into account * Double sync * Address edit window doesn't follow addressDB custom fields & layout Things to think about: * Usability. I've swept all the menu items into one "File" menu that contains two configure wrenches, 4 actions, and a quit button. I'm wondering whether this is the right way to go or whether separate "file", "sync" and "conduit" menu items would be better. KPilot Developer's notes for march 4th 2001 =========================================== So after "the big cleanup" I've continued doing cleanup code in smaller chunks with more commits, mostly for reasons of bug-tracking. Dates in [] indicate when the fix or change was committed. * Removed a really stupid crash from KPilotConfig::fixed(). [23-2] * The internal conduits' names weren't reported properly anymore. This is a binary and source incompatible change. [23-2] * Extra debugging while starting the listener process. [26-2] * Changed exit(-1) to exit(3) in the daemon. [26-2] * Use Qt layout classes in fileInstallWidget. [26-2] * Removed some null-conduit comments from the KNotes conduit. [26-2] * Removed some #include for Solaris. Cleaned up other includes as well, just a little. [26-2] * Started a change to KActions. [ 1-3] * Added a new FileInstaller for use in the daemon and the widget. [ 1-3] It's currently only used by the widget. * Added listItems.{h,cc} in response to bug #21392; changed address and memo widgets to use them. [ 4-3] KPilot Developer's notes for february 19th 2001 =============================================== Yay! KDE 2.1 is out. Which means we can commit all kinds of changes to KPilot again, not just well-thought-out bugfixes. That means that we can get to work on cleaning up the code base again. * Split all the config-file stuff out of KPilotLink into a new class KPilotConfig. Fixed all the resulting include dependencies. * The function fixed() in KPilotInstaller obviously belongs to KPilotConfig. * The {address,memo,fileInstall} widgets all had unnecessary dependencies on KPilotInstaller. Removed. KPilotInstaller now adds the widgets it creates itself. * Removed as many dependencies on kpilot.h and kpilotlink.h as possible. * Removed a bunch of char[] buffer stupidities from pilotLocalDatabase &c. * Removed the database open and close functions from kpilotlink. All the sensible fixes, like those listed under feb. 4th, will come later. KPilot Developer's notes for february 4th 2001 ============================================== Nick Papadonis spent hours tracking down the vcal conduit crash and we found at least one bug in kpilotlink. It's been removed and I hope this quashes all the vcal crashes. Other than that there's simply not much we *can* do with the message and feature freeze and all. This is why the todo-immediately-after-freeze list exists: * Split KPilotLink into its separate functionalities: config management, local database management, and link from daemon to conduits. * Make KPilot and KPilotDaemon communicate only through DCOP. * Add an extra message concerning NULL user on hotsync. * Sort out all the icon issues. * Make the progress bar show something during a conduit sync. KPilot Developer's notes for january 6th 2001 ============================================= Happy Millennium. I ([ade]) am off on a two-week vacation to Calgary, so no KPilot news from me till (almost) february. There have been several troublesome bugreports this week, ranging from "all the conduits crash" to "daemon dies on hotsync." That don't make me happy at all. Done this week: * Built POSE, the Palm Emulator, so this may help in testing stuff for the OS versions that I don't actually have. POSE is a real $#*%^ to build, but I can now actually use my PalmV on-screen (with a PalmIII skin, which is kinda weird). * Replaced the addressEditor widget with something less stone-age. * Added a nifty feature so that you can edit one address in two windows and they keep semi-in-sync. abbrowser doesn't have this (which means abbrowser has a bug :( ). * #&$%#$ conduitApp doesn't turn the GUI on by default, so recent vcal crashes can be blamed on trying to create a KMessageBox without a GUI :( Changed the default values. * Tried fixing some ugly icons. I'm no artist though. * Teeny-tiny layout change in Address page of setup dialog. * If you try to add records to the address book before you've done a HotSync / Backup KPilot has an empty AddressDB and doesn't deal with the address very well. Added a sorry() there. * Added a doTest() to vcal-conduit. * More cleanups in the debugging code. There's still a weird mix of code controlled by --debug and kdebugdialog style stuff. Functions kdWarning() and kdError() should be given __FUNCTION__ as their << argument, while kdDebug() should get fname as first argument. This will make all the debugs optimize away painlessly while keeping the warnings and error messages. Since messages may change status some time there's now a #define TEST_DEBUG that makes fname a weird object that can only be passed to kndbgstreams. So sensible combinations are: production: NDEBUG defined, DEBUG undefined, TEST_DEBUG undefined test nodebug: NDEBUG defined, DEBUG undefined, TEST_DEBUG defined testing: NDEBUG undefined, DEBUG defined, TEST_DEBUG defined * Actually KPilotLink::doFullBackup wasn't all that bad. Still, all the code needs going-over for i18n yuckiness. doFullRestore() was worse; also fixed up directory yuckiness. Note to self: text for user is i18n()ed, kdDebug() &c. is in english ('cause Dan or I have to read it :) ) * Finished integrating Heiko's patches. I believe that both HotSync and FastSync now do what the ought to do. * Started adding a DCOP interface to the daemon. Other stuff: * It's a HotSync and a Pilot. I'll change strings in the source as I come across them. As for conjugations: I HotSynced, it HotSyncs. Todo: * Should just use the KPilotLink::config object to store all kinds of user settings instead of copying them from the config file to local variables, since this is just asking for inconsistency. * Close bug 16457.html in some way. * More vcal work * Clean up more of the butt-ugly parts of the code base (less of this now!) * Tell the KOrganizer docs people about KPilot * KPilot is an i18n nightmare - The const char *s in the pilot databases can be addressed most easily, I think. - get rid of most of the strcpy, strcat, etc. But not all! We're stuck with pilot-link, after all. * The password dialog in the popmail conduit is probably a very bad idea I think tdesud should come into play here. Anyway, a KMail conduit would be much cooler and safer. Sigh. Things-to-be-considered: * Splitting kpilotlink up into its various functionalities KPilot Developer's notes for december 30th 2000 =============================================== Ho ho ho. Merry Christmas. Happy new year. Last week started out with Thomas Zander reporting that he *still* has the totally bizzarre and inexplicable crash in KPilot that he's had ever since KPilot was ported to KDE2 (+). That pretty much colors this week's work. The rest of the week was used for the KNotes conduit. After a pleasant exchange of ideas with Wynn Wilkes (of KNotes) we got a DCOP interface working and this make the KNotes conduit more useful. Talked to Greg about the kab conduit and he's enthusiastic about the possibilities there, we hope to have a framework in CVS soon. Done: * Claimed some debug areas (5510,5511,5512). * KNotes rereads the notes dir after a sync, so new notes (which have come from Pilot memos) appear there. * KNotes conduit --test now displays all the notes (on screen) that knotes shares with the pilot. This is a test (!) of the DCOP stuff, mostly. * KNotes conduit now has a checksum function (md5) to reduce the number of notes that has to be copied between KNotes and the Pilot. * Applied Dag Nygren's vcal patches so that repeating events now show up in KOrganizer properly. * Fixed the button-enabling in the address app * Added more debugging output for Thomas. * Added more debugging output for Nick. Todo: * More vcal work * Clean up more of the butt-ugly parts of the code base * Tell the KOrganizer docs people about KPilot * KPilot is an i18n nightmare - The const char *s in the pilot databases can be addressed most easily, I think. - KPilotLink::doFullBackup should cause i18n people to run away - get rid of most of the strcpy, strcat, etc. But not all! We're stuck with pilot-link, after all. * The messages need validation - Pilot vs pilot, HotSync vs whatever * The password dialog in the popmail conduit is probably a very bad idea + Thomas' crash produces the following (partial) backtrace: #4 0x408960b7 in read_png_image () from /usr/kde2/source/qt-copy/lib/libqt.so.2 #5 0x40838dd9 in QImageIO::read () from /usr/kde2/source/qt-copy/lib/libqt.so.2 #6 0x40836cf1 in QImage::load () from /usr/kde2/source/qt-copy/lib/libqt.so.2 #7 0x408305b2 in QImage::QImage () from /usr/kde2/source/qt-copy/lib/libqt.so.2 #8 0x40483fcf in KIconLoader::loadIcon () from /usr/kde2/lib/libtdecore.so.3 #9 0x805a166 in KPilotInstaller::initIcons () which is weird since the only possible png image being read is the quit icon, which is standard in KDE2. Maybe some weird combo of options? KPilot Developer's notes for december 18th 2000 =============================================== It looks like tdepim and KPilot aren't going to make the 2.1 release. Darn. This does give us more time to deal with docs and bugfixes. Every time I get something done though I find I've discovered two new things to do :(. I hope Lukas will help out with a lot of the i18n stuff though. Done: * Moved all the (english) docs to the correct place. * More doc fixes: use &kpilot; and &pilot; properly, added screen shots for various conduit setups. The docs still aren't complete but they're a darn sight better than they were. * Modal dialogs need exec() instead of show() * Changes in tdelibs caused some dialogs to hang in slotCancel() * Changes in includes means we have to include kdebug.h ourselves * Get rid of cerr and use kdDebug or kdWarning or kdError as appropriate. There are still a very few cerrs left in places where we can't rely on kdDebug(). * Added #ifdef DEBUG to the debug sections of code. So KPilot now compiles without debugging stuff. I realise now that I should have stuck to the KDE kdDebug() guidelines, but, um, I didn't know they existed when the port from KDE1 to KDE2 started. Darn. ToDo: * More vcal work * Clean up more of the butt-ugly parts of the code base * Detect memo-too-large in knotes conduit * Try to reduce number of updates in knotes conduit * Figure out a nice DCOP interface with Wynn (KNotes) * Finally take a look at kab or whatever for the address book conduit. Should probably talk to Greg about this one too. * Tell the KOrganizer docs people about KPilot * Fix the button-enabling in the address app * KPilot is an i18n nightmare - The const char *s in the pilot databases can be addressed most easily, I think. - KPilotLink::doFullBackup should cause i18n people to run away - get rid of most of the strcpy, strcat, etc. But not all! We're stuck with pilot-link, after all. * The messages need validation - Pilot vs pilot, HotSync vs whatever * The password dialog in the popmail conduit is probably a very bad idea KPilot Developer's notes for december 10th 2000 =============================================== Lots of internal stuff going on: * The sense of the debugging flags was the wrong way around, so using --debug 4 gave you all the UI debugging messages as opposed to just the major and minor ones. This is what you get from suggesting debug 1023 all the time. * BaseConduit had some weird debugging output -- not controlled by --debug -- so patched that up. And there was ugliness in the icon loading function. This changes the interface to BaseConduit slightly, 3rd party conduit authors beware. * Finally fixed up the Makefile.ams for the standard conduits so that they run properly (without setting LD_LIBRARY_PATH). Visible changes: * Fixed up the documentation, the screenshots, the descriptions of the conduits, etc. etc. It's still not complete but at least it matches what happens when you run KPilot. Still on the todo-list: * Really fix the vcal conduit. I've patched some things up and once again I hope it works, but since I can't reproduce the error I'm a little stuck here. Still on the wish-list: * Actually *doing* a fast sync for Heiko * More and better information in the progress bar * The PilotMemo class is butt-ugly and filled with weird C-string manipulations. * KPilot should display the sync log as well, just like the Pilot does. This is useful for reporting the result of a sync to the user (who then doesn't need to look at the Pilot) * I noticed Thomas Zander has submitted an official wishlist item: DateBk3 (the new date book format in PalmOS3.5) support. I think I'll get back to him on that when Mirko pans out with the free hardware goodies from Palm :) KPilot Developer's notes for december 2nd 2000 =============================================== Almost Sinterklaas, so I'd like to wish all the KPilot users in .nl a Happy Sinterklaas en Weg met de Kerstman. UI Changes: * Added Heiko's Fast-Sync icon .. but it's ugly and hard to distinguish from the regular icon. This needs fixing by an artist. * Added an ugly restore icon as well. * Added an undocumented config-file option. You can now add the following line to kpilotrc in the null group if you really want to: ToolbarIcons=list where list is a comma-separated list of icons to appear on the KPilot toolbar. You can choose from HotSync,FastSync,Backup and Restore. The standard setting is: ToolbarIcons=HotSync,Backup That's not a lot but it should keep Heiko happy for a while and it reminds us that we should move towards a more modern method of setting up the UI -- or not? * Tried to fix some UI weirdneses like: - Delete Memo button enabled when no memo selected but QListBox has the nasty habit of always having *something* selected, even if you can't see what it is. Now I know that the internal conduits -- memoWidget and addressWidget will probably die out soon when we have a real working kab2 conduit as well as a KNotes conduit, but till then it's nice to have something that at least obeys basic UI design rules. * The following bugs in QListBox and QListView made me ditch the old two column layout with movement buttons for something else. Let me know which one you prefer. - There is some *bizzarre* behavior in the handling of conduits being selected: select the top item in the left column, the top item in the right column (um, so install a conduit first) and then the top item in the left column again. The new layout allows you to drag conduits from one state (available) to another (active). Click on a conduit to set it up -- you may have to doubleclick depending on you KDE settings. Internal Changes: * Conduits that crash no longer hang KPilot and the entire sync. * Made a lot of static const int members of various classes enum values instead, and added a function write() to CStatusMessages for a clean way to write status messages to the link. * Replaced several if else if ... constructions with switch() * Added a sensibleTitle() and shortTitle() to PilotMemo for use by the KNotes conduit (and maybe others) Documentation: * Spent a little time on the (english) documentation and brought a few parts of it back up-to-date. It needs up-to-date URL's, probably we should move the mailing list to kde-pim@kde.org, and we need new screenshots. Wishlist: * More and better information in the progress bar * The PilotMemo class is butt-ugly and filled with weird C-string manipulations. * KPilot should display the sync log as well, just like the Pilot does. This is useful for reporting the result of a sync to the user (who then doesn't need to look at the Pilot) KPilot Developer's notes for november 25th 2000 =============================================== Spent most of the week at a conference, but managed to get the KNotes conduit almost fully functional. New memos (KNotes) are copied to the desktop (Pilot). Memos changed on the pilot are changed on the desktop. However, not all deleted memos are deleted on the other side, nor are modified memos copied from the desktop to the Pilot. I don't know what the desired action for KPilot is in the cases of deleted memos. Any suggestions? There's now a config option in the KNotes conduit setup, but maybe that should be subsumed by the global Local Overrides Pilot setting. Anyway, if a memo is deleted on the Pilot the corresponding KNote is deleted as well. If KNotes is running and the KNotes conduit makes changes, these aren't picked up by KNotes. There are also some obvious race conditions caused by the conduit writing KNotes config files. This basically means that we need to talk to the KNotes maintainer to resolve these coordination problems. As for the code, I wrote this: class KNotesOptions : public setupDialog { Q_OBJECT protected: static const QString KNotesGroup; }; [with better layout, of course] But there's a static QString there, and I read somewhere that Static Objects Are Evil (tm). I could use a const char * there, since it's just the name of a group in the config file, but what's the consensus on things like this? I did handle some more of Heiko's patches. From last week's list: - Some phone number magic I don't understand yet - Some changes in the address import function - getShowPhone() -- don't understand that yet either - Fix bad repeat-n-times handling in vcal-conduit This leaves just the Fast Sync capability still unimplemented. Given the release schedule that has been discussed recently (and we really do want to have KPilot in KDE 2.1, so as to add a nifty feature to the desktop as a whole) I think feature creep should be abandoned for the time being and we should try to fix as many bugs in what we have before the release (around the middle of december, IIRC). This means testing, lots of it. So people, take the plunge, give it a try, compile the latest tdepim CVS stuff with KPilot in it and then complain when your Pilot catches fire, OK? O yeah .. when you *do* give it a try, make sure you do something like: $ export LD_LIBRARY_PATH=$QTDIR/lib: $ kpilot --debug 1023 To make sure none of the conduits crashes with library loading problems and with all the debugging messages turned on. KPilot Developer's notes for november 19th 2000 =============================================== Fixes: * Added most of Heiko's patches to the vcal-conduit * Added convention to conduits --info handling: return "" for no databases. Handled in conduitSetup as well. * Made some minor changes to the info page presented in dialogs (generally the setup dialog of a conduit) so that it gracefully handles weird settings and handles its own resizing properly. * Added some const-qualifiers to various char *s * Add a "kill daemon on exit" feature -- there was already some code for this, but not complete. * Changed all the boolean config entries to booleans as opposed to 0-or-1 ints. * Removed all the "const char * id defined but not used" warnings * Added some extra robustness in PilotDaemon::setupConnections * Made the daemon obey the "show in system tray" setting -- this was broken during the first port to KDE2 * Handle reconfiguration through the settings dialog properly -- at least KPilot picks up the changes to "Kill Daemon on Exit" * (re)Added --test option to conduits, though not all of them will support actual tests. * KNotes conduit is now functional in the sense that notes you write on your desktop are in fact copied to the Pilot. Some general comments: * Suggestion: call the desktop files for conduits conduit-pilot-appname.desktop and the conduit executables themselves conduit-pilot-Appname This at least gives conduits some consistent naming scheme and the addition of -pilot leaves some namespace for conduits for other PDA's. Well, actually this naming scheme isn't much good. But we *do* need to think about how to handle sync-programs for various PDA's in a nice fashion -- I can imagine having a Nokia phone, a Psion and a Pilot and wanting to sync them all. Still on the todo-list: * Fix bad repeat-n-times handling in vcal-conduit * Dealing with the rest of Heiko's patches - Some phone number magic I don't understand yet - Some changes in the address import function - Fast-sync capability (this is different from SyncLast) - getShowPhone() -- don't understand that yet either * More and better information in the progress bar * The PilotMemo class is butt-ugly and filled with weird C-string manipulations. KPilot Developer's notes for november 14th 2000 =============================================== Lots of things have changed in the class hierarchy. * Jorg's bug in the memo-import function was handled OK in addressWidget, but it seemed clumsy to deal with the same problem in two different places. Moved findSelectedCategory() to PilotComponent. Added some other convenience functions there for the category combo box. * The getConfig() change was very poorly done, sorry about that. Added some (semi-) bizarre debugging functions into options.{h,cc} that are #ifdeffed out. * Ditched all the #ifdef KDE2 stuff and dropped the KDE1 backport. * Added a .desktop file for the NULL conduit (with some translations of my own) * Added Qt2 layout code to the address and memo widgets so that they become easier to i18n() (ie. they display properly when the string lengths change). * Adopted some of Heiko's patches: - New feature ForceFirst causes every conduit to behave as if FirstTime=true every time (this is off by default, which matches previous behavior) - New feature SyncLastPC causes a slow sync if the Pilot is synced with a different PC than the last time it was synced (this is on by default, matching old behavior) - "fixed" font in address and memo editor replaced by the user's system preference - In some cases the title (first name+last name or something similar) in an address was empty. This now gives the title [unknown] - Similar for memos Let's sum up the current wishlist: * KNotes conduit * Dealing with the rest of Heiko's patches - Proper multi-day appointments in the vcal conduit - Some phone number magic I don't understand yet - Some changes in the address import function - Fast-sync capability (this is different from SyncLast) - getShowPhone() -- don't understand that yet either These patches are quite useful but it takes a lot of work to unsnarl them, which is why they're taking so long. Developer's notes for november 9th 2000 ======================================= What's new? Lots of little bugs found by code review, some new (trivial?) features. KPilot 4 is in Mandrake cooker so it receives a little more attention now than before. * Jorg Habenicht found a bug in the memo-import function. It causes array-bounds overruns. The same bug was present in many other parts of the memo widget. I think I got them all. * Added some robustness checking in the daemon to cover weird cases like running conduits by hand. * Added better handling of the "first time" dialog in the vcal conduit. * The NULL-conduit now has an extra configuration field "Databases" which you can attach it to. This allows you to do a bogus conduit sync with a database (almost equivalent to putting it in the "backup only" entry of the global KPilot settings, except you run the external conduit. * Made KPilotLink::getConfig return a reference instead of a pointer, to avoid new()ing and delete()ing the config data structure all the time. I hope this increases consistency as well. This has caused lots of little type changes throughout the conduit system, so third-party conduit authors beware :) -- all the changes cause compile failures though. * Jorg brought in a patch so that KPilot uses the pilot-link environment variables to set initial values. Some wishlist-style items: * The memo and address internal conduits are (a) ugly and (b) impossible to i18n properly, because they have hard-coded sizes. Need to spend some time cleaning that up. * Really, it's time to write a conduit that syncs with KNotes. It's not that hard, but KNotes has some silly bugs that need fixing first :( * A patch to introduce a notion of "fast sync" has been produced for KPilot 3.2.1 -- we're now looking into how to integrate that into the KPilot 4.x series. The idea is you only run a sync on the databases you have a conduit for. Developer's notes for october 29th 2000 ======================================= * Thomas Zander pointed out that KPilot doesn't write a config file the first time it is run, leading it to *still* believe it's the first time it's run the next time. Fixed. * In PilotDaemon::setupConnections() things have been reorganized so that a failure on opening the Pilot device will not allow KPilot to start. * Added an undocumented Debug= entry to conduit's configuration, to ease debugging. Conduits will have to read this themselves. * Added a "Run KPilot" menu item to the daemon. And there's some really strange behavior that I've noticed: when I run the setup for an external conduit -- which is a separate process -- KPilot always "jumps in front" of that conduits setup dialog when I give KPilot the focus. This is very irritating. Bugs noted still remaining: * Much weirdness in conduit startup (mode must be set before running the conduit's constructor, but mode wasn't set till after) has been looked at but not repaired. * The vcal-conduit had trouble running a sync the first time (you really should do a backup instead). We're working on this one. Developer's notes for october 26th 2000 ======================================= OK, I admit it: code,commit,announce,test is the *wrong* way to do things. I made some mistakes in the code that looks up conduits in the .desktop files, so conduits *still* won't run with this morning's commits. This has been fixed now, and the conduits run. Of course, vcalconduit just SIGSEGV'ed on me, so ... This brings me to a couple of wishlist items for KPilot: * A "Cancel" button. I just clicked on Backup when I was aiming for HotSync, and there's nothing I can do about it. * A timeout when running conduits so that badly behaved conduits don't hang up the KPilot system. Some other minor issues have been fixed as well: * Boatloads of compiler warnings in the included .xpm files * Some i18n stuff And new questions raised for people who know the code (I'm thinking Preston or Cornelius may be able to explain): * vcal-conduit.cc line 522, what's the purpose of voStatus there? Developer's notes for october 23rd 2000 ======================================= It's been a week where I couldn't bring myself to tackle really big problems, like an address-book conduit for kab or pine. So I sat back and polished things, wandered through the code finding little bugs (if I was an OpenBSD kinda guy I'd call it a proactive code audit). This has led to: A whole slew of minor fixes: * Updated Help menu in main menu bar * Removed superfluous about tab in kpilot setup dialog * Fixed config-doesn't-change bug * Disable autostart-daemon option if .desktop file unavailable * Added quit icon into file menu * Added hotsync and backup icons into file menu * Cleaned up include files in conduitSetup.h * Cleaned up dialog code in conduitSetup.cc for KDE2 compliance * Fixed conduits-not-running-during-sync bug in kpilotlink.cc * Fixed a minor Qt2 incompatibility in messageDialog.cc * Fixed some i18n issues in kpilotlink.cc * Replaced sprintf stuff with QString operations in kpilotlink.cc * Added hot-sync to file menu for consistency (it's in the toolbar) * Added logic in showTitlePage in kpilot.cc to reduce flicker Some remaining issues: * The icon for "About KPilot" in the help menu is the wrong one * We still need pretty icons for various things (like external conduits) Some questions: * Is there a memory leak with the config file in kpilotOptions.cc? * Do we really want to be new() and delete()ing the config file so often? Perhaps getConfig() should do some caching. * Should we add icons for the other menu items? * Is there an entry iterator in TDEConfig so that you can iterate over entries in a certain group (and possibly delete them?) Some philosophical stuff: * Maybe it's time to ditch the internal conduits altogether and work on external conduits for kab and knotes? Although that would still leave the file installer. Maybe a splash of the kpilot logo and then an icon view of what has been dropped into the file installer? As far as I can tell KPilot 4 now has the same functionality and bugs as KPilot 3.2.1 did (with some polishing). So you still have to be careful with KOrganizer. But I think the framework is sufficiently OK to make it worthwhile to really write some conduits for various KDE 2 apps. Like a kab conduit and a knotes conduit.