TODO

Mon, 09 Jan 2006 04:42:25 +0000

author
Etan Reisner <deryni@pidgin.im>
date
Mon, 09 Jan 2006 04:42:25 +0000
changeset 12773
1f635f83d71f
parent 12680
eae090e4bf7c
child 12928
b7048c35521b
permissions
-rw-r--r--

[gaim-migrate @ 15120]
Some whitespace stuff so it doesn't clutter up later commits.

10881
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
1 * conversation api {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
2 * need to handle: {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
3 * unnamed chats
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
4 * chats with the same name as a buddy
11451
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
5 * this should be working now, but it needs to be kept in mind when (re-)designing
10881
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
6 * jabber Messages (one off messages vrs a conversation with a backlog)
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
7 * multiple conversations with a single buddy (jabber, with thread tag)
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
8 * bugs
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
9 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
10 * notes: {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
11 * (12:58:39) Robot101: user list always|auto|never
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
12 * topic only where supported by the protocol
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
13 * how do we log this? {{{
11451
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
14 * rlaager's (NEW) proposal: {{{
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
15 * each conversation has 1 or more logs associated with it.
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
16 * when someone joins, a new log is opened
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
17 * file based loggers should try to use hard-links in a smart way
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
18 to avoid duplicating data on disk as much as possible...
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
19 * this needs to be designed in such a way that a database logger
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
20 can handle it w/o duplication...
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
21 * TO SOLVE THESE CONCERNS, a link and/or copy function callback
913688d25a67 [gaim-migrate @ 13690]
Richard Laager <rlaager@pidgin.im>
parents: 11415
diff changeset
22 will likely need to be added
10881
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
23 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
24 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
25 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
26 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
27 * buddy list {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
28 * we have not committed any gobjectification, so this is not a blocker for 2.0.0 until we do.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
29 * if we do, it is only a blocker to the extent that gaim needs to run. That is, we do not
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
30 *necessarily* have to gobjectifiy everything as long as we preserve functionality.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
31 * That being said, my understanding of the signals mess says that it is probly more work to
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
32 try to do this in stages than to start it or not start it.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
33 * This would require some sort of signal aggregation, as gobject signals are unique to the instance.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
34 * one way to do this would be to emit the signals from a non-descript buddy object. this would
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
35 most closely mimic the current functionality
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
36 * a second way would be to actually try to aggregate them in some way. I really don't know how
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
37 possible this is, but it would allow us to do things like set a pounce on everyone in a group
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
38 or define sounds on a per-group basis.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
39 * we could look at replacing the UI ops with signals/call backs
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
40 * bugs
11415
d18a0837434d [gaim-migrate @ 13652]
Luke Schierer <lschiere@pidgin.im>
parents: 10891
diff changeset
41 * wrong buddy given priority
10881
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
42 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
43 * build targets {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
44 * this is not a blocker
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
45 * we need build targets for libgaim, we need to test them, and make sure they work.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
46 * we ought to use our own build targets to build the executable itself.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
47 * due to the limitations of cvs, this cannot accompany moving files to other directories at this time.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
48 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
49 * status {{{
12680
eae090e4bf7c [gaim-migrate @ 15023]
Luke Schierer <lschiere@pidgin.im>
parents: 11451
diff changeset
50 * Error messages aren't particularly usable currently. we need to be able to see the full text of
eae090e4bf7c [gaim-migrate @ 15023]
Luke Schierer <lschiere@pidgin.im>
parents: 11451
diff changeset
51 the error, and what account is in that error condition.
eae090e4bf7c [gaim-migrate @ 15023]
Luke Schierer <lschiere@pidgin.im>
parents: 11451
diff changeset
52 * No way to see accounts not in the global state.
eae090e4bf7c [gaim-migrate @ 15023]
Luke Schierer <lschiere@pidgin.im>
parents: 11451
diff changeset
53 * Easier access to saved states is needed.
10881
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
54 }}}
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
55 * Privacy {{{
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
56 * this is not a blocker for 2.0.0
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
57 * Privacy sucks. it doesn't handle many of the protocols in a way that users understand. notably
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
58 msn, but also yahoo, jabber, and icq.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
59 * We want to sync to the server as much as possible, entirely local-only privacy is not an option
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
60 except on protocols like irc that have no server-side.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
61 * We want to be as consistent across protocols as possible. this will require renaming things on
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
62 some protocols.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
63 * Bleeter suggests that we create a privacy.xml, remove privacy from blist.xml. He suggests
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
64 that each protocol define certain capabilities & defaults, with accounts.xml holding exceptions
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
65 to the defaults.
cfc21ca20abd [gaim-migrate @ 12577]
Luke Schierer <lschiere@pidgin.im>
parents:
diff changeset
66 }}}
10885
64824dc5ee02 [gaim-migrate @ 12583]
Luke Schierer <lschiere@pidgin.im>
parents: 10881
diff changeset
67 * Perl {{{
10886
2d798c8853a0 [gaim-migrate @ 12584]
Luke Schierer <lschiere@pidgin.im>
parents: 10885
diff changeset
68 * Block for 2.0.0 or remove perl:
11415
d18a0837434d [gaim-migrate @ 13652]
Luke Schierer <lschiere@pidgin.im>
parents: 10891
diff changeset
69 * Extended testing and resolving the inevitable bugs remains.
10886
2d798c8853a0 [gaim-migrate @ 12584]
Luke Schierer <lschiere@pidgin.im>
parents: 10885
diff changeset
70 * Test each call to make sure it actually works
2d798c8853a0 [gaim-migrate @ 12584]
Luke Schierer <lschiere@pidgin.im>
parents: 10885
diff changeset
71 * Make it work with G_MODULE_BIND_LOCAL
10885
64824dc5ee02 [gaim-migrate @ 12583]
Luke Schierer <lschiere@pidgin.im>
parents: 10881
diff changeset
72 }}}
10891
b52569a32997 [gaim-migrate @ 12599]
Luke Schierer <lschiere@pidgin.im>
parents: 10890
diff changeset
73 * Prefs {{{
12680
eae090e4bf7c [gaim-migrate @ 15023]
Luke Schierer <lschiere@pidgin.im>
parents: 11451
diff changeset
74 * on upgrade from 1.x, the timestamp preference often gets lost.
10891
b52569a32997 [gaim-migrate @ 12599]
Luke Schierer <lschiere@pidgin.im>
parents: 10890
diff changeset
75 }}}
b52569a32997 [gaim-migrate @ 12599]
Luke Schierer <lschiere@pidgin.im>
parents: 10890
diff changeset
76

mercurial