updates.
[website.git] / docs / toolkit / manual / programming_conv.html
1
2 <html>
3 <head>
4  <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-a" />
5  <meta http-equiv="Content-Language" content="en" />
6  <meta name="description" content="SILC Secure Internet Live Conferencing" />
7  <meta name="keywords" content="SILC, secure, chat, protocol, cipher, encrypt, SKE" />
8  <meta content="INDEX, FOLLOW" name="ROBOTS" />
9  <style type="text/css">
10   <!--
11   body { color: #000000; background: #f0f0f0; font-family: Helvetica, Arial, Sans-serif; }
12   a:link { text-decoration: none; color: #2f488f; }
13   a:visited { text-decoration: none;color: #2f488f; }
14   a:active { text-decoration: none; color: #2f488f; }
15   -->
16  </style>
17 </head>
18
19 <body topmargin="0" leftmargin="0" marginheight="0" marginwidth="0">
20
21 <table border="0" cellspacing="0" cellpadding="6" width="100%">
22  <tr valign="top" bgcolor="#dddddd">
23   <td><small>Copyright &copy; 2001 - 2007 SILC Project<br />
24     <a href="http://silcnet.org">SILC Project Website</a></small></td>
25   <td align="right"><small>
26    <a href="index.html">SILC Toolkit Reference Manual</a><br />
27    <a href="toolkit_index.html">Index</a></small></td>
28    </small></td>
29  </tr>
30 </table>
31 <table border="0" cellspacing="0" cellpadding="0" width="100%">
32 <tr bgcolor="#444444"><td><img src="space.gif" width="1" height="1"border="0" alt="" ></td></tr>
33 </table>
34
35 <table cellpadding="0" cellspacing="0" border="0">
36  <tr valign="top">
37
38   <td width="200" bgcolor="#f0f0f0">
39    <img src="space.gif" width="1" height="1" border="0" alt="">
40    <table width="100%" cellpadding="2" cellspacing="2" border="0">
41     <tr valign="top"><td>
42 <br />
43 <small>
44 <!-- Template file for the big index that appears in the Toolkit reference
45 manual on the left side.  With this file it is possible to add other than
46 automatically generated links to that list. -->
47
48 <a href="index.html"><img src="box.gif" border="0" alt="">SILC Toolkit Reference Manual</a><br />
49
50
51 <a href=silccryptlib.html><img src=box.gif border=0 alt=>SILC Crypto Library</a><br />
52 &nbsp;&nbsp;&nbsp; <a href=silcrng_intro.html><img src=box2.gif border=0 alt=>Introduction to SILC RNG</a><br />
53 &nbsp;&nbsp;&nbsp; <a href=silcrng.html><img src=box2.gif border=0 alt=>SILC RNG Interface</a><br />
54 &nbsp;&nbsp;&nbsp; <a href=silccipher.html><img src=box2.gif border=0 alt=>SILC Cipher API</a><br />
55 &nbsp;&nbsp;&nbsp; <a href=silcpkcs.html><img src=box2.gif border=0 alt=>SILC PKCS API</a><br />
56 &nbsp;&nbsp;&nbsp; <a href=silcpk.html><img src=box2.gif border=0 alt=>SILC Public Key API</a><br />
57 &nbsp;&nbsp;&nbsp; <a href=silcpkcs1.html><img src=box2.gif border=0 alt=>SILC PKCS #1 API</a><br />
58 &nbsp;&nbsp;&nbsp; <a href=silchash.html><img src=box2.gif border=0 alt=>SILC Hash Interface</a><br />
59 &nbsp;&nbsp;&nbsp; <a href=silchmac.html><img src=box2.gif border=0 alt=>SILC HMAC Interface</a><br />
60 <a href=silccorelib.html><img src=box.gif border=0 alt=>SILC Core Library</a><br />
61 &nbsp;&nbsp;&nbsp; <a href=silcauth.html><img src=box2.gif border=0 alt=>SILC Authentication Interface</a><br />
62 &nbsp;&nbsp;&nbsp; <a href=silcmessage.html><img src=box2.gif border=0 alt=>SILC Message Interface</a><br />
63 &nbsp;&nbsp;&nbsp; <a href=silcchannel.html><img src=box2.gif border=0 alt=>SILC Channel Interface</a><br />
64 &nbsp;&nbsp;&nbsp; <a href=silccommand.html><img src=box2.gif border=0 alt=>SILC Command Interface</a><br />
65 &nbsp;&nbsp;&nbsp; <a href=silcnotify.html><img src=box2.gif border=0 alt=>SILC Notify Interface</a><br />
66 &nbsp;&nbsp;&nbsp; <a href=silcstatus.html><img src=box2.gif border=0 alt=>SILC Status Types</a><br />
67 &nbsp;&nbsp;&nbsp; <a href=silcmode.html><img src=box2.gif border=0 alt=>SILC Modes</a><br />
68 &nbsp;&nbsp;&nbsp; <a href=silcid.html><img src=box2.gif border=0 alt=>SILC ID Interface</a><br />
69 &nbsp;&nbsp;&nbsp; <a href=silcargument.html><img src=box2.gif border=0 alt=>SILC Argument Interface</a><br />
70 &nbsp;&nbsp;&nbsp; <a href=silcattrs.html><img src=box2.gif border=0 alt=>SILC Attributes Interface</a><br />
71 &nbsp;&nbsp;&nbsp; <a href=silcpacket.html><img src=box2.gif border=0 alt=>Packet Engine Interface</a><br />
72 &nbsp;&nbsp;&nbsp; <a href=silcpubkey.html><img src=box2.gif border=0 alt=>SILC Public Key Payload Interface</a><br />
73 <a href=silcskelib.html><img src=box.gif border=0 alt=>SILC Key Exchange Library</a><br />
74 &nbsp;&nbsp;&nbsp; <a href=silcske.html><img src=box2.gif border=0 alt=>SILC SKE Interface</a><br />
75 &nbsp;&nbsp;&nbsp; <a href=silcconnauth.html><img src=box2.gif border=0 alt=>SILC Connection Authentication Interface</a><br />
76 <a href=silcvcardlib.html><img src=box.gif border=0 alt=>SILC VCard Library</a><br />
77 &nbsp;&nbsp;&nbsp; <a href=silcvcard.html><img src=box2.gif border=0 alt=>SILC VCard Interface</a><br />
78 <a href=silcmathlib.html><img src=box.gif border=0 alt=>SILC Math Library</a><br />
79 &nbsp;&nbsp;&nbsp; <a href=silcmp.html><img src=box2.gif border=0 alt=>SILC MP Interface</a><br />
80 &nbsp;&nbsp;&nbsp; <a href=silcmath.html><img src=box2.gif border=0 alt=>SILC Math Interface</a><br />
81 <a href=silcclientlib.html><img src=box.gif border=0 alt=>SILC Client Library</a><br />
82 &nbsp;&nbsp;&nbsp; <a href=silcclient_using.html><img src=box2.gif border=0 alt=>Using SILC Client Library Tutorial</a><br />
83 &nbsp;&nbsp;&nbsp; <a href=command_reply_args.html><img src=box2.gif border=0 alt=>Arguments for <b>command_reply</b> Client Operation</a><br />
84 &nbsp;&nbsp;&nbsp; <a href=silcstatus_args.html><img src=box2.gif border=0 alt=>SilcStatus Error Arguments in <b>command_reply</b> Client Operation</a><br />
85 &nbsp;&nbsp;&nbsp; <a href=notifyargs.html><img src=box2.gif border=0 alt=>Arguments for <b>notify</b> Client Operation</a><br />
86 &nbsp;&nbsp;&nbsp; <a href=silcclient_unicode.html><img src=box2.gif border=0 alt=>Unicode and UTF-8 Strings in Client Library</a><br />
87 &nbsp;&nbsp;&nbsp; <a href=silcclient.html><img src=box2.gif border=0 alt=>Client Library Interface Reference</a><br />
88 &nbsp;&nbsp;&nbsp; <a href=silcclient_entry.html><img src=box2.gif border=0 alt=>Client Entry Interface Reference</a><br />
89 <a href=silcasn1lib.html><img src=box.gif border=0 alt=>SILC ASN.1 Library</a><br />
90 &nbsp;&nbsp;&nbsp; <a href=silcasn1.html><img src=box2.gif border=0 alt=>SILC ASN.1 Interface</a><br />
91 &nbsp;&nbsp;&nbsp; <a href=silcber.html><img src=box2.gif border=0 alt=>SILC BER interface</a><br />
92 <a href=silchttplib.html><img src=box.gif border=0 alt=>SILC HTTP Library</a><br />
93 &nbsp;&nbsp;&nbsp; <a href=silchttpserver.html><img src=box2.gif border=0 alt=>SILC HTTP Server Interface</a><br />
94 &nbsp;&nbsp;&nbsp; <a href=silchttpphp.html><img src=box2.gif border=0 alt=>SILC HTTP PHP Translator</a><br />
95 <a href=silcutillib.html><img src=box.gif border=0 alt=>SILC Utility Library</a><br />
96 &nbsp;&nbsp;&nbsp; <a href=silctypes.html><img src=box2.gif border=0 alt=>Basic Types and Definitions</a><br />
97 &nbsp;&nbsp;&nbsp; <a href=silcbuffer.html><img src=box2.gif border=0 alt=>Data Buffer Interface</a><br />
98 &nbsp;&nbsp;&nbsp; <a href=silcbuffmt.html><img src=box2.gif border=0 alt=>Data Buffer Format Interface</a><br />
99 &nbsp;&nbsp;&nbsp; <a href=silchashtable.html><img src=box2.gif border=0 alt=>Hash Table Interface</a><br />
100 &nbsp;&nbsp;&nbsp; <a href=silcmemory.html><img src=box2.gif border=0 alt=>Memory Allocation Interface</a><br />
101 &nbsp;&nbsp;&nbsp; <a href=silcstack.html><img src=box2.gif border=0 alt=>Data Stack (memory pool) Interface</a><br />
102 &nbsp;&nbsp;&nbsp; <a href=silcfsm.html><img src=box2.gif border=0 alt=>Finite State Machine Interface</a><br />
103 &nbsp;&nbsp;&nbsp; <a href=silcthread.html><img src=box2.gif border=0 alt=>Thread Interface</a><br />
104 &nbsp;&nbsp;&nbsp; <a href=silcmutex.html><img src=box2.gif border=0 alt=>Mutual Exclusion Lock Interface</a><br />
105 &nbsp;&nbsp;&nbsp; <a href=silccond.html><img src=box2.gif border=0 alt=>Condition Variable Interface</a><br />
106 &nbsp;&nbsp;&nbsp; <a href=silcatomic.html><img src=box2.gif border=0 alt=>Atomic Operations Interface</a><br />
107 &nbsp;&nbsp;&nbsp; <a href=silcnet.html><img src=box2.gif border=0 alt=>Network (TCP and UDP) Interface</a><br />
108 &nbsp;&nbsp;&nbsp; <a href=silcschedule.html><img src=box2.gif border=0 alt=>Scheduler Interface</a><br />
109 &nbsp;&nbsp;&nbsp; <a href=silcasync.html><img src=box2.gif border=0 alt=>Asynchronous Operation Interface</a><br />
110 &nbsp;&nbsp;&nbsp; <a href=silcstream.html><img src=box2.gif border=0 alt=>Abstract Stream Interface</a><br />
111 &nbsp;&nbsp;&nbsp; <a href=silcsocketstream.html><img src=box2.gif border=0 alt=>Socket Stream Interface</a><br />
112 &nbsp;&nbsp;&nbsp; <a href=silcfdstream.html><img src=box2.gif border=0 alt=>File Descriptor Stream Interface</a><br />
113 &nbsp;&nbsp;&nbsp; <a href=silcfileutil.html><img src=box2.gif border=0 alt=>File Utility Functions</a><br />
114 &nbsp;&nbsp;&nbsp; <a href=silcstrutil.html><img src=box2.gif border=0 alt=>String Utility Interface</a><br />
115 &nbsp;&nbsp;&nbsp; <a href=silcsnprintf.html><img src=box2.gif border=0 alt=>Snprintf Interface</a><br />
116 &nbsp;&nbsp;&nbsp; <a href=silcutf8.html><img src=box2.gif border=0 alt=>UTF-8 String Interface</a><br />
117 &nbsp;&nbsp;&nbsp; <a href=silcstringprep.html><img src=box2.gif border=0 alt=>Stringprep Interface</a><br />
118 &nbsp;&nbsp;&nbsp; <a href=silcutil.html><img src=box2.gif border=0 alt=>Utility Functions</a><br />
119 &nbsp;&nbsp;&nbsp; <a href=silclist.html><img src=box2.gif border=0 alt=>List Interface</a><br />
120 &nbsp;&nbsp;&nbsp; <a href=silcdlist.html><img src=box2.gif border=0 alt=>Dynamic List Interface</a><br />
121 &nbsp;&nbsp;&nbsp; <a href=silcmime.html><img src=box2.gif border=0 alt=>MIME Interface</a><br />
122 &nbsp;&nbsp;&nbsp; <a href=silctime.html><img src=box2.gif border=0 alt=>Time Utility Functions</a><br />
123 &nbsp;&nbsp;&nbsp; <a href=silclog.html><img src=box2.gif border=0 alt=>Logging Interface</a><br />
124 &nbsp;&nbsp;&nbsp; <a href=silcconfig.html><img src=box2.gif border=0 alt=>Config File Interface</a><br />
125 <a href=silcskrlib.html><img src=box.gif border=0 alt=>SILC Key Repository Library</a><br />
126 &nbsp;&nbsp;&nbsp; <a href=silcskr.html><img src=box2.gif border=0 alt=>SILC SKR Interface</a><br />
127 <a href=silcaputillib.html><img src=box.gif border=0 alt=>SILC Application Utility Library</a><br />
128 &nbsp;&nbsp;&nbsp; <a href=silcapputil.html><img src=box2.gif border=0 alt=>SILC Application Utilities</a><br />
129 &nbsp;&nbsp;&nbsp; <a href=silcidcache.html><img src=box2.gif border=0 alt=>SILC ID Cache Interface</a><br />
130 <a href=silcsftplib.html><img src=box.gif border=0 alt=>SILC SFTP Library</a><br />
131 &nbsp;&nbsp;&nbsp; <a href=silcsftp.html><img src=box2.gif border=0 alt=>SILC SFTP Interface</a><br />
132 &nbsp;&nbsp;&nbsp; <a href=silcsftp_fs.html><img src=box2.gif border=0 alt=>SFTP Filesystems Interface</a><br />
133
134 <br />
135 <b>Resource Links</b>
136 <br />
137 <a href="http://silcnet.org"><img src="box.gif" border="0" alt="">SILC Project Website</a><br />
138 <a href="http://silcnet.org/support/documentation/"><img src="box.gif" border="0" alt="">SILC Protocol Documentation</a><br />
139 <a href="http://silcnet.org/support/documentation/wp/"><img src="box.gif" border="0" alt="">SILC White Paper</a><br />
140 <a href="http://silcnet.org/support/faq/"><img src="box.gif" border="0" alt="">SILC FAQs</a><br />
141
142 </small>
143 <br /><br /><br /><br />
144     </td></tr>
145    </table>
146   </td>
147
148   <td bgcolor="#cccccc" background="dot.gif">
149    <img src="space.gif" width="1" height="1" border="0" alt=""></td>
150
151   <td width="720" bgcolor="#ffffff">
152    <img src="space.gif" width="1" height="1" border="0" alt="">
153    <table cellpadding="2" cellspacing="6" width="100%">
154     <tr><td valign="top">
155 <br />
156 <big><b>Programming Conventions</b></big>
157
158 <br />&nbsp;<br />
159 The SILC Toolkit has been programmed with a specific programming style that
160 is consistent across all libraries and interfaces.  The programming style
161 defines for example naming conventions for functions, structures, macros,
162 enumerations, and other constants.
163
164
165 <br />&nbsp;<br />&nbsp;<br />
166 <b>Naming Conventions</b>
167
168 <br />&nbsp;<br />
169 <b>Macros and Defines</b>
170
171 <br />&nbsp;<br />
172 Macros are always capitalised and include underscores to separate words
173 in the name.  All macros start with the "SILC_" prefix.  Example:
174
175 <br />&nbsp;<br />
176 <tt>
177 #define SILC_PACKET_PADLEN(__packetlen, __blocklen)      \<br />
178 &nbsp;&nbsp;SILC_PACKET_DEFAULT_PADLEN - (__packetlen) % \<br />
179 &nbsp;&nbsp;&nbsp;&nbsp;((__blocklen) ? (__blocklen) : SILC_PACKET_DEFAULT_PADLEN)
180 </tt>
181
182 <br />&nbsp;<br />
183 Also other defines (#define) are always capitalised and include 
184 underscores to separate words in the name.  Also all defines start with 
185 the "SILC_" prefix.
186
187 <br />&nbsp;<br />
188 <b>Structures</b>
189
190 <br />&nbsp;<br />
191 All structure names begin with "Silc" prefix, and the name is mixed-case,
192 for example: SilcClientConnection, SilcCommandPayload.  Many of the 
193 structures used in SILC are actually private structures, and application
194 cannot access them directly.  In these cases the structures are forward
195 declared in the public header, and the implementation of the structure
196 is in the source file.  In these case application does not need to know
197 the contents of the structure, and is usually provided with a helper API
198 to access the structure when needed.
199
200 <br />&nbsp;<br />
201 In the most of the cases the forward declaration for a structure is pointer, 
202 for example:
203
204 <br />&nbsp;<br />
205 <tt>typedef struct SilcClientStruct *SilcClient;</tt>
206
207 <br />&nbsp;<br />
208 Application should always use the type defined pointer instead of the
209 actual structure.
210
211 <br />&nbsp;<br />
212 <b>Functions</b>
213
214 <br />&nbsp;<br />
215 Function naming uses the common naming convention used in Toolkit.  All
216 functions are always lowercase and they use underscores.  The name of
217 the function always starts with prefix "silc_".  The name tells what
218 the function do.  The name of a function is constructed from following parts:
219
220 <br />&nbsp;<br />
221 <tt>silc_(module)_(function)</tt>
222
223 <br />&nbsp;<br />
224 The (module) is the library, or interface this functions is part of.  For
225 example: "cipher", "config", "command", "packet", etc.
226
227 <br />&nbsp;<br />
228 The (function) is the description of the functionality of the function.
229 For example: "read", "new_id", "register", "find_by_name", etc.  Examples:
230
231 <br />&nbsp;<br />
232 <tt>
233 silc_server_packet_send<br />
234 silc_server_packet_send_to_channel<br />
235 silc_idcache_del_by_id<br />
236 silc_schedule_init<br />
237 silc_protocol_excute_final<br />
238 silc_buffer_alloc
239 </tt>
240
241 <br />&nbsp;<br />
242 When function registers something the name of the function generally is
243 "silc_function_register" and unregistering is done with
244 "silc_function_unregister".  When function allocates something it
245 is "silc_function_alloc" and when freeing it is
246 "silc_function_free".  Respectively, with init/uninit functions.
247
248 <br />&nbsp;<br />
249 <b>Enumerations</b>
250
251 <br />&nbsp;<br />
252 Enumerations are always capitalised and include underscores to separate
253 words in the name.  All enumerations start with the "SILC_" prefix.  Also,
254 usually all enumerations are type defined to a specific name which can
255 be used as type for the enumeration.  Example:
256
257 <br />&nbsp;<br />
258 <tt>
259 typedef enum {<br />
260 &nbsp;&nbsp;SILC_EXAMPLE_ENUM_NONE,<br />
261 &nbsp;&nbsp;SILC_EXAMPLE_ENUM_LIST,<br />
262 &nbsp;&nbsp;SILC_EXAMPLE_ENUM_STATUS,<br />
263 } SilcExampleEnum;
264 </tt>
265
266 <br />&nbsp;<br />
267 The naming for the type definition for the enumerations follow the
268 normal naming convention; the name starts with "Silc" prefix and the
269 name is mixed-case.
270
271
272 <br />&nbsp;<br />&nbsp;<br />
273 <b>Layout</b>
274
275 <br />&nbsp;<br />
276 <b>Indentation</b>
277
278 <br />&nbsp;<br />
279 The indendation in the source code is 2 characters, and tabulators are
280 not used.  Example piece of code:
281
282 <br />&nbsp;<br />
283 <tt>
284 void silc_client_free(SilcClient client)<br />
285 {<br />
286 &nbsp;&nbsp;if (client) {<br />
287 &nbsp;&nbsp;&nbsp;&nbsp;if (client->rng)<br />
288 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;silc_rng_free(client->rng);<br />
289 &nbsp;&nbsp;&nbsp;&nbsp;silc_free(client);<br />
290 &nbsp;&nbsp;}<br />
291 }
292 </tt>
293
294 <br />&nbsp;<br />
295 <b>Placing Braces</b>
296
297 <br />&nbsp;<br />
298 Generally the braces placing the SILC code follows the K&R style; the
299 opening of the brace is put to the last on the line, and the closing brace
300 is on first on its own line, except for functions.  Examples:
301
302 <br />&nbsp;<br />
303 <tt>
304 if (condition) {<br />
305 &nbsp;&nbsp;silc_something();<br />
306 &nbsp;&nbsp;silc_something_more();<br />
307 }
308 </tt>
309
310 <br />&nbsp;<br />
311 <tt>
312 int silc_client_function()<br />
313 {<br />
314 &nbsp;&nbsp;return 0;<br />
315 }
316 </tt>
317
318 <br />&nbsp;<br />
319 <tt>
320 if (condition) {<br />
321 &nbsp;&nbsp;something;<br />
322 &nbsp;&nbsp;silc_something_more();<br />
323 } else {<br />
324 &nbsp;&nbsp;something_else;<br />
325 }
326 </tt>
327
328 <br />&nbsp;<br />
329 <tt>
330 if (condition) {<br />
331 &nbsp;&nbsp;something;<br />
332 &nbsp;&nbsp;silc_something_more();<br />
333 } else if (other_condition) {<br />
334 &nbsp;&nbsp;something;<br />
335 &nbsp;&nbsp;silc_something_more();<br />
336 } else {<br />
337 &nbsp;&nbsp;something_else;<br />
338 }
339 </tt>
340
341 <br />&nbsp;<br />
342 <b>Header Files</b>
343 <br />&nbsp;<br />
344
345 Standard anti-nesting method is used in the header files to avoid 
346 multiple inclusion of the header file.  Example:
347
348 <br />&nbsp;<br />
349 <tt>
350 #ifndef SILCHEADER_H<br />
351 #define SILCHEADER_H<br />
352 ...<br />
353 #endif /* SILCHEADER_H */
354 </tt>
355
356 <br />&nbsp;<br />
357 All public header files have the "silc" prefix in the filename, for example:
358 silcclient.h, silcprivate.h, silcutil.h.  There are other header files in
359 the Toolkit as well.  Application should not directly include these headers,
360 however if needed it may access them.
361
362 <br />&nbsp;<br />
363 Every header file also includes a copyright notice.
364 <br /><br /><br /><br />
365     </td></tr>
366    </table>
367   </td>
368
369   <td bgcolor="#cccccc" background="dot.gif">
370    <img src="space.gif" width="1" height="1" border="0" alt=""></td>
371
372   <td width="180" bgcolor="#f0f0f0">
373     <img src="space.gif" width="1" height="1" border="0" alt="">
374     <table width="100%" cellpadding="4" cellspacing="0">
375     <tr valign="top"><td>
376 <br />
377 <font face="Helvetica,Arial,Sans-serif" size="1">
378 </font>
379
380 <br /><br /><br /><br />
381     </td></tr>
382     </table>
383   </td>
384 </tr>
385 </table>
386
387 <table border="0" cellspacing="0" cellpadding="0" width="100%">
388 <tr bgcolor="#444444"><td><img src="space.gif" width="1" height="1"border="0" alt="" ></td></tr>
389 </table>
390 <table border="0" cellspacing="0" cellpadding="6" width="100%">
391  <tr valign="top" bgcolor="#dddddd">
392   <td><small>Copyright &copy; 2001 - 2007 SILC Project<br />
393     <a href="http://silcnet.org">SILC Project Website</a></small></td>
394   <td align="right"><small>
395    <a href="index.html">SILC Toolkit Reference Manual</a><br />
396    <a href="toolkit_index.html">Index</a></small></td>
397    </small></td>
398  </tr>
399 </table>
400
401 </body>
402 </html>