Sun, 17 Oct 2004 23:55:49 +0000
[gaim-migrate @ 11141]
Two things:
a. Added Enter as a gtk_binding to GtkIMHtml. This fixes everything.
Input methods now work. The "Enter sends" and "Ctrl-Enter sends" preferences
were removed and defaulted to yes and no respectively, BUT, in a very super-cool
turn of events, you can now add your own bindings to .gtkrc to make WHATEVER
YOU WANT send. Awesome. Someone should use g_signal_accumulator_true_handled
or something to make profiles and away messages able to insert newlines.
b. Removed "Use multi-colored screennames in chats," defaulted to yes, and
wrote a nifty algorithm to automatically adjust the colors to accomodate the
background (see http://gaim.sf.net/sean/porn-chat.png). People should play
around and tweak it a bit. The algorithm takes into consideration the
luminosity of the current background and the base hue to use for the screenname
in generating the new colors. Note that it does this while maintaining the hues.
Someone should optimize this so it skips over the floating point arithmatic when
the background color is white.
| 8231 | 1 | /** |
| 2 | * @file network.h Network API | |
| 3 | * @ingroup core | |
| 4 | * | |
| 5 | * gaim | |
| 6 | * | |
| 7 | * Gaim is the legal property of its developers, whose names are too numerous | |
| 8 | * to list here. Please refer to the COPYRIGHT file distributed with this | |
| 9 | * source distribution. | |
| 10 | * | |
| 11 | * This program is free software; you can redistribute it and/or modify | |
| 12 | * it under the terms of the GNU General Public License as published by | |
| 13 | * the Free Software Foundation; either version 2 of the License, or | |
| 14 | * (at your option) any later version. | |
| 15 | * | |
| 16 | * This program is distributed in the hope that it will be useful, | |
| 17 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 18 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 19 | * GNU General Public License for more details. | |
| 20 | * | |
| 21 | * You should have received a copy of the GNU General Public License | |
| 22 | * along with this program; if not, write to the Free Software | |
| 23 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
| 24 | */ | |
| 25 | #ifndef _GAIM_NETWORK_H_ | |
| 26 | #define _GAIM_NETWORK_H_ | |
| 27 | ||
| 28 | #ifdef __cplusplus | |
| 29 | extern "C" { | |
| 30 | #endif | |
| 31 | ||
| 32 | /**************************************************************************/ | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
33 | /** @name Network API */ |
| 8231 | 34 | /**************************************************************************/ |
| 35 | /*@{*/ | |
| 36 | ||
| 37 | /** | |
|
8838
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
38 | * Converts a dot-decimal IP address to an array of unsigned |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
39 | * chars. For example, converts 192.168.0.1 to a 4 byte |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
40 | * array containing 192, 168, 0 and 1. |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
41 | * |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
42 | * @param ip An IP address in dot-decimal notiation. |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
43 | * @return An array of 4 bytes containing an IP addresses |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
44 | * equivalent to the given parameter, or NULL if |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
45 | * the given IP address is invalid. This value |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
46 | * is statically allocated and should not be |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
47 | * freed. |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
48 | */ |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
49 | const unsigned char *gaim_network_ip_atoi(const char *ip); |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
50 | |
|
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
51 | /** |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
52 | * Sets the IP address of the local system in preferences. This |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
53 | * is the IP address that should be used for incoming connections |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
54 | * (file transfer, direct IM, etc.) and should therefore be |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
55 | * publicly accessible. |
| 8231 | 56 | * |
| 57 | * @param ip The local IP address. | |
| 58 | */ | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
59 | void gaim_network_set_public_ip(const char *ip); |
| 8231 | 60 | |
| 61 | /** | |
| 62 | * Returns the IP address of the local system set in preferences. | |
| 63 | * | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
64 | * This returns the value set via gaim_network_set_public_ip(). |
|
8838
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
65 | * You probably want to use gaim_network_get_my_ip() instead. |
| 8231 | 66 | * |
| 67 | * @return The local IP address set in preferences. | |
| 68 | */ | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
69 | const char *gaim_network_get_public_ip(void); |
| 8231 | 70 | |
| 71 | /** | |
| 72 | * Returns the IP address of the local system. | |
| 73 | * | |
|
8838
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
74 | * You probably want to use gaim_network_get_my_ip() instead. |
| 8231 | 75 | * |
| 76 | * @note The returned string is a pointer to a static buffer. If this | |
| 77 | * function is called twice, it may be important to make a copy | |
| 78 | * of the returned string. | |
| 79 | * | |
| 80 | * @param fd The fd to use to help figure out the IP, or else -1. | |
| 81 | * @return The local IP address. | |
| 82 | */ | |
| 83 | const char *gaim_network_get_local_system_ip(int fd); | |
| 84 | ||
| 85 | /** | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
86 | * Returns the IP address that should be used anywhere a |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
87 | * public IP addresses is needed (listening for an incoming |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
88 | * file transfer, etc). |
| 8231 | 89 | * |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
90 | * If the user has manually specified an IP address via |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
91 | * preferences, then this IP is returned. Otherwise the |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
92 | * IP address returned by gaim_network_get_local_system_ip() |
|
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
93 | * is returned. |
| 8231 | 94 | * |
| 95 | * @note The returned string is a pointer to a static buffer. If this | |
| 96 | * function is called twice, it may be important to make a copy | |
| 97 | * of the returned string. | |
| 98 | * | |
| 99 | * @param fd The fd to use to help figure out the IP, or -1. | |
| 100 | * @return The local IP address to be used. | |
| 101 | */ | |
|
8838
c23227da7b4a
[gaim-migrate @ 9604]
Mark Doliner <markdoliner@pidgin.im>
parents:
8834
diff
changeset
|
102 | const char *gaim_network_get_my_ip(int fd); |
| 8231 | 103 | |
| 104 | /** | |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
105 | * Attempts to open a listening port ONLY on the specified port number. |
|
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
106 | * You probably want to use gaim_network_listen_range() instead of this. |
|
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
107 | * This function is useful, for example, if you wanted to write a telnet |
|
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
108 | * server as a Gaim plugin, and you HAD to listen on port 23. Why anyone |
|
8248
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
109 | * would want to do that is beyond me. |
| 8231 | 110 | * |
| 111 | * This opens a listening port. The caller will want to set up a watcher | |
| 112 | * of type GAIM_INPUT_READ on the returned fd. It will probably call | |
| 113 | * accept in the callback, and then possibly remove the watcher and close | |
| 114 | * the listening socket, and add a new watcher on the new socket accept | |
| 115 | * returned. | |
| 116 | * | |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
117 | * @param port The port number to bind to. Must be greater than 0. |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
118 | * |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
119 | * @return The file descriptor of the listening socket, or -1 if |
|
8240
2e5f97ed575d
[gaim-migrate @ 8963]
Mark Doliner <markdoliner@pidgin.im>
parents:
8239
diff
changeset
|
120 | * no socket could be established. |
| 8231 | 121 | */ |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
122 | int gaim_network_listen(unsigned short port); |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
123 | |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
124 | /** |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
125 | * Opens a listening port selected from a range of ports. The range of |
|
8248
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
126 | * ports used is chosen in the following manner: |
|
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
127 | * If a range is specified in preferences, these values are used. |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
128 | * If a non-0 values are passed to the function as parameters, these |
|
8248
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
129 | * values are used. |
|
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
130 | * Otherwise a port is chosen at random by the kernel. |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
131 | * |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
132 | * This opens a listening port. The caller will want to set up a watcher |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
133 | * of type GAIM_INPUT_READ on the returned fd. It will probably call |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
134 | * accept in the callback, and then possibly remove the watcher and close |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
135 | * the listening socket, and add a new watcher on the new socket accept |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
136 | * returned. |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
137 | * |
|
8248
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
138 | * @param start The port number to bind to, or 0 to pick a random port. |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
139 | * Users are allowed to override this arg in prefs. |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
140 | * @param end The highest possible port in the range of ports to listen on, |
|
8248
47da4fbe1a17
[gaim-migrate @ 8971]
Mark Doliner <markdoliner@pidgin.im>
parents:
8246
diff
changeset
|
141 | * or 0 to pick a random port. Users are allowed to override this |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
142 | * arg in prefs. |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
143 | * |
|
8246
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
144 | * @return The file descriptor of the listening socket, or -1 if |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
145 | * no socket could be established. |
|
c83c0421149a
[gaim-migrate @ 8969]
Mark Doliner <markdoliner@pidgin.im>
parents:
8240
diff
changeset
|
146 | */ |
|
8250
e855dcce1fa0
[gaim-migrate @ 8973]
Mark Doliner <markdoliner@pidgin.im>
parents:
8248
diff
changeset
|
147 | int gaim_network_listen_range(unsigned short start, unsigned short end); |
| 8231 | 148 | |
| 149 | /** | |
| 150 | * Gets a port number from a file descriptor. | |
| 151 | * | |
| 152 | * @param fd The file descriptor. This should be a tcp socket. The current | |
| 153 | * implementation probably dies on anything but IPv4. Perhaps this | |
| 154 | * possible bug will inspire new and valuable contributors to Gaim. | |
| 155 | * @return The port number, in host byte order. | |
| 156 | */ | |
|
8834
0a798e3d2b84
[gaim-migrate @ 9598]
Mark Doliner <markdoliner@pidgin.im>
parents:
8250
diff
changeset
|
157 | unsigned short gaim_network_get_port_from_fd(int fd); |
| 8231 | 158 | |
| 159 | /** | |
| 160 | * Initializes the network subsystem. | |
| 161 | */ | |
| 162 | void gaim_network_init(void); | |
| 163 | ||
| 164 | /*@}*/ | |
| 165 | ||
| 166 | #ifdef __cplusplus | |
| 167 | } | |
| 168 | #endif | |
| 169 | ||
| 170 | #endif /* _GAIM_NETWORK_H_ */ |