Mercurial > pidgin
annotate HACKING @ 1053:864f4aae0b60
[gaim-migrate @ 1063]
i am so smart
i am so smart
s-m-r-t
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Fri, 03 Nov 2000 01:33:28 +0000 |
parents | daad2440a642 |
children | e1408fb04c36 |
rev | line source |
---|---|
639 | 1 A lot of people have tried to hack gaim, but haven't been able to because |
2 the code is just so horrid. Well, the code isn't getting better anytime | |
3 soon, so to help all you would-be hackers help out gaim, here's a brief | |
4 tutorial on how gaim works. I'll quickly describe the logical flow of | |
5 things, then what you'll find in each of the source files. Hopefully | |
6 that's enough to get most of you going. | |
7 | |
708
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
8 If you're going to hack gaim, PLEASE, PLEASE PLEASE PLEASE send patches |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
9 against the absolute latest CVS. I get really annoyed when I get patches |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
10 against the last released version, especially since I don't usually have |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
11 a copy of it on my computer, and gaim tends to change a lot between |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
12 versions. (I sometimes get annoyed when they're against CVS from 3 days |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
13 ago, but can't complain because it's usually my fault that I haven't |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
14 looked at the patch yet.) To get gaim from CVS (if you haven't already), |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
15 run the following commands: |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
16 |
774
b61607d6c2af
[gaim-migrate @ 784]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
749
diff
changeset
|
17 $ export CVSROOT=:pserver:anonymous@cvs.gaim.sourceforge.net:/cvsroot/gaim |
708
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
18 $ cvs login |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
19 (hit enter as the password) |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
20 $ cvs co gaim |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
21 (you'll see it getting all of the files) |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
22 $ cd gaim |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
23 $ ./gen |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
24 |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
25 You'll now have your normal gaim tree with ./configure and all. (If you |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
26 want to make your life really simple, learn how CVS works. CVS is your |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
27 friend.) |
3ff8b997cd37
[gaim-migrate @ 718]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
706
diff
changeset
|
28 |
639 | 29 There's one little thing that's just a pet peeve, and it's really stupid. |
706
a9758452f3c4
[gaim-migrate @ 716]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
684
diff
changeset
|
30 In ./configure there's an --enable-debug option. This does two things: |
639 | 31 compiles with -Wall, and prints debugging information to stdout. The |
32 debugging information is printed to the debug window (which can be turned | |
33 on in the preferences) whether or not --enable-debug was selected. Most | |
34 of the information that's printed is useless anyway though; so the | |
35 --enable-debug option really doesn't do a whole lot. | |
36 | |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
37 This file was last modified by $Author: warmenhoven $ on $Date: 2000-10-31 05:49:53 -0500 (Tue, 31 Oct 2000) $. |
684
b29c92be568b
[gaim-migrate @ 694]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
639
diff
changeset
|
38 |
639 | 39 |
40 PROGRAM FLOW | |
41 ============ | |
42 | |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
43 Before gaim does anything you can see, it initializes itself, which is |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
44 mostly just reading .gaimrc (handled by the functions in gaimrc.c) and |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
45 parsing command-line options. It then draws the login window by calling |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
46 show_login, and waits for input. |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
47 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
48 At the login window, when "Accounts" is clicked, account_editor() is |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
49 called. This then displays all of the users and various information about |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
50 them. If the user clicks the "Signon" button instead, serv_login is called. |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
51 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
52 When the "Sign on/off" button is clicked, serv_login is passed the |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
53 username and the password for the account. If the password length is |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
54 zero (the password field is a character array rather than pointer so |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
55 it will not be NULL) then the Signon callback will prompt for the |
980
82c5865f7cfe
[gaim-migrate @ 990]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
979
diff
changeset
|
56 password before calling serv_login. serv_login then signs in the user |
82c5865f7cfe
[gaim-migrate @ 990]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
979
diff
changeset
|
57 using the appropriate protocol. We'll assume TOC for the rest of this |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
58 discussion; Oscar has a lot of bad hacks to get it working that I don't |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
59 even want to think about. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
60 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
61 After you're signed in (I'll skip that discussion - I doubt many people |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
62 are going to change the login process, since it pretty much just follows |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
63 PROTOCOL), Gaim draws the buddy list by calling show_buddy_list, and |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
64 waits for input from two places: the server and the user. The first place |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
65 it gets input from after signon is usually the server, when the server |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
66 tells Gaim which buddies are signed on. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
67 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
68 When there is information ready to be read from the server, toc_callback |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
69 is called (by GDK) to parse the incoming information. On an UPDATE, |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
70 serv_got_update is called, which takes care of things like notifying |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
71 conversation windows of the update if need be; notifying the plugins; |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
72 and finally, calling set_buddy. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
73 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
74 New connections happen the exact same way as described above. Each aim_user |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
75 can have one gaim_connection associated with it. aim_user and gaim_connection |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
76 both have a protocol field; gaim_connection's should be constant once it is |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
77 set in the appropriate (protocol)_login function. There are lots of details |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
78 that are connected with multiple connections that are best explained by |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
79 reading the code. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
80 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
81 When the user opens a new conversation window, new_conversation is called. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
82 That's easy enough. If there isn't a conversation with the person already |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
83 open (checked by calling find_conversation), show_conv is called to |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
84 create the new window. All sorts of neat things happen there, but it's |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
85 mostly drawing the window. show_conv is the best place to edit the UI. |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
86 |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
87 That's pretty much it for the quick tutorial. I know it wasn't much but |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
88 it's enough to get you started. Make sure you know GTK before you get too |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
89 involved. Most of the back-end stuff is pretty basic; most of gaim is GTK. |
639 | 90 |
91 | |
92 SOURCE FILES | |
93 ============ | |
94 | |
95 about.c: | |
96 Not much to say here, just a few basic functions. | |
97 | |
98 aim.c: | |
99 This is where the main() function is. It takes care of a lot of the | |
100 initialization stuff, and showing the login window. It's pretty tiny | |
101 and there's not really much to edit in it. Watch out for bad Oscar | |
102 sign in hacks. | |
103 | |
104 away.c: | |
105 This takes care of most of the away stuff: setting the away message | |
106 (do_im_away); coming back (do_im_back); drawing the away window; | |
107 etc. To be honest I haven't looked at this file in months. | |
108 | |
109 browser.c: | |
110 Code for opening a browser window. Most of the code is trying to deal | |
111 with Netscape. The most important function here is open_url. Have fun. | |
112 | |
113 buddy.c: | |
114 This takes care of not only nearly everything buddy-related (the buddy | |
115 list, the permit/deny lists, and the window), but also a lot of the | |
116 code flow and util functions. Look for good things like find_buddy, | |
117 set_buddy, and signoff() here. | |
118 | |
119 buddy_chat.c: | |
120 This takes care of the buddy chat stuff. This used to be a lot bigger | |
121 until the chat and IM windows got merged in the code. Now it mostly | |
122 just takes care of chat-specific stuff, like ignoring people and | |
123 keeping track of who's in the room. This is also where the chat window | |
124 is created. | |
125 | |
126 conversation.c: | |
127 This is where most of the functions dealing with the IM and chat windows | |
128 are hidden. It tries to abstract things as much as possible, but doesn't | |
129 do a very good job. This is also where things like "Enter sends" and | |
130 "Ctrl-{B/I/U/S}" options get carried out (look for send_callback). The | |
131 chat and IM toolbar (with the B/I/U/S buttons) are both built from the | |
132 same function, build_conv_toolbar. | |
133 | |
134 dialogs.c: | |
135 A massive file with a lot of little utility functions. This is where | |
136 all of those little dialog windows are created. Things like the warn | |
137 dialog and the add buddy dialog are here. Not all of the dialogs in | |
138 gaim are in this file, though. But most of them are. This is also | |
139 where do_import is housed, to import buddy lists. | |
140 | |
141 gaimrc.c: | |
142 This controls everything about the .gaimrc file. There's not really much | |
143 to say about it; this is probably one of the better designed and easier | |
144 to follow files in gaim. The important functions are towards the bottom. | |
145 | |
146 gnome_applet_mgr.c: | |
147 A hideous creation from the days before I started working on gaim. Most | |
148 of it works, but it has functionsLikeThis. I hate looking at this | |
149 file, but I'm too lazy to change the functions. The best functions | |
150 are things like set_applet_draw_open, whose sole purpose is to set a | |
749
94edd99b7302
[gaim-migrate @ 759]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
708
diff
changeset
|
151 global variable to TRUE. [ note 8/22/00 - I finally changed this file. ] |
639 | 152 |
153 gtkhtml.c: | |
154 This is really just one big hack. It started off as an HTML widget that | |
155 was written for Gnome as far as I can tell. The current version is | |
156 huge, requires way too many libs, and is too hard to upgrade to. But | |
157 we've managed to hack this poor old version into basically what we | |
158 need it for. I recommend not looking at this file if you want to save | |
159 your sanity. | |
160 | |
161 gtkticker.c: | |
162 Syd, our resident GTK God, wrote a GtkWidget, GtkTicker. This is that | |
163 widget. It's cool, and it's tiny. | |
164 | |
165 html.c: | |
166 Don't ask my why this is called html.c. Most of it is just grab_url, | |
167 which does like the name says; it downloads a URL to show in the | |
168 GtkHTML widget. http.c would be a more appropriate name, but that's OK. | |
169 | |
170 idle.c: | |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
171 This file used to be entirely #if 0'd out of existance. However, thanks |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
172 to some very generous people who submitted patches, this takes care of |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
173 reporting idle time (imagine that). It's a pretty straight-forward file. |
639 | 174 |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
175 multi.c: |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
176 This is the file that tries to take care of most of the major issues |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
177 with multiple connections. The best function in here by far is the |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
178 account_editor(). auto_login() is also in here (I'm just reading |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
179 multi.h now...); auto_login has problems. Someone please fix it. |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
180 account_editor is really the only function that the UI needs to be |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
181 concerned with. If you want to remove multiconnectivity from gaim, |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
182 all you would really need to do is comment out any lines that make |
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
183 reference to this function (there are only two - one in aim.c and one |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
184 in buddy.c). Or you could just run ./configure --disable-multi. |
979
ae6d13c11570
[gaim-migrate @ 989]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
960
diff
changeset
|
185 |
639 | 186 network.c: |
187 This has two functions: get_address and connect_address, both of which | |
188 call proxy functions. If you want to see how these are used, look at | |
189 toc.c and/or rvous.c. These are really just front-ends to the proxy | |
190 stuff; use these instead of calling the proxy functions. | |
191 | |
192 oscar.c: | |
193 One big hack of copied code. This is supposed to be the libfaim tie-in | |
194 in gaim. Most of it is just copied straight from faimtest, the small | |
195 program that comes with libfaim. I'm not even sure how half of it works, | |
196 if that makes you feel any better. | |
197 | |
198 perl.c: | |
199 This was basically copied straight from X-Chat through the power of | |
200 the GPL. Perl is the biggest, most confusing piece of C code I've ever | |
201 seen in my life (and keep in mind I'm a gaim hacker). I have a basic | |
202 idea of what's going on in it, but I couldn't tell you exactly. The | |
203 top half sets up perl and tells it what's going on and the bottom half | |
204 implements the AIM module. | |
205 | |
206 plugins.c: | |
207 This is the "plugin plug", as the file states. This file is probably | |
208 the only file in all of gaim that at the top has all of the functions | |
209 and global and static variables named out for you. It makes reading | |
210 it a little easier, but not by much. A lot of the code in here deals | |
211 with the plugin window rather than the plugins themselves. | |
212 | |
213 prefs.c: | |
214 The important function in here is build_prefs, but the most useful | |
215 function is gaim_button. build_prefs draws the window, and calls | |
216 gaim_button probably 30 or 40 times. (I don't really wanna run grep | |
217 | wc to count.) This is where you add the toggle button for gaim | |
218 preferences. It's very simple, and if you look at a couple of the | |
219 calls to gaim_button you'll figure it out right away. | |
220 | |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
221 prpl.c: |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
222 This file is what lets gaim dynamically load protocols, sort of. All of |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
223 the actual dlopen(), dlsym() stuff is in plugins.c. But this contains |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
224 all of the functions that the protocol plugin needs to call, and manages |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
225 all of the protocols. It's a pretty simple file actually. |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
226 |
639 | 227 proxy.c: |
228 This is where the bulk of the actual networking code is done. The big | |
229 function here is proxy_connect, which will connect through the proxy | |
230 setup you've chosen (most of which don't work...) or just regularly. | |
231 | |
232 rvous.c: | |
233 This was originally going to be the stuff for all of the Buddy Icon | |
234 and Voice Chat stuff, but I got really sick of protocol hacking really | |
235 quick. Now it only houses the file transfer stuff, which only works | |
236 for TOC. | |
237 | |
238 server.c: | |
239 This is where all of the differentiation between TOC and Oscar is | |
240 done. Nearly everything that's network related goes through here | |
241 at one point or another. This has good things like serv_send_im and | |
242 serv_got_update. Most of it should be pretty self-explanatory. | |
243 | |
244 sound.c: | |
1038
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
245 The main function in this file is play_sound, which plays one of 8 |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
246 (maybe 9?) sounds based on preferences. All that the rest of the |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
247 code should have to do is call play_sound(BUDDY_ARRIVE), for example, |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
248 and this file will take care of determining if a sound should be played |
daad2440a642
[gaim-migrate @ 1048]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
980
diff
changeset
|
249 and which file should be played. |
639 | 250 |
251 ticker.c: | |
252 Syd is just so cool. I really can't get over it. He let me come | |
253 visit him at Netscape one day, and I got to see all of their toys | |
254 (don't worry, I'm under an NDA). Anyway, this file is for the buddy | |
255 ticker. This is also a damn cool file because it's got all of the | |
256 functions that you'd want right up at the top. Someday I want to be | |
257 as cool as Syd. | |
258 | |
259 toc.c: | |
260 This handles everything TOC-related, including parsing gaim's buddy | |
261 list. Most of this file is toc_callback, which parses the incoming | |
262 information from the server. I really don't like TOC though. | |
263 | |
264 util.c: | |
265 There's not really a lot of cohesion to this file; it's just a lot of | |
266 stuff that happened to be thrown into it for no apparent reason. None | |
267 of it is particularly tasty; it's all just utility functions. Just | |
268 like the name says. | |
269 | |
270 | |
271 So that's our little tour of the internals of Gaim. It's really not | |
272 difficult to figure out if you've spent any time with GTK. I'm looking | |
273 forward to getting all of your patches :) |