| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | All modules must have at least the following: | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | static int load_module(): | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | 	Do what you need to do when you get started.  This function can return | 
					
						
							| 
									
										
										
										
											2007-09-20 19:05:16 +00:00
										 |  |  | AST_MODULE_LOAD_FAILURE if an action fails and the module is prevented from loading, | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | AST_MODULE_LOAD_DECLINE if the module can not load because of a non-critical failure | 
					
						
							|  |  |  | (the configuration file was not found), or AST_MODULE_LOAD_SUCCESS if the module | 
					
						
							|  |  |  | loaded fine. | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | static int unload_module(): | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	The module will soon be unloaded.  If any channels are using your | 
					
						
							|  |  |  | features, you should give them a softhangup in an effort to keep the | 
					
						
							|  |  |  | program from crashing.  Generally, unload_module is only called when the | 
					
						
							|  |  |  | usecount is 0 or less, but the user can force unloading at their | 
					
						
							| 
									
										
										
										
											2004-02-15 07:48:46 +00:00
										 |  |  | discretion, and thus a module should do its best to comply (although in | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | some cases there may be no way to avoid a crash).  This function should | 
					
						
							|  |  |  | return 0 on success and non-zero on failure (i.e. it cannot yet be | 
					
						
							|  |  |  | unloaded). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | AST_MODULE_INFO_STANDARD(keystr, desc); | 
					
						
							| 
									
										
										
										
											1999-10-19 01:52:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-23 16:41:18 +00:00
										 |  |  | keystr: Applicable license for module. In most cases this is ASTERISK_GPL_KEY. | 
					
						
							|  |  |  | desc: Description of module. |