[Freeswitch-svn] [commit] r9810 - in freeswitch/trunk/src/mod/languages/mod_managed: . managed

Freeswitch SVN mikej at freeswitch.org
Fri Oct 3 14:05:38 EDT 2008


Author: mikej
Date: Fri Oct  3 14:05:37 2008
New Revision: 9810

Modified:
   freeswitch/trunk/src/mod/languages/mod_managed/freeswitch_wrap.cxx
   freeswitch/trunk/src/mod/languages/mod_managed/managed/swig.cs

Log:
reswig mod_managed

Modified: freeswitch/trunk/src/mod/languages/mod_managed/freeswitch_wrap.cxx
==============================================================================
--- freeswitch/trunk/src/mod/languages/mod_managed/freeswitch_wrap.cxx	(original)
+++ freeswitch/trunk/src/mod/languages/mod_managed/freeswitch_wrap.cxx	Fri Oct  3 14:05:37 2008
@@ -1,6 +1,6 @@
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  * 
  * This file is not intended to be easily readable and contains a number of 
  * coding conventions designed to improve portability and efficiency. Do not make
@@ -71,6 +71,12 @@
 # endif
 #endif
 
+#ifndef SWIG_MSC_UNSUPPRESS_4505
+# if defined(_MSC_VER)
+#   pragma warning(disable : 4505) /* unreferenced local function has been removed */
+# endif 
+#endif
+
 #ifndef SWIGUNUSEDPARM
 # ifdef __cplusplus
 #   define SWIGUNUSEDPARM(p)
@@ -195,7 +201,7 @@
 
 static void SWIGUNUSED SWIG_CSharpSetPendingException(SWIG_CSharpExceptionCodes code, const char *msg) {
   SWIG_CSharpExceptionCallback_t callback = SWIG_csharp_exceptions[SWIG_CSharpApplicationException].callback;
-  if (code >=0 && (size_t)code < sizeof(SWIG_csharp_exceptions)/sizeof(SWIG_CSharpException_t)) {
+  if ((size_t)code < sizeof(SWIG_csharp_exceptions)/sizeof(SWIG_CSharpException_t)) {
     callback = SWIG_csharp_exceptions[code].callback;
   }
   callback(msg);
@@ -203,7 +209,7 @@
 
 static void SWIGUNUSED SWIG_CSharpSetPendingExceptionArgument(SWIG_CSharpExceptionArgumentCodes code, const char *msg, const char *param_name) {
   SWIG_CSharpExceptionArgumentCallback_t callback = SWIG_csharp_exceptions_argument[SWIG_CSharpArgumentException].callback;
-  if (code >=0 && (size_t)code < sizeof(SWIG_csharp_exceptions_argument)/sizeof(SWIG_CSharpExceptionArgument_t)) {
+  if ((size_t)code < sizeof(SWIG_csharp_exceptions_argument)/sizeof(SWIG_CSharpExceptionArgument_t)) {
     callback = SWIG_csharp_exceptions_argument[code].callback;
   }
   callback(msg, param_name);
@@ -283,7 +289,6 @@
   char *result = 0 ;
   
   result = (char *) "27880";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -294,7 +299,6 @@
   char *result = 0 ;
   
   result = (char *) ".1.3.6.1.4.1.27880";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -305,7 +309,6 @@
   char *result = 0 ;
   
   result = (char *) "543";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -316,7 +319,6 @@
   int result;
   
   result = (int) 1;
-  
   jresult = result; 
   return jresult;
 }
@@ -327,7 +329,6 @@
   int result;
   
   result = (int) 1;
-  
   jresult = result; 
   return jresult;
 }
@@ -338,7 +339,6 @@
   char *result = 0 ;
   
   result = (char *) "\0";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -349,7 +349,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -360,7 +359,6 @@
   char result;
   
   result = (char) 'H';
-  
   jresult = result; 
   return jresult;
 }
@@ -371,7 +369,6 @@
   char *result = 0 ;
   
   result = (char *) "H";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -382,7 +379,6 @@
   char result;
   
   result = (char) '1';
-  
   jresult = result; 
   return jresult;
 }
@@ -393,7 +389,6 @@
   char *result = 0 ;
   
   result = (char *) "1";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -404,7 +399,6 @@
   char *result = 0 ;
   
   result = (char *) "K";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -415,7 +409,6 @@
   char result;
   
   result = (char) '2';
-  
   jresult = result; 
   return jresult;
 }
@@ -426,7 +419,6 @@
   char result;
   
   result = (char) 'J';
-  
   jresult = result; 
   return jresult;
 }
@@ -437,7 +429,6 @@
   char *result = 0 ;
   
   result = (char *) "2J";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -448,7 +439,6 @@
   char *result = 0 ;
   
   result = (char *) ";";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -459,7 +449,6 @@
   char *result = 0 ;
   
   result = (char *) "m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -470,7 +459,6 @@
   char *result = 0 ;
   
   result = (char *) "30";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -481,7 +469,6 @@
   char *result = 0 ;
   
   result = (char *) "31";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -492,7 +479,6 @@
   char *result = 0 ;
   
   result = (char *) "32";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -503,7 +489,6 @@
   char *result = 0 ;
   
   result = (char *) "33";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -514,7 +499,6 @@
   char *result = 0 ;
   
   result = (char *) "34";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -525,7 +509,6 @@
   char *result = 0 ;
   
   result = (char *) "35";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -536,7 +519,6 @@
   char *result = 0 ;
   
   result = (char *) "36";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -547,7 +529,6 @@
   char *result = 0 ;
   
   result = (char *) "37";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -558,7 +539,6 @@
   char *result = 0 ;
   
   result = (char *) "40";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -569,7 +549,6 @@
   char *result = 0 ;
   
   result = (char *) "41";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -580,7 +559,6 @@
   char *result = 0 ;
   
   result = (char *) "42";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -591,7 +569,6 @@
   char *result = 0 ;
   
   result = (char *) "43";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -602,7 +579,6 @@
   char *result = 0 ;
   
   result = (char *) "44";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -613,7 +589,6 @@
   char *result = 0 ;
   
   result = (char *) "45";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -624,7 +599,6 @@
   char *result = 0 ;
   
   result = (char *) "46";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -635,7 +609,6 @@
   char *result = 0 ;
   
   result = (char *) "47";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -646,7 +619,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[30m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -657,7 +629,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[31m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -668,7 +639,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[32m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -679,7 +649,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[33m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -690,7 +659,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[34m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -701,7 +669,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[35m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -712,7 +679,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[36m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -723,7 +689,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[37m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -734,7 +699,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[40m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -745,7 +709,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[41m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -756,7 +719,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[42m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -767,7 +729,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[43m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -778,7 +739,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[44m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -789,7 +749,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[45m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -800,7 +759,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[46m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -811,7 +769,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[47m";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -822,7 +779,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[H";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -833,7 +789,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[1";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -844,7 +799,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[K";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -855,7 +809,6 @@
   char *result = 0 ;
   
   result = (char *) "\33[2J\33[H";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -866,7 +819,6 @@
   int result;
   
   result = (int) 2000;
-  
   jresult = result; 
   return jresult;
 }
@@ -877,7 +829,6 @@
   int result;
   
   result = (int) 192000;
-  
   jresult = result; 
   return jresult;
 }
@@ -888,7 +839,6 @@
   char *result = 0 ;
   
   result = (char *) "/";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -899,7 +849,6 @@
   char *result = 0 ;
   
   result = (char *) "://";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -910,7 +859,6 @@
   char *result = 0 ;
   
   result = (char *) "bypass_media_after_bridge";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -921,7 +869,6 @@
   char *result = 0 ;
   
   result = (char *) "read_result";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -932,7 +879,6 @@
   char *result = 0 ;
   
   result = (char *) "copy_xml_cdr";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -943,7 +889,6 @@
   char *result = 0 ;
   
   result = (char *) "current_application";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -954,7 +899,6 @@
   char *result = 0 ;
   
   result = (char *) "proto_specific_hangup_cause";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -965,7 +909,6 @@
   char *result = 0 ;
   
   result = (char *) "execute_on_answer";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -976,7 +919,6 @@
   char *result = 0 ;
   
   result = (char *) "execute_on_ring";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -987,7 +929,6 @@
   char *result = 0 ;
   
   result = (char *) "call_timeout";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -998,7 +939,6 @@
   char *result = 0 ;
   
   result = (char *) "holding_uuid";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1009,7 +949,6 @@
   char *result = 0 ;
   
   result = (char *) "api_after_bridge";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1020,7 +959,6 @@
   char *result = 0 ;
   
   result = (char *) "api_hangup_hook";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1031,7 +969,6 @@
   char *result = 0 ;
   
   result = (char *) "process_cdr";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1042,7 +979,6 @@
   char *result = 0 ;
   
   result = (char *) "bridge_channel";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1053,7 +989,6 @@
   char *result = 0 ;
   
   result = (char *) "channel_name";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1064,7 +999,6 @@
   char *result = 0 ;
   
   result = (char *) "bridge_uuid";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1075,7 +1009,6 @@
   char *result = 0 ;
   
   result = (char *) "continue_on_fail";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1086,7 +1019,16 @@
   char *result = 0 ;
   
   result = (char *) "playback_terminators";
+  jresult = SWIG_csharp_string_callback((const char *)result); 
+  return jresult;
+}
+
+
+SWIGEXPORT char * SWIGSTDCALL CSharp_SWITCH_PLAYBACK_TERMINATOR_USED_get() {
+  char * jresult ;
+  char *result = 0 ;
   
+  result = (char *) "playback_terminator_used";
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1097,7 +1039,6 @@
   char *result = 0 ;
   
   result = (char *) "cache_speech_handles";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1108,7 +1049,6 @@
   char *result = 0 ;
   
   result = (char *) "__cache_speech_handles_obj__";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1119,7 +1059,6 @@
   char *result = 0 ;
   
   result = (char *) "bypass_media";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1130,7 +1069,6 @@
   char *result = 0 ;
   
   result = (char *) "proxy_media";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1141,7 +1079,6 @@
   char *result = 0 ;
   
   result = (char *) "endpoint_disposition";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1152,7 +1089,6 @@
   char *result = 0 ;
   
   result = (char *) "hold_music";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1163,7 +1099,6 @@
   char *result = 0 ;
   
   result = (char *) "export_vars";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1174,7 +1109,6 @@
   char *result = 0 ;
   
   result = (char *) "switch_r_sdp";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1185,7 +1119,6 @@
   char *result = 0 ;
   
   result = (char *) "switch_l_sdp";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1196,7 +1129,6 @@
   char *result = 0 ;
   
   result = (char *) "switch_m_sdp";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1207,7 +1139,6 @@
   char *result = 0 ;
   
   result = (char *) "bridge_to";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1218,7 +1149,6 @@
   char *result = 0 ;
   
   result = (char *) "signal_bridge_to";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1229,7 +1159,6 @@
   char *result = 0 ;
   
   result = (char *) "signal_bond";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1240,7 +1169,6 @@
   char *result = 0 ;
   
   result = (char *) "originator";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1251,7 +1179,6 @@
   char *result = 0 ;
   
   result = (char *) "originator_codec";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1262,7 +1189,6 @@
   char *result = 0 ;
   
   result = (char *) "local_media_ip";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1273,7 +1199,6 @@
   char *result = 0 ;
   
   result = (char *) "local_media_port";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1284,7 +1209,6 @@
   char *result = 0 ;
   
   result = (char *) "remote_media_ip";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1295,7 +1219,6 @@
   char *result = 0 ;
   
   result = (char *) "remote_media_port";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1306,7 +1229,6 @@
   char *result = 0 ;
   
   result = (char *) "remote_video_ip";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1317,7 +1239,6 @@
   char *result = 0 ;
   
   result = (char *) "remote_video_port";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1328,7 +1249,6 @@
   char *result = 0 ;
   
   result = (char *) "local_video_ip";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1339,7 +1259,6 @@
   char *result = 0 ;
   
   result = (char *) "local_video_port";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1350,7 +1269,6 @@
   char *result = 0 ;
   
   result = (char *) "hangup_after_bridge";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1361,7 +1279,6 @@
   char *result = 0 ;
   
   result = (char *) "exec_after_bridge_app";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1372,7 +1289,6 @@
   char *result = 0 ;
   
   result = (char *) "exec_after_bridge_arg";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1383,7 +1299,6 @@
   char *result = 0 ;
   
   result = (char *) "max_forwards";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1394,7 +1309,6 @@
   char *result = 0 ;
   
   result = (char *) "disable_app_log";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1405,7 +1319,6 @@
   char *result = 0 ;
   
   result = (char *) "speech";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1416,7 +1329,6 @@
   char *result = 0 ;
   
   result = (char *) "uuid_bridge";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -1427,7 +1339,6 @@
   int result;
   
   result = (int) 8;
-  
   jresult = result; 
   return jresult;
 }
@@ -1440,7 +1351,6 @@
   arg1 = (switch_dtmf_t *)jarg1; 
   arg2 = (char)jarg2; 
   if (arg1) (arg1)->digit = arg2;
-  
 }
 
 
@@ -1463,7 +1373,6 @@
   arg1 = (switch_dtmf_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->duration = arg2;
-  
 }
 
 
@@ -1494,7 +1403,6 @@
   
   arg1 = (switch_dtmf_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -1505,7 +1413,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t *)jarg2; 
   if (arg1) (arg1)->buf = arg2;
-  
 }
 
 
@@ -1528,7 +1435,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->buflen = arg2;
-  
 }
 
 
@@ -1551,7 +1457,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t *)jarg2; 
   if (arg1) (arg1)->cur = arg2;
-  
 }
 
 
@@ -1574,7 +1479,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->bytes = arg2;
-  
 }
 
 
@@ -1597,7 +1501,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->bits_tot = arg2;
-  
 }
 
 
@@ -1620,7 +1523,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->bits_cur = arg2;
-  
 }
 
 
@@ -1643,7 +1545,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->bits_rem = arg2;
-  
 }
 
 
@@ -1666,7 +1567,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->frame_bits = arg2;
-  
 }
 
 
@@ -1689,7 +1589,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->shiftby = arg2;
-  
 }
 
 
@@ -1712,7 +1611,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->this_byte = arg2;
-  
 }
 
 
@@ -1735,7 +1633,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->under = arg2;
-  
 }
 
 
@@ -1758,7 +1655,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_byte_t)jarg2; 
   if (arg1) (arg1)->over = arg2;
-  
 }
 
 
@@ -1781,7 +1677,6 @@
   arg1 = (switch_bitpack_t *)jarg1; 
   arg2 = (switch_bitpack_mode_t)jarg2; 
   if (arg1) (arg1)->mode = arg2;
-  
 }
 
 
@@ -1812,7 +1707,6 @@
   
   arg1 = (switch_bitpack_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -2131,7 +2025,6 @@
   
   arg1 = (switch_directories *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -2140,7 +2033,6 @@
   
   arg1 = (switch_directories *)jarg1; 
   SWITCH_GLOBAL_dirs = *arg1;
-  
 }
 
 
@@ -2159,7 +2051,6 @@
   int result;
   
   result = (int) 32;
-  
   jresult = result; 
   return jresult;
 }
@@ -2170,7 +2061,16 @@
   int result;
   
   result = (int) 240*1024;
+  jresult = result; 
+  return jresult;
+}
+
+
+SWIGEXPORT int SWIGSTDCALL CSharp_SWITCH_SYSTEM_THREAD_STACKSIZE_get() {
+  int jresult ;
+  int result;
   
+  result = (int) 8192*1024;
   jresult = result; 
   return jresult;
 }
@@ -2181,7 +2081,6 @@
   int result;
   
   result = (int) 120;
-  
   jresult = result; 
   return jresult;
 }
@@ -2192,7 +2091,6 @@
   int result;
   
   result = (int) 10;
-  
   jresult = result; 
   return jresult;
 }
@@ -2203,7 +2101,6 @@
   int result;
   
   result = (int) 32;
-  
   jresult = result; 
   return jresult;
 }
@@ -2214,7 +2111,6 @@
   int result;
   
   result = (int) 2;
-  
   jresult = result; 
   return jresult;
 }
@@ -2225,7 +2121,6 @@
   int result;
   
   result = (int) (2*32*(120+10));
-  
   jresult = result; 
   return jresult;
 }
@@ -2236,7 +2131,6 @@
   int result;
   
   result = (int) 50;
-  
   jresult = result; 
   return jresult;
 }
@@ -2247,7 +2141,6 @@
   int result;
   
   result = (int) 30;
-  
   jresult = result; 
   return jresult;
 }
@@ -2258,7 +2151,6 @@
   int result;
   
   result = (int) 100000;
-  
   jresult = result; 
   return jresult;
 }
@@ -2269,7 +2161,6 @@
   int result;
   
   result = (int) 1024*8;
-  
   jresult = result; 
   return jresult;
 }
@@ -2280,7 +2171,6 @@
   int result;
   
   result = (int) 13;
-  
   jresult = result; 
   return jresult;
 }
@@ -2293,7 +2183,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->version = arg2;
-  
 }
 
 
@@ -2316,7 +2205,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->p = arg2;
-  
 }
 
 
@@ -2339,7 +2227,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->x = arg2;
-  
 }
 
 
@@ -2362,7 +2249,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->cc = arg2;
-  
 }
 
 
@@ -2385,7 +2271,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->m = arg2;
-  
 }
 
 
@@ -2408,7 +2293,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->pt = arg2;
-  
 }
 
 
@@ -2431,7 +2315,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->seq = arg2;
-  
 }
 
 
@@ -2454,7 +2337,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->ts = arg2;
-  
 }
 
 
@@ -2477,7 +2359,6 @@
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->ssrc = arg2;
-  
 }
 
 
@@ -2508,7 +2389,6 @@
   
   arg1 = (switch_rtp_hdr_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -2519,7 +2399,6 @@
   arg1 = (switch_input_args_t *)jarg1; 
   arg2 = (switch_input_callback_function_t)jarg2; 
   if (arg1) (arg1)->input_callback = arg2;
-  
 }
 
 
@@ -2542,7 +2421,6 @@
   arg1 = (switch_input_args_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->buf = arg2;
-  
 }
 
 
@@ -2565,7 +2443,6 @@
   arg1 = (switch_input_args_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->buflen = arg2;
-  
 }
 
 
@@ -2588,7 +2465,6 @@
   arg1 = (switch_input_args_t *)jarg1; 
   arg2 = (switch_read_frame_callback_function_t)jarg2; 
   if (arg1) (arg1)->read_frame_callback = arg2;
-  
 }
 
 
@@ -2611,7 +2487,6 @@
   arg1 = (switch_input_args_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->user_data = arg2;
-  
 }
 
 
@@ -2642,7 +2517,6 @@
   
   arg1 = (switch_input_args_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -2651,7 +2525,6 @@
   int result;
   
   result = (int) 1;
-  
   jresult = result; 
   return jresult;
 }
@@ -2664,7 +2537,6 @@
   arg1 = (switch_loadable_module_function_table_t *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->switch_api_version = arg2;
-  
 }
 
 
@@ -2687,7 +2559,6 @@
   arg1 = (switch_loadable_module_function_table_t *)jarg1; 
   arg2 = (switch_module_load_t)jarg2; 
   if (arg1) (arg1)->load = arg2;
-  
 }
 
 
@@ -2710,7 +2581,6 @@
   arg1 = (switch_loadable_module_function_table_t *)jarg1; 
   arg2 = (switch_module_shutdown_t)jarg2; 
   if (arg1) (arg1)->shutdown = arg2;
-  
 }
 
 
@@ -2733,7 +2603,6 @@
   arg1 = (switch_loadable_module_function_table_t *)jarg1; 
   arg2 = (switch_module_runtime_t)jarg2; 
   if (arg1) (arg1)->runtime = arg2;
-  
 }
 
 
@@ -2764,7 +2633,6 @@
   
   arg1 = (switch_loadable_module_function_table_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -3057,7 +2925,6 @@
   int result;
   
   result = (int) 0;
-  
   jresult = result; 
   return jresult;
 }
@@ -3068,7 +2935,6 @@
   int result;
   
   result = (int) 1;
-  
   jresult = result; 
   return jresult;
 }
@@ -3079,7 +2945,6 @@
   int result;
   
   result = (int) 2;
-  
   jresult = result; 
   return jresult;
 }
@@ -3090,7 +2955,6 @@
   int result;
   
   result = (int) 3;
-  
   jresult = result; 
   return jresult;
 }
@@ -3101,7 +2965,6 @@
   int result;
   
   result = (int) 4;
-  
   jresult = result; 
   return jresult;
 }
@@ -3112,7 +2975,6 @@
   int result;
   
   result = (int) 5;
-  
   jresult = result; 
   return jresult;
 }
@@ -3123,7 +2985,6 @@
   int result;
   
   result = (int) 6;
-  
   jresult = result; 
   return jresult;
 }
@@ -3134,7 +2995,6 @@
   int result;
   
   result = (int) 7;
-  
   jresult = result; 
   return jresult;
 }
@@ -3145,7 +3005,6 @@
   int result;
   
   result = (int) 8;
-  
   jresult = result; 
   return jresult;
 }
@@ -3156,7 +3015,6 @@
   int result;
   
   result = (int) 9;
-  
   jresult = result; 
   return jresult;
 }
@@ -3167,7 +3025,6 @@
   int result;
   
   result = (int) 10;
-  
   jresult = result; 
   return jresult;
 }
@@ -3178,7 +3035,6 @@
   int result;
   
   result = (int) 11;
-  
   jresult = result; 
   return jresult;
 }
@@ -3189,7 +3045,6 @@
   int result;
   
   result = (int) 12;
-  
   jresult = result; 
   return jresult;
 }
@@ -3200,7 +3055,6 @@
   int result;
   
   result = (int) 13;
-  
   jresult = result; 
   return jresult;
 }
@@ -3211,7 +3065,6 @@
   int result;
   
   result = (int) 14;
-  
   jresult = result; 
   return jresult;
 }
@@ -3222,7 +3075,6 @@
   int result;
   
   result = (int) 15;
-  
   jresult = result; 
   return jresult;
 }
@@ -3233,7 +3085,6 @@
   int result;
   
   result = (int) 16;
-  
   jresult = result; 
   return jresult;
 }
@@ -3244,7 +3095,6 @@
   int result;
   
   result = (int) 17;
-  
   jresult = result; 
   return jresult;
 }
@@ -3255,7 +3105,6 @@
   int result;
   
   result = (int) 18;
-  
   jresult = result; 
   return jresult;
 }
@@ -3266,7 +3115,6 @@
   int result;
   
   result = (int) 19;
-  
   jresult = result; 
   return jresult;
 }
@@ -3277,7 +3125,6 @@
   int result;
   
   result = (int) 20;
-  
   jresult = result; 
   return jresult;
 }
@@ -3288,7 +3135,6 @@
   int result;
   
   result = (int) 21;
-  
   jresult = result; 
   return jresult;
 }
@@ -3299,7 +3145,6 @@
   int result;
   
   result = (int) 22;
-  
   jresult = result; 
   return jresult;
 }
@@ -3310,7 +3155,6 @@
   int result;
   
   result = (int) 23;
-  
   jresult = result; 
   return jresult;
 }
@@ -3321,7 +3165,6 @@
   int result;
   
   result = (int) 24;
-  
   jresult = result; 
   return jresult;
 }
@@ -3332,7 +3175,6 @@
   int result;
   
   result = (int) 25;
-  
   jresult = result; 
   return jresult;
 }
@@ -3343,7 +3185,6 @@
   int result;
   
   result = (int) 26;
-  
   jresult = result; 
   return jresult;
 }
@@ -3354,7 +3195,6 @@
   int result;
   
   result = (int) 100;
-  
   jresult = result; 
   return jresult;
 }
@@ -3365,7 +3205,6 @@
   int result;
   
   result = (int) 101;
-  
   jresult = result; 
   return jresult;
 }
@@ -3515,7 +3354,6 @@
   int result;
   
   result = (int) 128;
-  
   jresult = result; 
   return jresult;
 }
@@ -3526,7 +3364,6 @@
   int result;
   
   result = (int) 128;
-  
   jresult = result; 
   return jresult;
 }
@@ -3539,7 +3376,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->mms = arg2;
-  
 }
 
 
@@ -3562,7 +3398,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->ms = arg2;
-  
 }
 
 
@@ -3585,7 +3420,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->sec = arg2;
-  
 }
 
 
@@ -3608,7 +3442,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->min = arg2;
-  
 }
 
 
@@ -3631,7 +3464,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->hr = arg2;
-  
 }
 
 
@@ -3654,7 +3486,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->day = arg2;
-  
 }
 
 
@@ -3677,7 +3508,6 @@
   arg1 = (switch_core_time_duration *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->yr = arg2;
-  
 }
 
 
@@ -3708,7 +3538,6 @@
   
   arg1 = (switch_core_time_duration *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -3779,7 +3608,6 @@
   arg1 = (switch_app_log *)jarg1; 
   arg2 = (switch_app_log *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -3810,7 +3638,6 @@
   
   arg1 = (switch_app_log *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -3851,7 +3678,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (switch_core_session_message_types_t)jarg2; 
   if (arg1) (arg1)->message_id = arg2;
-  
 }
 
 
@@ -3874,7 +3700,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->numeric_arg = arg2;
-  
 }
 
 
@@ -3932,7 +3757,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->string_arg_size = arg2;
-  
 }
 
 
@@ -3943,7 +3767,7 @@
   
   arg1 = (switch_core_session_message *)jarg1; 
   result =  ((arg1)->string_arg_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -3955,7 +3779,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->pointer_arg = arg2;
-  
 }
 
 
@@ -3984,7 +3807,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->pointer_arg_size = arg2;
-  
 }
 
 
@@ -3995,7 +3817,7 @@
   
   arg1 = (switch_core_session_message *)jarg1; 
   result =  ((arg1)->pointer_arg_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -4007,7 +3829,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->numeric_reply = arg2;
-  
 }
 
 
@@ -4066,7 +3887,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->string_reply_size = arg2;
-  
 }
 
 
@@ -4077,7 +3897,7 @@
   
   arg1 = (switch_core_session_message *)jarg1; 
   result =  ((arg1)->string_reply_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -4089,7 +3909,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->pointer_reply = arg2;
-  
 }
 
 
@@ -4118,7 +3937,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->pointer_reply_size = arg2;
-  
 }
 
 
@@ -4129,7 +3947,7 @@
   
   arg1 = (switch_core_session_message *)jarg1; 
   result =  ((arg1)->pointer_reply_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -4141,7 +3959,6 @@
   arg1 = (switch_core_session_message *)jarg1; 
   arg2 = (switch_core_session_message_flag_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -4172,7 +3989,6 @@
   
   arg1 = (switch_core_session_message *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -4183,7 +3999,6 @@
   arg1 = (switch_core_thread_session *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->running = arg2;
-  
 }
 
 
@@ -4206,7 +4021,6 @@
   arg1 = (switch_core_thread_session *)jarg1; 
   arg2 = (switch_mutex_t *)jarg2; 
   if (arg1) (arg1)->mutex = arg2;
-  
 }
 
 
@@ -4255,7 +4069,6 @@
   arg1 = (switch_core_thread_session *)jarg1; 
   arg2 = (switch_input_callback_function_t)jarg2; 
   if (arg1) (arg1)->input_callback = arg2;
-  
 }
 
 
@@ -4278,7 +4091,6 @@
   arg1 = (switch_core_thread_session *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->pool = arg2;
-  
 }
 
 
@@ -4309,7 +4121,6 @@
   
   arg1 = (switch_core_thread_session *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -4321,8 +4132,8 @@
   time_t arg4 ;
   switch_media_bug_flag_t arg5 ;
   switch_media_bug_t **arg6 = (switch_media_bug_t **) 0 ;
-  switch_status_t result;
   time_t *argp4 ;
+  switch_status_t result;
   
   arg1 = (switch_core_session_t *)jarg1; 
   arg2 = (switch_media_bug_callback_t)jarg2; 
@@ -4751,8 +4562,8 @@
   char *arg2 = (char *) 0 ;
   char *arg3 = (char *) 0 ;
   int arg4 ;
-  void *result = 0 ;
   switch_size_t *argp1 ;
+  void *result = 0 ;
   
   argp1 = (switch_size_t *)jarg1; 
   if (!argp1) {
@@ -4776,8 +4587,8 @@
   char *arg3 = (char *) 0 ;
   char *arg4 = (char *) 0 ;
   int arg5 ;
-  void *result = 0 ;
   switch_size_t *argp2 ;
+  void *result = 0 ;
   
   arg1 = (switch_memory_pool_t *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -4802,8 +4613,8 @@
   char *arg3 = (char *) 0 ;
   char *arg4 = (char *) 0 ;
   int arg5 ;
-  void *result = 0 ;
   switch_size_t *argp2 ;
+  void *result = 0 ;
   
   arg1 = (switch_core_session_t *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -4964,7 +4775,7 @@
   switch_size_t result;
   
   result = switch_core_session_id();
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -6208,7 +6019,6 @@
   char *result = 0 ;
   
   result = (char *) "core";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -6710,8 +6520,8 @@
   switch_management_action_t arg2 ;
   char *arg3 = (char *) 0 ;
   switch_size_t arg4 ;
-  switch_status_t result;
   switch_size_t *argp4 ;
+  switch_status_t result;
   
   arg1 = (char *)jarg1; 
   arg2 = (switch_management_action_t)jarg2; 
@@ -6793,7 +6603,7 @@
   switch_time_t result;
   
   result = switch_core_uptime();
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -6936,7 +6746,7 @@
   switch_time_t result;
   
   result = switch_timestamp_now();
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -6978,29 +6788,47 @@
   
   arg1 = (time_t *)jarg1; 
   result = switch_timestamp(arg1);
-  jresult = new time_t((time_t &)result); 
+  jresult = new time_t((const time_t &)result); 
   return jresult;
 }
 
 
-SWIGEXPORT void SWIGSTDCALL CSharp_switch_load_network_lists(int jarg1) {
-  switch_bool_t arg1 ;
-  
-  arg1 = (switch_bool_t)jarg1; 
-  switch_load_network_lists(arg1);
-}
-
-
-SWIGEXPORT int SWIGSTDCALL CSharp_switch_check_network_list_ip_token(char * jarg1, char * jarg2, void * jarg3) {
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_strftime_tz(char * jarg1, char * jarg2, char * jarg3, unsigned long jarg4) {
   int jresult ;
   char *arg1 = (char *) 0 ;
   char *arg2 = (char *) 0 ;
-  char **arg3 = (char **) 0 ;
-  switch_bool_t result;
+  char *arg3 = (char *) 0 ;
+  size_t arg4 ;
+  switch_status_t result;
   
   arg1 = (char *)jarg1; 
   arg2 = (char *)jarg2; 
-  arg3 = (char **)jarg3; 
+  arg3 = (char *)jarg3; 
+  arg4 = (size_t)jarg4; 
+  result = (switch_status_t)switch_strftime_tz((char const *)arg1,(char const *)arg2,arg3,arg4);
+  jresult = result; 
+  return jresult;
+}
+
+
+SWIGEXPORT void SWIGSTDCALL CSharp_switch_load_network_lists(int jarg1) {
+  switch_bool_t arg1 ;
+  
+  arg1 = (switch_bool_t)jarg1; 
+  switch_load_network_lists(arg1);
+}
+
+
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_check_network_list_ip_token(char * jarg1, char * jarg2, void * jarg3) {
+  int jresult ;
+  char *arg1 = (char *) 0 ;
+  char *arg2 = (char *) 0 ;
+  char **arg3 = (char **) 0 ;
+  switch_bool_t result;
+  
+  arg1 = (char *)jarg1; 
+  arg2 = (char *)jarg2; 
+  arg3 = (char **)jarg3; 
   result = (switch_bool_t)switch_check_network_list_ip_token((char const *)arg1,(char const *)arg2,(char const **)arg3);
   jresult = result; 
   return jresult;
@@ -7063,12 +6891,25 @@
 }
 
 
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_system(char * jarg1, int jarg2) {
+  int jresult ;
+  char *arg1 = (char *) 0 ;
+  switch_bool_t arg2 ;
+  int result;
+  
+  arg1 = (char *)jarg1; 
+  arg2 = (switch_bool_t)jarg2; 
+  result = (int)switch_system((char const *)arg1,arg2);
+  jresult = result; 
+  return jresult;
+}
+
+
 SWIGEXPORT int SWIGSTDCALL CSharp_SWITCH_CMD_CHUNK_LEN_get() {
   int jresult ;
   int result;
   
   result = (int) 1024;
-  
   jresult = result; 
   return jresult;
 }
@@ -7084,8 +6925,8 @@
   switch_stream_handle_t *arg1 = (switch_stream_handle_t *) 0 ;
   uint8_t *arg2 = (uint8_t *) 0 ;
   switch_size_t arg3 ;
-  switch_status_t result;
   switch_size_t *argp3 ;
+  switch_status_t result;
   
   arg1 = (switch_stream_handle_t *)jarg1; 
   arg2 = (uint8_t *)jarg2; 
@@ -7106,7 +6947,6 @@
   int result;
   
   result = (int) 32767;
-  
   jresult = result; 
   return jresult;
 }
@@ -7117,7 +6957,6 @@
   int result;
   
   result = (int) -32768;
-  
   jresult = result; 
   return jresult;
 }
@@ -7141,9 +6980,9 @@
   switch_size_t arg2 ;
   unsigned char *arg3 = (unsigned char *) 0 ;
   switch_size_t arg4 ;
-  switch_status_t result;
   switch_size_t *argp2 ;
   switch_size_t *argp4 ;
+  switch_status_t result;
   
   arg1 = (unsigned char *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -7170,8 +7009,8 @@
   char *arg1 = (char *) 0 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (char *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -7182,7 +7021,7 @@
   }
   arg3 = *argp3; 
   result = switch_b64_decode(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -7192,8 +7031,8 @@
   char *arg1 = (char *) 0 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  char *result = 0 ;
   switch_size_t *argp3 ;
+  char *result = 0 ;
   
   arg1 = (char *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -7226,8 +7065,8 @@
   int arg1 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (int)jarg1; 
   arg2 = (char *)jarg2; 
@@ -7238,7 +7077,7 @@
   }
   arg3 = *argp3; 
   result = switch_fd_read_line(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -7265,9 +7104,9 @@
   switch_size_t arg2 ;
   sockaddr *arg3 = (sockaddr *) 0 ;
   socklen_t arg4 ;
-  char *result = 0 ;
   switch_size_t *argp2 ;
   socklen_t *argp4 ;
+  char *result = 0 ;
   
   arg1 = (char *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -7309,8 +7148,8 @@
   char *arg4 = (char *) 0 ;
   switch_sockaddr_t *arg5 = (switch_sockaddr_t *) 0 ;
   int arg6 ;
-  int result;
   switch_size_t *argp2 ;
+  int result;
   
   arg1 = (char *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -7410,7 +7249,7 @@
   
   arg1 = (char *)jarg1; 
   result = switch_str_time((char const *)arg1);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -7880,7 +7719,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->caller_ton = arg2;
-  
 }
 
 
@@ -7903,7 +7741,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->caller_numplan = arg2;
-  
 }
 
 
@@ -7984,7 +7821,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->ani_ton = arg2;
-  
 }
 
 
@@ -8007,7 +7843,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->ani_numplan = arg2;
-  
 }
 
 
@@ -8088,7 +7923,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->rdnis_ton = arg2;
-  
 }
 
 
@@ -8111,7 +7945,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->rdnis_numplan = arg2;
-  
 }
 
 
@@ -8164,7 +7997,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->destination_number_ton = arg2;
-  
 }
 
 
@@ -8187,7 +8019,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->destination_number_numplan = arg2;
-  
 }
 
 
@@ -8357,7 +8188,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_caller_profile_flag_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -8380,7 +8210,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_caller_profile *)jarg2; 
   if (arg1) (arg1)->originator_caller_profile = arg2;
-  
 }
 
 
@@ -8403,7 +8232,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_caller_profile *)jarg2; 
   if (arg1) (arg1)->originatee_caller_profile = arg2;
-  
 }
 
 
@@ -8426,7 +8254,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_channel_timetable *)jarg2; 
   if (arg1) (arg1)->times = arg2;
-  
 }
 
 
@@ -8449,7 +8276,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_caller_extension *)jarg2; 
   if (arg1) (arg1)->caller_extension = arg2;
-  
 }
 
 
@@ -8472,7 +8298,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->pool = arg2;
-  
 }
 
 
@@ -8495,7 +8320,6 @@
   arg1 = (switch_caller_profile *)jarg1; 
   arg2 = (switch_caller_profile *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -8526,7 +8350,6 @@
   
   arg1 = (switch_caller_profile *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -8597,7 +8420,6 @@
   arg1 = (switch_caller_application *)jarg1; 
   arg2 = (switch_application_function_t)jarg2; 
   if (arg1) (arg1)->application_function = arg2;
-  
 }
 
 
@@ -8620,7 +8442,6 @@
   arg1 = (switch_caller_application *)jarg1; 
   arg2 = (switch_caller_application *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -8651,7 +8472,6 @@
   
   arg1 = (switch_caller_application *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -8722,7 +8542,6 @@
   arg1 = (switch_caller_extension *)jarg1; 
   arg2 = (switch_caller_application_t *)jarg2; 
   if (arg1) (arg1)->current_application = arg2;
-  
 }
 
 
@@ -8745,7 +8564,6 @@
   arg1 = (switch_caller_extension *)jarg1; 
   arg2 = (switch_caller_application_t *)jarg2; 
   if (arg1) (arg1)->last_application = arg2;
-  
 }
 
 
@@ -8768,7 +8586,6 @@
   arg1 = (switch_caller_extension *)jarg1; 
   arg2 = (switch_caller_application_t *)jarg2; 
   if (arg1) (arg1)->applications = arg2;
-  
 }
 
 
@@ -8791,7 +8608,6 @@
   arg1 = (switch_caller_extension *)jarg1; 
   arg2 = (switch_caller_profile *)jarg2; 
   if (arg1) (arg1)->children = arg2;
-  
 }
 
 
@@ -8814,7 +8630,6 @@
   arg1 = (switch_caller_extension *)jarg1; 
   arg2 = (switch_caller_extension *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -8845,7 +8660,6 @@
   
   arg1 = (switch_caller_extension *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -8990,7 +8804,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (switch_codec_t *)jarg2; 
   if (arg1) (arg1)->codec = arg2;
-  
 }
 
 
@@ -9042,7 +8855,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->packet = arg2;
-  
 }
 
 
@@ -9065,7 +8877,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->packetlen = arg2;
-  
 }
 
 
@@ -9088,7 +8899,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->data = arg2;
-  
 }
 
 
@@ -9111,7 +8921,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->datalen = arg2;
-  
 }
 
 
@@ -9134,7 +8943,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->buflen = arg2;
-  
 }
 
 
@@ -9157,7 +8965,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samples = arg2;
-  
 }
 
 
@@ -9180,7 +8987,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->rate = arg2;
-  
 }
 
 
@@ -9203,7 +9009,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (switch_payload_t)jarg2; 
   if (arg1) (arg1)->payload = arg2;
-  
 }
 
 
@@ -9232,7 +9037,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->timestamp = arg2;
-  
 }
 
 
@@ -9243,7 +9047,7 @@
   
   arg1 = (switch_frame *)jarg1; 
   result =  ((arg1)->timestamp);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -9255,7 +9059,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint16_t)jarg2; 
   if (arg1) (arg1)->seq = arg2;
-  
 }
 
 
@@ -9278,7 +9081,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->ssrc = arg2;
-  
 }
 
 
@@ -9301,7 +9103,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (switch_bool_t)jarg2; 
   if (arg1) (arg1)->m = arg2;
-  
 }
 
 
@@ -9324,7 +9125,6 @@
   arg1 = (switch_frame *)jarg1; 
   arg2 = (switch_frame_flag_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -9355,7 +9155,6 @@
   
   arg1 = (switch_frame *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -9366,7 +9165,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_init = arg2;
-  
 }
 
 
@@ -9389,7 +9187,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_routing = arg2;
-  
 }
 
 
@@ -9412,7 +9209,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_execute = arg2;
-  
 }
 
 
@@ -9435,7 +9231,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_hangup = arg2;
-  
 }
 
 
@@ -9458,7 +9253,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_exchange_media = arg2;
-  
 }
 
 
@@ -9481,7 +9275,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_soft_execute = arg2;
-  
 }
 
 
@@ -9504,7 +9297,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_consume_media = arg2;
-  
 }
 
 
@@ -9527,7 +9319,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_hibernate = arg2;
-  
 }
 
 
@@ -9550,7 +9341,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_reset = arg2;
-  
 }
 
 
@@ -9573,7 +9363,6 @@
   arg1 = (switch_state_handler_table *)jarg1; 
   arg2 = (switch_state_handler_t)jarg2; 
   if (arg1) (arg1)->on_park = arg2;
-  
 }
 
 
@@ -9630,7 +9419,6 @@
   
   arg1 = (switch_state_handler_table *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -9641,7 +9429,6 @@
   arg1 = (switch_stream_handle *)jarg1; 
   arg2 = (switch_stream_handle_write_function_t)jarg2; 
   if (arg1) (arg1)->write_function = arg2;
-  
 }
 
 
@@ -9664,7 +9451,6 @@
   arg1 = (switch_stream_handle *)jarg1; 
   arg2 = (switch_stream_handle_raw_write_function_t)jarg2; 
   if (arg1) (arg1)->raw_write_function = arg2;
-  
 }
 
 
@@ -9687,7 +9473,6 @@
   arg1 = (switch_stream_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->data = arg2;
-  
 }
 
 
@@ -9710,7 +9495,6 @@
   arg1 = (switch_stream_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->end = arg2;
-  
 }
 
 
@@ -9739,7 +9523,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->data_size = arg2;
-  
 }
 
 
@@ -9750,7 +9533,7 @@
   
   arg1 = (switch_stream_handle *)jarg1; 
   result =  ((arg1)->data_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -9768,7 +9551,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->data_len = arg2;
-  
 }
 
 
@@ -9779,7 +9561,7 @@
   
   arg1 = (switch_stream_handle *)jarg1; 
   result =  ((arg1)->data_len);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -9797,7 +9579,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->alloc_len = arg2;
-  
 }
 
 
@@ -9808,7 +9589,7 @@
   
   arg1 = (switch_stream_handle *)jarg1; 
   result =  ((arg1)->alloc_len);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -9826,7 +9607,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->alloc_chunk = arg2;
-  
 }
 
 
@@ -9837,7 +9617,7 @@
   
   arg1 = (switch_stream_handle *)jarg1; 
   result =  ((arg1)->alloc_chunk);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -9849,7 +9629,6 @@
   arg1 = (switch_stream_handle *)jarg1; 
   arg2 = (switch_event_t *)jarg2; 
   if (arg1) (arg1)->param_event = arg2;
-  
 }
 
 
@@ -9880,7 +9659,6 @@
   
   arg1 = (switch_stream_handle *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -9891,7 +9669,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_outgoing_channel_t)jarg2; 
   if (arg1) (arg1)->outgoing_channel = arg2;
-  
 }
 
 
@@ -9914,7 +9691,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_read_frame_t)jarg2; 
   if (arg1) (arg1)->read_frame = arg2;
-  
 }
 
 
@@ -9937,7 +9713,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_write_frame_t)jarg2; 
   if (arg1) (arg1)->write_frame = arg2;
-  
 }
 
 
@@ -9960,7 +9735,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_kill_channel_t)jarg2; 
   if (arg1) (arg1)->kill_channel = arg2;
-  
 }
 
 
@@ -9983,7 +9757,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_send_dtmf_t)jarg2; 
   if (arg1) (arg1)->send_dtmf = arg2;
-  
 }
 
 
@@ -10006,7 +9779,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_receive_message_t)jarg2; 
   if (arg1) (arg1)->receive_message = arg2;
-  
 }
 
 
@@ -10029,7 +9801,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_receive_event_t)jarg2; 
   if (arg1) (arg1)->receive_event = arg2;
-  
 }
 
 
@@ -10052,7 +9823,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_state_change_t)jarg2; 
   if (arg1) (arg1)->state_change = arg2;
-  
 }
 
 
@@ -10075,7 +9845,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_read_video_frame_t)jarg2; 
   if (arg1) (arg1)->read_video_frame = arg2;
-  
 }
 
 
@@ -10098,7 +9867,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_write_video_frame_t)jarg2; 
   if (arg1) (arg1)->write_video_frame = arg2;
-  
 }
 
 
@@ -10121,7 +9889,6 @@
   arg1 = (switch_io_routines *)jarg1; 
   arg2 = (switch_io_resurrect_session_t)jarg2; 
   if (arg1) (arg1)->resurrect_session = arg2;
-  
 }
 
 
@@ -10178,7 +9945,6 @@
   
   arg1 = (switch_io_routines *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -10218,7 +9984,6 @@
   arg1 = (switch_endpoint_interface *)jarg1; 
   arg2 = (switch_io_routines_t *)jarg2; 
   if (arg1) (arg1)->io_routines = arg2;
-  
 }
 
 
@@ -10241,7 +10006,6 @@
   arg1 = (switch_endpoint_interface *)jarg1; 
   arg2 = (switch_state_handler_table_t *)jarg2; 
   if (arg1) (arg1)->state_handler = arg2;
-  
 }
 
 
@@ -10264,7 +10028,6 @@
   arg1 = (switch_endpoint_interface *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -10287,7 +10050,6 @@
   arg1 = (switch_endpoint_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -10310,7 +10072,6 @@
   arg1 = (switch_endpoint_interface *)jarg1; 
   arg2 = (switch_endpoint_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -10341,7 +10102,6 @@
   
   arg1 = (switch_endpoint_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -10352,7 +10112,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->interval = arg2;
-  
 }
 
 
@@ -10375,7 +10134,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -10398,7 +10156,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->samples = arg2;
-  
 }
 
 
@@ -10421,7 +10178,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samplecount = arg2;
-  
 }
 
 
@@ -10444,7 +10200,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (switch_timer_interface_t *)jarg2; 
   if (arg1) (arg1)->timer_interface = arg2;
-  
 }
 
 
@@ -10467,7 +10222,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -10490,7 +10244,6 @@
   arg1 = (switch_timer *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -10519,7 +10272,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->diff = arg2;
-  
 }
 
 
@@ -10530,7 +10282,7 @@
   
   arg1 = (switch_timer *)jarg1; 
   result =  ((arg1)->diff);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -10548,7 +10300,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->tick = arg2;
-  
 }
 
 
@@ -10559,7 +10310,7 @@
   
   arg1 = (switch_timer *)jarg1; 
   result =  ((arg1)->tick);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -10579,7 +10330,6 @@
   
   arg1 = (switch_timer *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -10619,7 +10369,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *))jarg2; 
   if (arg1) (arg1)->timer_init = arg2;
-  
 }
 
 
@@ -10642,7 +10391,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *))jarg2; 
   if (arg1) (arg1)->timer_next = arg2;
-  
 }
 
 
@@ -10665,7 +10413,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *))jarg2; 
   if (arg1) (arg1)->timer_step = arg2;
-  
 }
 
 
@@ -10688,7 +10435,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *))jarg2; 
   if (arg1) (arg1)->timer_sync = arg2;
-  
 }
 
 
@@ -10711,7 +10457,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *,switch_bool_t))jarg2; 
   if (arg1) (arg1)->timer_check = arg2;
-  
 }
 
 
@@ -10734,7 +10479,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_timer_t *))jarg2; 
   if (arg1) (arg1)->timer_destroy = arg2;
-  
 }
 
 
@@ -10757,7 +10501,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -10780,7 +10523,6 @@
   arg1 = (switch_timer_interface *)jarg1; 
   arg2 = (switch_timer_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -10811,7 +10553,6 @@
   
   arg1 = (switch_timer_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -10851,7 +10592,6 @@
   arg1 = (switch_dialplan_interface *)jarg1; 
   arg2 = (switch_dialplan_hunt_function_t)jarg2; 
   if (arg1) (arg1)->hunt_function = arg2;
-  
 }
 
 
@@ -10874,7 +10614,6 @@
   arg1 = (switch_dialplan_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -10897,7 +10636,6 @@
   arg1 = (switch_dialplan_interface *)jarg1; 
   arg2 = (switch_dialplan_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -10928,7 +10666,6 @@
   
   arg1 = (switch_dialplan_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -10968,7 +10705,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,char const *))jarg2; 
   if (arg1) (arg1)->file_open = arg2;
-  
 }
 
 
@@ -10991,7 +10727,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *))jarg2; 
   if (arg1) (arg1)->file_close = arg2;
-  
 }
 
 
@@ -11014,7 +10749,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,void *,switch_size_t *))jarg2; 
   if (arg1) (arg1)->file_read = arg2;
-  
 }
 
 
@@ -11037,7 +10771,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,void *,switch_size_t *))jarg2; 
   if (arg1) (arg1)->file_write = arg2;
-  
 }
 
 
@@ -11060,7 +10793,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,unsigned int *,int64_t,int))jarg2; 
   if (arg1) (arg1)->file_seek = arg2;
-  
 }
 
 
@@ -11083,7 +10815,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,switch_audio_col_t,char const *))jarg2; 
   if (arg1) (arg1)->file_set_string = arg2;
-  
 }
 
 
@@ -11106,7 +10837,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_file_handle_t *,switch_audio_col_t,char const **))jarg2; 
   if (arg1) (arg1)->file_get_string = arg2;
-  
 }
 
 
@@ -11129,7 +10859,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (char **)jarg2; 
   if (arg1) (arg1)->extens = arg2;
-  
 }
 
 
@@ -11152,7 +10881,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -11175,7 +10903,6 @@
   arg1 = (switch_file_interface *)jarg1; 
   arg2 = (switch_file_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -11206,7 +10933,6 @@
   
   arg1 = (switch_file_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -11217,7 +10943,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_file_interface_t *)jarg2; 
   if (arg1) (arg1)->file_interface = (switch_file_interface_t const *)arg2;
-  
 }
 
 
@@ -11240,7 +10965,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -11263,7 +10987,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_file_t *)jarg2; 
   if (arg1) (arg1)->fd = arg2;
-  
 }
 
 
@@ -11286,7 +11009,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->samples = arg2;
-  
 }
 
 
@@ -11309,7 +11031,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samplerate = arg2;
-  
 }
 
 
@@ -11332,7 +11053,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->native_rate = arg2;
-  
 }
 
 
@@ -11355,7 +11075,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->channels = arg2;
-  
 }
 
 
@@ -11378,7 +11097,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->format = arg2;
-  
 }
 
 
@@ -11401,7 +11119,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->sections = arg2;
-  
 }
 
 
@@ -11424,7 +11141,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->seekable = arg2;
-  
 }
 
 
@@ -11453,7 +11169,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->sample_count = arg2;
-  
 }
 
 
@@ -11464,7 +11179,7 @@
   
   arg1 = (switch_file_handle *)jarg1; 
   result =  ((arg1)->sample_count);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -11476,7 +11191,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->speed = arg2;
-  
 }
 
 
@@ -11499,7 +11213,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -11522,7 +11235,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->prebuf = arg2;
-  
 }
 
 
@@ -11545,7 +11257,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->interval = arg2;
-  
 }
 
 
@@ -11568,7 +11279,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -11621,7 +11331,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (int64_t)jarg2; 
   if (arg1) (arg1)->pos = arg2;
-  
 }
 
 
@@ -11644,7 +11353,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_buffer_t *)jarg2; 
   if (arg1) (arg1)->audio_buffer = arg2;
-  
 }
 
 
@@ -11667,7 +11375,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_buffer_t *)jarg2; 
   if (arg1) (arg1)->sp_audio_buffer = arg2;
-  
 }
 
 
@@ -11690,7 +11397,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->thresh = arg2;
-  
 }
 
 
@@ -11713,7 +11419,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->silence_hits = arg2;
-  
 }
 
 
@@ -11736,7 +11441,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->offset_pos = arg2;
-  
 }
 
 
@@ -11759,7 +11463,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->last_pos = arg2;
-  
 }
 
 
@@ -11782,7 +11485,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (int32_t)jarg2; 
   if (arg1) (arg1)->vol = arg2;
-  
 }
 
 
@@ -11805,7 +11507,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_audio_resampler_t *)jarg2; 
   if (arg1) (arg1)->resampler = arg2;
-  
 }
 
 
@@ -11828,7 +11529,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_buffer_t *)jarg2; 
   if (arg1) (arg1)->buffer = arg2;
-  
 }
 
 
@@ -11851,7 +11551,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (switch_byte_t *)jarg2; 
   if (arg1) (arg1)->dbuf = arg2;
-  
 }
 
 
@@ -11880,7 +11579,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->dbuflen = arg2;
-  
 }
 
 
@@ -11891,7 +11589,7 @@
   
   arg1 = (switch_file_handle *)jarg1; 
   result =  ((arg1)->dbuflen);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -11961,7 +11659,6 @@
   arg1 = (switch_file_handle *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->line = arg2;
-  
 }
 
 
@@ -11992,7 +11689,6 @@
   
   arg1 = (switch_file_handle *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -12032,7 +11728,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,char const *,int,char const *,switch_asr_flag_t *))jarg2; 
   if (arg1) (arg1)->asr_open = arg2;
-  
 }
 
 
@@ -12055,7 +11750,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,char const *,char const *))jarg2; 
   if (arg1) (arg1)->asr_load_grammar = arg2;
-  
 }
 
 
@@ -12078,7 +11772,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,char const *))jarg2; 
   if (arg1) (arg1)->asr_unload_grammar = arg2;
-  
 }
 
 
@@ -12101,7 +11794,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,switch_asr_flag_t *))jarg2; 
   if (arg1) (arg1)->asr_close = arg2;
-  
 }
 
 
@@ -12124,7 +11816,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,void *,unsigned int,switch_asr_flag_t *))jarg2; 
   if (arg1) (arg1)->asr_feed = arg2;
-  
 }
 
 
@@ -12147,7 +11838,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *))jarg2; 
   if (arg1) (arg1)->asr_resume = arg2;
-  
 }
 
 
@@ -12170,7 +11860,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *))jarg2; 
   if (arg1) (arg1)->asr_pause = arg2;
-  
 }
 
 
@@ -12193,7 +11882,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,switch_asr_flag_t *))jarg2; 
   if (arg1) (arg1)->asr_check_results = arg2;
-  
 }
 
 
@@ -12216,7 +11904,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_asr_handle_t *,char **,switch_asr_flag_t *))jarg2; 
   if (arg1) (arg1)->asr_get_results = arg2;
-  
 }
 
 
@@ -12239,7 +11926,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -12262,7 +11948,6 @@
   arg1 = (switch_asr_interface *)jarg1; 
   arg2 = (switch_asr_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -12293,7 +11978,6 @@
   
   arg1 = (switch_asr_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -12304,7 +11988,6 @@
   arg1 = (switch_asr_handle *)jarg1; 
   arg2 = (switch_asr_interface_t *)jarg2; 
   if (arg1) (arg1)->asr_interface = (switch_asr_interface_t const *)arg2;
-  
 }
 
 
@@ -12327,7 +12010,6 @@
   arg1 = (switch_asr_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -12410,7 +12092,6 @@
   arg1 = (switch_asr_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->rate = arg2;
-  
 }
 
 
@@ -12493,7 +12174,6 @@
   arg1 = (switch_asr_handle *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -12516,7 +12196,6 @@
   arg1 = (switch_asr_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -12547,7 +12226,6 @@
   
   arg1 = (switch_asr_handle *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -12587,7 +12265,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_speech_handle_t *,char const *,int,switch_speech_flag_t *))jarg2; 
   if (arg1) (arg1)->speech_open = arg2;
-  
 }
 
 
@@ -12610,7 +12287,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_speech_handle_t *,switch_speech_flag_t *))jarg2; 
   if (arg1) (arg1)->speech_close = arg2;
-  
 }
 
 
@@ -12633,7 +12309,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_speech_handle_t *,char *,switch_speech_flag_t *))jarg2; 
   if (arg1) (arg1)->speech_feed_tts = arg2;
-  
 }
 
 
@@ -12656,7 +12331,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_speech_handle_t *,void *,switch_size_t *,uint32_t *,switch_speech_flag_t *))jarg2; 
   if (arg1) (arg1)->speech_read_tts = arg2;
-  
 }
 
 
@@ -12679,7 +12353,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (void (*)(switch_speech_handle_t *))jarg2; 
   if (arg1) (arg1)->speech_flush_tts = arg2;
-  
 }
 
 
@@ -12702,7 +12375,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (void (*)(switch_speech_handle_t *,char *,char const *))jarg2; 
   if (arg1) (arg1)->speech_text_param_tts = arg2;
-  
 }
 
 
@@ -12725,7 +12397,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (void (*)(switch_speech_handle_t *,char *,int))jarg2; 
   if (arg1) (arg1)->speech_numeric_param_tts = arg2;
-  
 }
 
 
@@ -12748,7 +12419,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (void (*)(switch_speech_handle_t *,char *,double))jarg2; 
   if (arg1) (arg1)->speech_float_param_tts = arg2;
-  
 }
 
 
@@ -12771,7 +12441,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -12794,7 +12463,6 @@
   arg1 = (switch_speech_interface *)jarg1; 
   arg2 = (switch_speech_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -12825,7 +12493,6 @@
   
   arg1 = (switch_speech_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -12836,7 +12503,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (switch_speech_interface_t *)jarg2; 
   if (arg1) (arg1)->speech_interface = (switch_speech_interface_t const *)arg2;
-  
 }
 
 
@@ -12859,7 +12525,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -12912,7 +12577,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->rate = arg2;
-  
 }
 
 
@@ -12935,7 +12599,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->speed = arg2;
-  
 }
 
 
@@ -12958,7 +12621,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samples = arg2;
-  
 }
 
 
@@ -13066,7 +12728,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -13089,7 +12750,6 @@
   arg1 = (switch_speech_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -13120,7 +12780,6 @@
   
   arg1 = (switch_speech_handle *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13160,7 +12819,6 @@
   arg1 = (switch_say_interface *)jarg1; 
   arg2 = (switch_say_callback_t)jarg2; 
   if (arg1) (arg1)->say_function = arg2;
-  
 }
 
 
@@ -13183,7 +12841,6 @@
   arg1 = (switch_say_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -13206,7 +12863,6 @@
   arg1 = (switch_say_interface *)jarg1; 
   arg2 = (switch_say_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -13237,7 +12893,6 @@
   
   arg1 = (switch_say_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13277,7 +12932,6 @@
   arg1 = (switch_chat_interface *)jarg1; 
   arg2 = (switch_status_t (*)(char *,char *,char *,char *,char *,char *))jarg2; 
   if (arg1) (arg1)->chat_send = arg2;
-  
 }
 
 
@@ -13300,7 +12954,6 @@
   arg1 = (switch_chat_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -13323,7 +12976,6 @@
   arg1 = (switch_chat_interface *)jarg1; 
   arg2 = (switch_chat_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -13354,7 +13006,6 @@
   
   arg1 = (switch_chat_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13394,7 +13045,6 @@
   arg1 = (switch_management_interface *)jarg1; 
   arg2 = (switch_status_t (*)(char *,switch_management_action_t,char *,switch_size_t))jarg2; 
   if (arg1) (arg1)->management_function = arg2;
-  
 }
 
 
@@ -13417,7 +13067,6 @@
   arg1 = (switch_management_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -13440,7 +13089,6 @@
   arg1 = (switch_management_interface *)jarg1; 
   arg2 = (switch_management_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -13471,7 +13119,6 @@
   
   arg1 = (switch_management_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13511,7 +13158,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_directory_handle_t *,char *,char *,char *))jarg2; 
   if (arg1) (arg1)->directory_open = arg2;
-  
 }
 
 
@@ -13534,7 +13180,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_directory_handle_t *))jarg2; 
   if (arg1) (arg1)->directory_close = arg2;
-  
 }
 
 
@@ -13557,7 +13202,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_directory_handle_t *,char *,char *))jarg2; 
   if (arg1) (arg1)->directory_query = arg2;
-  
 }
 
 
@@ -13580,7 +13224,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_directory_handle_t *))jarg2; 
   if (arg1) (arg1)->directory_next = arg2;
-  
 }
 
 
@@ -13603,7 +13246,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_status_t (*)(switch_directory_handle_t *,char **,char **))jarg2; 
   if (arg1) (arg1)->directory_next_pair = arg2;
-  
 }
 
 
@@ -13626,7 +13268,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -13649,7 +13290,6 @@
   arg1 = (switch_directory_interface *)jarg1; 
   arg2 = (switch_directory_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -13680,7 +13320,6 @@
   
   arg1 = (switch_directory_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13691,7 +13330,6 @@
   arg1 = (switch_directory_handle *)jarg1; 
   arg2 = (switch_directory_interface_t *)jarg2; 
   if (arg1) (arg1)->directory_interface = (switch_directory_interface_t const *)arg2;
-  
 }
 
 
@@ -13714,7 +13352,6 @@
   arg1 = (switch_directory_handle *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -13737,7 +13374,6 @@
   arg1 = (switch_directory_handle *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -13760,7 +13396,6 @@
   arg1 = (switch_directory_handle *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -13791,7 +13426,6 @@
   
   arg1 = (switch_directory_handle *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -13802,7 +13436,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->quality = arg2;
-  
 }
 
 
@@ -13825,7 +13458,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->complexity = arg2;
-  
 }
 
 
@@ -13848,7 +13480,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->enhancement = arg2;
-  
 }
 
 
@@ -13871,7 +13502,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->vad = arg2;
-  
 }
 
 
@@ -13894,7 +13524,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->vbr = arg2;
-  
 }
 
 
@@ -13917,7 +13546,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (float)jarg2; 
   if (arg1) (arg1)->vbr_quality = arg2;
-  
 }
 
 
@@ -13940,7 +13568,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->abr = arg2;
-  
 }
 
 
@@ -13963,7 +13590,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->dtx = arg2;
-  
 }
 
 
@@ -13986,7 +13612,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->preproc = arg2;
-  
 }
 
 
@@ -14009,7 +13634,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->pp_vad = arg2;
-  
 }
 
 
@@ -14032,7 +13656,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->pp_agc = arg2;
-  
 }
 
 
@@ -14055,7 +13678,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (float)jarg2; 
   if (arg1) (arg1)->pp_agc_level = arg2;
-  
 }
 
 
@@ -14078,7 +13700,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->pp_denoise = arg2;
-  
 }
 
 
@@ -14101,7 +13722,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->pp_dereverb = arg2;
-  
 }
 
 
@@ -14124,7 +13744,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (float)jarg2; 
   if (arg1) (arg1)->pp_dereverb_decay = arg2;
-  
 }
 
 
@@ -14147,7 +13766,6 @@
   arg1 = (switch_codec_settings *)jarg1; 
   arg2 = (float)jarg2; 
   if (arg1) (arg1)->pp_dereverb_level = arg2;
-  
 }
 
 
@@ -14178,7 +13796,6 @@
   
   arg1 = (switch_codec_settings *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -14189,7 +13806,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (switch_codec_interface_t *)jarg2; 
   if (arg1) (arg1)->codec_interface = (switch_codec_interface_t const *)arg2;
-  
 }
 
 
@@ -14212,7 +13828,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (switch_codec_implementation_t *)jarg2; 
   if (arg1) (arg1)->implementation = (switch_codec_implementation_t const *)arg2;
-  
 }
 
 
@@ -14295,7 +13910,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (switch_codec_settings_t *)jarg2; 
   if (arg1) (arg1)->codec_settings = *arg2;
-  
 }
 
 
@@ -14318,7 +13932,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -14341,7 +13954,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (switch_memory_pool_t *)jarg2; 
   if (arg1) (arg1)->memory_pool = arg2;
-  
 }
 
 
@@ -14364,7 +13976,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->private_info = arg2;
-  
 }
 
 
@@ -14387,7 +13998,6 @@
   arg1 = (switch_codec *)jarg1; 
   arg2 = (switch_payload_t)jarg2; 
   if (arg1) (arg1)->agreed_pt = arg2;
-  
 }
 
 
@@ -14418,7 +14028,6 @@
   
   arg1 = (switch_codec *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -14429,7 +14038,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_codec_type_t)jarg2; 
   if (arg1) (arg1)->codec_type = arg2;
-  
 }
 
 
@@ -14452,7 +14060,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_payload_t)jarg2; 
   if (arg1) (arg1)->ianacode = arg2;
-  
 }
 
 
@@ -14535,7 +14142,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samples_per_second = arg2;
-  
 }
 
 
@@ -14558,7 +14164,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->actual_samples_per_second = arg2;
-  
 }
 
 
@@ -14581,7 +14186,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->bits_per_second = arg2;
-  
 }
 
 
@@ -14604,7 +14208,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->microseconds_per_frame = arg2;
-  
 }
 
 
@@ -14627,7 +14230,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->samples_per_frame = arg2;
-  
 }
 
 
@@ -14650,7 +14252,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->bytes_per_frame = arg2;
-  
 }
 
 
@@ -14673,7 +14274,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->encoded_bytes_per_frame = arg2;
-  
 }
 
 
@@ -14696,7 +14296,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint8_t)jarg2; 
   if (arg1) (arg1)->number_of_channels = arg2;
-  
 }
 
 
@@ -14719,7 +14318,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->pref_frames_per_packet = arg2;
-  
 }
 
 
@@ -14742,7 +14340,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->max_frames_per_packet = arg2;
-  
 }
 
 
@@ -14765,7 +14362,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_core_codec_init_func_t)jarg2; 
   if (arg1) (arg1)->init = arg2;
-  
 }
 
 
@@ -14788,7 +14384,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_core_codec_encode_func_t)jarg2; 
   if (arg1) (arg1)->encode = arg2;
-  
 }
 
 
@@ -14811,7 +14406,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_core_codec_decode_func_t)jarg2; 
   if (arg1) (arg1)->decode = arg2;
-  
 }
 
 
@@ -14834,7 +14428,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_core_codec_destroy_func_t)jarg2; 
   if (arg1) (arg1)->destroy = arg2;
-  
 }
 
 
@@ -14857,7 +14450,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->codec_id = arg2;
-  
 }
 
 
@@ -14880,7 +14472,6 @@
   arg1 = (switch_codec_implementation *)jarg1; 
   arg2 = (switch_codec_implementation *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -14911,7 +14502,6 @@
   
   arg1 = (switch_codec_implementation *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -14951,7 +14541,6 @@
   arg1 = (switch_codec_interface *)jarg1; 
   arg2 = (switch_codec_implementation_t *)jarg2; 
   if (arg1) (arg1)->implementations = arg2;
-  
 }
 
 
@@ -14974,7 +14563,6 @@
   arg1 = (switch_codec_interface *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->codec_id = arg2;
-  
 }
 
 
@@ -14997,7 +14585,6 @@
   arg1 = (switch_codec_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -15020,7 +14607,6 @@
   arg1 = (switch_codec_interface *)jarg1; 
   arg2 = (switch_codec_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -15051,7 +14637,6 @@
   
   arg1 = (switch_codec_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -15091,7 +14676,6 @@
   arg1 = (switch_application_interface *)jarg1; 
   arg2 = (switch_application_function_t)jarg2; 
   if (arg1) (arg1)->application_function = arg2;
-  
 }
 
 
@@ -15201,7 +14785,6 @@
   arg1 = (switch_application_interface *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -15224,7 +14807,6 @@
   arg1 = (switch_application_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -15247,7 +14829,6 @@
   arg1 = (switch_application_interface *)jarg1; 
   arg2 = (switch_application_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -15278,7 +14859,6 @@
   
   arg1 = (switch_application_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -15347,7 +14927,6 @@
   arg1 = (switch_api_interface *)jarg1; 
   arg2 = (switch_api_function_t)jarg2; 
   if (arg1) (arg1)->function = arg2;
-  
 }
 
 
@@ -15399,7 +14978,6 @@
   arg1 = (switch_api_interface *)jarg1; 
   arg2 = (switch_thread_rwlock_t *)jarg2; 
   if (arg1) (arg1)->rwlock = arg2;
-  
 }
 
 
@@ -15422,7 +15000,6 @@
   arg1 = (switch_api_interface *)jarg1; 
   arg2 = (switch_api_interface *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -15453,7 +15030,6 @@
   
   arg1 = (switch_api_interface *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -15470,7 +15046,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->profile_created = arg2;
-  
 }
 
 
@@ -15481,7 +15056,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->profile_created);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15499,7 +15074,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->created = arg2;
-  
 }
 
 
@@ -15510,7 +15084,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->created);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15528,7 +15102,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->answered = arg2;
-  
 }
 
 
@@ -15539,7 +15112,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->answered);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15557,7 +15130,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->progress = arg2;
-  
 }
 
 
@@ -15568,7 +15140,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->progress);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15586,7 +15158,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->progress_media = arg2;
-  
 }
 
 
@@ -15597,7 +15168,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->progress_media);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15615,7 +15186,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->hungup = arg2;
-  
 }
 
 
@@ -15626,7 +15196,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->hungup);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15644,7 +15214,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->transferred = arg2;
-  
 }
 
 
@@ -15655,7 +15224,7 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   result =  ((arg1)->transferred);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -15667,7 +15236,6 @@
   arg1 = (switch_channel_timetable *)jarg1; 
   arg2 = (switch_channel_timetable *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -15698,7 +15266,6 @@
   
   arg1 = (switch_channel_timetable *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -15810,25 +15377,49 @@
 }
 
 
-SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_str2cause(char * jarg1) {
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_str2cause(char * jarg1) {
+  int jresult ;
+  char *arg1 = (char *) 0 ;
+  switch_call_cause_t result;
+  
+  arg1 = (char *)jarg1; 
+  result = (switch_call_cause_t)switch_channel_str2cause((char const *)arg1);
+  jresult = result; 
+  return jresult;
+}
+
+
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_get_cause(void * jarg1) {
+  int jresult ;
+  switch_channel_t *arg1 = (switch_channel_t *) 0 ;
+  switch_call_cause_t result;
+  
+  arg1 = (switch_channel_t *)jarg1; 
+  result = (switch_call_cause_t)switch_channel_get_cause(arg1);
+  jresult = result; 
+  return jresult;
+}
+
+
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_cause_q850(int jarg1) {
   int jresult ;
-  char *arg1 = (char *) 0 ;
+  switch_call_cause_t arg1 ;
   switch_call_cause_t result;
   
-  arg1 = (char *)jarg1; 
-  result = (switch_call_cause_t)switch_channel_str2cause((char const *)arg1);
+  arg1 = (switch_call_cause_t)jarg1; 
+  result = (switch_call_cause_t)switch_channel_cause_q850(arg1);
   jresult = result; 
   return jresult;
 }
 
 
-SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_get_cause(void * jarg1) {
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_get_cause_q850(void * jarg1) {
   int jresult ;
   switch_channel_t *arg1 = (switch_channel_t *) 0 ;
   switch_call_cause_t result;
   
   arg1 = (switch_channel_t *)jarg1; 
-  result = (switch_call_cause_t)switch_channel_get_cause(arg1);
+  result = (switch_call_cause_t)switch_channel_get_cause_q850(arg1);
   jresult = result; 
   return jresult;
 }
@@ -16006,6 +15597,23 @@
 }
 
 
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_set_variable_printf(void * jarg1, char * jarg2, char * jarg3) {
+  int jresult ;
+  switch_channel_t *arg1 = (switch_channel_t *) 0 ;
+  char *arg2 = (char *) 0 ;
+  char *arg3 = (char *) 0 ;
+  void *arg4 = 0 ;
+  switch_status_t result;
+  
+  arg1 = (switch_channel_t *)jarg1; 
+  arg2 = (char *)jarg2; 
+  arg3 = (char *)jarg3; 
+  result = (switch_status_t)switch_channel_set_variable_printf(arg1,(char const *)arg2,(char const *)arg3,arg4);
+  jresult = result; 
+  return jresult;
+}
+
+
 SWIGEXPORT int SWIGSTDCALL CSharp_switch_channel_set_variable_partner(void * jarg1, char * jarg2, char * jarg3) {
   int jresult ;
   switch_channel_t *arg1 = (switch_channel_t *) 0 ;
@@ -16407,7 +16015,7 @@
   
   arg1 = (switch_channel_t *)jarg1; 
   result = switch_channel_has_dtmf(arg1);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16467,8 +16075,8 @@
   switch_channel_t *arg1 = (switch_channel_t *) 0 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (switch_channel_t *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -16479,7 +16087,7 @@
   }
   arg3 = *argp3; 
   result = switch_channel_dequeue_dtmf_string(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16565,8 +16173,8 @@
   switch_memory_pool_t *arg1 = (switch_memory_pool_t *) 0 ;
   switch_buffer_t **arg2 = (switch_buffer_t **) 0 ;
   switch_size_t arg3 ;
-  switch_status_t result;
   switch_size_t *argp3 ;
+  switch_status_t result;
   
   arg1 = (switch_memory_pool_t *)jarg1; 
   arg2 = (switch_buffer_t **)jarg2; 
@@ -16588,10 +16196,10 @@
   switch_size_t arg2 ;
   switch_size_t arg3 ;
   switch_size_t arg4 ;
-  switch_status_t result;
   switch_size_t *argp2 ;
   switch_size_t *argp3 ;
   switch_size_t *argp4 ;
+  switch_status_t result;
   
   arg1 = (switch_buffer_t **)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -16663,7 +16271,7 @@
   
   arg1 = (switch_buffer_t *)jarg1; 
   result = switch_buffer_len(arg1);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16675,7 +16283,7 @@
   
   arg1 = (switch_buffer_t *)jarg1; 
   result = switch_buffer_freespace(arg1);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16687,7 +16295,7 @@
   
   arg1 = (switch_buffer_t *)jarg1; 
   result = switch_buffer_inuse(arg1);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16697,8 +16305,8 @@
   switch_buffer_t *arg1 = (switch_buffer_t *) 0 ;
   void *arg2 = (void *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (switch_buffer_t *)jarg1; 
   arg2 = (void *)jarg2; 
@@ -16709,7 +16317,7 @@
   }
   arg3 = *argp3; 
   result = switch_buffer_read(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16719,8 +16327,8 @@
   switch_buffer_t *arg1 = (switch_buffer_t *) 0 ;
   void *arg2 = (void *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (switch_buffer_t *)jarg1; 
   arg2 = (void *)jarg2; 
@@ -16731,7 +16339,7 @@
   }
   arg3 = *argp3; 
   result = switch_buffer_read_loop(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16751,8 +16359,8 @@
   switch_buffer_t *arg1 = (switch_buffer_t *) 0 ;
   void *arg2 = (void *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (switch_buffer_t *)jarg1; 
   arg2 = (void *)jarg2; 
@@ -16763,7 +16371,7 @@
   }
   arg3 = *argp3; 
   result = switch_buffer_write(arg1,(void const *)arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16772,8 +16380,8 @@
   void * jresult ;
   switch_buffer_t *arg1 = (switch_buffer_t *) 0 ;
   switch_size_t arg2 ;
-  switch_size_t result;
   switch_size_t *argp2 ;
+  switch_size_t result;
   
   arg1 = (switch_buffer_t *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -16783,7 +16391,7 @@
   }
   arg2 = *argp2; 
   result = switch_buffer_toss(arg1,arg2);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16809,8 +16417,8 @@
   switch_buffer_t *arg1 = (switch_buffer_t *) 0 ;
   void *arg2 = (void *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (switch_buffer_t *)jarg1; 
   arg2 = (void *)jarg2; 
@@ -16821,7 +16429,7 @@
   }
   arg3 = *argp3; 
   result = switch_buffer_zwrite(arg1,(void const *)arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -16893,7 +16501,6 @@
   arg1 = (switch_event_header *)jarg1; 
   arg2 = (switch_event_header *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -16924,7 +16531,6 @@
   
   arg1 = (switch_event_header *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -16935,7 +16541,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (switch_event_types_t)jarg2; 
   if (arg1) (arg1)->event_id = arg2;
-  
 }
 
 
@@ -16958,7 +16563,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (switch_priority_t)jarg2; 
   if (arg1) (arg1)->priority = arg2;
-  
 }
 
 
@@ -17041,7 +16645,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (switch_event_header_t *)jarg2; 
   if (arg1) (arg1)->headers = arg2;
-  
 }
 
 
@@ -17064,7 +16667,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (switch_event_header_t *)jarg2; 
   if (arg1) (arg1)->last_header = arg2;
-  
 }
 
 
@@ -17117,7 +16719,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->bind_user_data = arg2;
-  
 }
 
 
@@ -17140,7 +16741,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->event_user_data = arg2;
-  
 }
 
 
@@ -17163,7 +16763,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (unsigned long)jarg2; 
   if (arg1) (arg1)->key = arg2;
-  
 }
 
 
@@ -17186,7 +16785,6 @@
   arg1 = (switch_event *)jarg1; 
   arg2 = (switch_event *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -17217,7 +16815,6 @@
   
   arg1 = (switch_event *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -17604,7 +17201,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->resampler = arg2;
-  
 }
 
 
@@ -17627,7 +17223,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->from_rate = arg2;
-  
 }
 
 
@@ -17650,7 +17245,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->to_rate = arg2;
-  
 }
 
 
@@ -17673,7 +17267,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (double)jarg2; 
   if (arg1) (arg1)->factor = arg2;
-  
 }
 
 
@@ -17696,7 +17289,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (double)jarg2; 
   if (arg1) (arg1)->rfactor = arg2;
-  
 }
 
 
@@ -17719,7 +17311,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (float *)jarg2; 
   if (arg1) (arg1)->from = arg2;
-  
 }
 
 
@@ -17742,7 +17333,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->from_len = arg2;
-  
 }
 
 
@@ -17771,7 +17361,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->from_size = arg2;
-  
 }
 
 
@@ -17782,7 +17371,7 @@
   
   arg1 = (switch_audio_resampler_t *)jarg1; 
   result =  ((arg1)->from_size);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -17794,7 +17383,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (float *)jarg2; 
   if (arg1) (arg1)->to = arg2;
-  
 }
 
 
@@ -17817,7 +17405,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->to_len = arg2;
-  
 }
 
 
@@ -17840,7 +17427,6 @@
   arg1 = (switch_audio_resampler_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->to_size = arg2;
-  
 }
 
 
@@ -17871,7 +17457,6 @@
   
   arg1 = (switch_audio_resampler_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -17883,8 +17468,8 @@
   int arg4 ;
   uint32_t arg5 ;
   switch_memory_pool_t *arg6 = (switch_memory_pool_t *) 0 ;
-  switch_status_t result;
   switch_size_t *argp3 ;
+  switch_status_t result;
   
   arg1 = (switch_audio_resampler_t **)jarg1; 
   arg2 = (int)jarg2; 
@@ -17938,8 +17523,8 @@
   float *arg1 = (float *) 0 ;
   short *arg2 = (short *) 0 ;
   switch_size_t arg3 ;
-  switch_size_t result;
   switch_size_t *argp3 ;
+  switch_size_t result;
   
   arg1 = (float *)jarg1; 
   arg2 = (short *)jarg2; 
@@ -17950,7 +17535,7 @@
   }
   arg3 = *argp3; 
   result = switch_float_to_short(arg1,arg2,arg3);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -18062,7 +17647,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_core_session_t *)jarg2; 
   if (arg1) (arg1)->session = arg2;
-  
 }
 
 
@@ -18085,7 +17669,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_codec_t *)jarg2; 
   if (arg1) (arg1)->read_codec = *arg2;
-  
 }
 
 
@@ -18108,7 +17691,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_frame_t *)jarg2; 
   if (arg1) (arg1)->write_frame = *arg2;
-  
 }
 
 
@@ -18157,7 +17739,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_socket_t *)jarg2; 
   if (arg1) (arg1)->socket = arg2;
-  
 }
 
 
@@ -18210,7 +17791,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_port_t)jarg2; 
   if (arg1) (arg1)->local_port = arg2;
-  
 }
 
 
@@ -18263,7 +17843,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_port_t)jarg2; 
   if (arg1) (arg1)->remote_port = arg2;
-  
 }
 
 
@@ -18286,7 +17865,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_sockaddr_t *)jarg2; 
   if (arg1) (arg1)->local_addr = arg2;
-  
 }
 
 
@@ -18309,7 +17887,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_sockaddr_t *)jarg2; 
   if (arg1) (arg1)->remote_addr = arg2;
-  
 }
 
 
@@ -18332,7 +17909,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (switch_mutex_t *)jarg2; 
   if (arg1) (arg1)->flag_mutex = arg2;
-  
 }
 
 
@@ -18355,7 +17931,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (int32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -18378,7 +17953,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->type = arg2;
-  
 }
 
 
@@ -18401,7 +17975,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->transport = arg2;
-  
 }
 
 
@@ -18424,7 +17997,6 @@
   arg1 = (switch_unicast_conninfo *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->stream_id = arg2;
-  
 }
 
 
@@ -18455,7 +18027,6 @@
   
   arg1 = (switch_unicast_conninfo *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -18636,9 +18207,9 @@
   uint32_t arg7 ;
   uint32_t arg8 ;
   uint32_t arg9 ;
-  switch_status_t result;
   switch_size_t *argp3 ;
   switch_size_t *argp4 ;
+  switch_status_t result;
   
   arg1 = (switch_core_session_t *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -18885,11 +18456,13 @@
 }
 
 
-SWIGEXPORT void SWIGSTDCALL CSharp_switch_ivr_session_echo(void * jarg1) {
+SWIGEXPORT void SWIGSTDCALL CSharp_switch_ivr_session_echo(void * jarg1, void * jarg2) {
   switch_core_session_t *arg1 = (switch_core_session_t *) 0 ;
+  switch_input_args_t *arg2 = (switch_input_args_t *) 0 ;
   
   arg1 = (switch_core_session_t *)jarg1; 
-  switch_ivr_session_echo(arg1);
+  arg2 = (switch_input_args_t *)jarg2; 
+  switch_ivr_session_echo(arg1,arg2);
 }
 
 
@@ -18914,8 +18487,8 @@
   time_t arg5 ;
   char *arg6 = (char *) 0 ;
   char *arg7 = (char *) 0 ;
-  switch_status_t result;
   time_t *argp5 ;
+  switch_status_t result;
   
   arg1 = (switch_core_session_t *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -19184,8 +18757,8 @@
   char *arg3 = (char *) 0 ;
   char *arg4 = (char *) 0 ;
   char *arg5 = (char *) 0 ;
-  uint32_t result;
   time_t *argp1 ;
+  uint32_t result;
   
   argp1 = (time_t *)jarg1; 
   if (!argp1) {
@@ -19209,8 +18782,8 @@
   char *arg2 = (char *) 0 ;
   switch_call_cause_t arg3 ;
   switch_bool_t arg4 ;
-  uint32_t result;
   time_t *argp1 ;
+  uint32_t result;
   
   argp1 = (time_t *)jarg1; 
   if (!argp1) {
@@ -19331,8 +18904,8 @@
   char *arg2 = (char *) 0 ;
   char *arg3 = (char *) 0 ;
   switch_media_flag_t arg4 ;
-  uint32_t result;
   time_t *argp1 ;
+  uint32_t result;
   
   argp1 = (time_t *)jarg1; 
   if (!argp1) {
@@ -19505,7 +19078,7 @@
 }
 
 
-SWIGEXPORT int SWIGSTDCALL CSharp_switch_ivr_menu_init(void * jarg1, void * jarg2, char * jarg3, char * jarg4, char * jarg5, char * jarg6, char * jarg7, char * jarg8, char * jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14, void * jarg15) {
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_ivr_menu_init(void * jarg1, void * jarg2, char * jarg3, char * jarg4, char * jarg5, char * jarg6, char * jarg7, char * jarg8, char * jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14, int jarg15, void * jarg16) {
   int jresult ;
   switch_ivr_menu_t **arg1 = (switch_ivr_menu_t **) 0 ;
   switch_ivr_menu_t *arg2 = (switch_ivr_menu_t *) 0 ;
@@ -19521,7 +19094,8 @@
   int arg12 ;
   int arg13 ;
   int arg14 ;
-  switch_memory_pool_t *arg15 = (switch_memory_pool_t *) 0 ;
+  int arg15 ;
+  switch_memory_pool_t *arg16 = (switch_memory_pool_t *) 0 ;
   switch_status_t result;
   
   arg1 = (switch_ivr_menu_t **)jarg1; 
@@ -19538,8 +19112,9 @@
   arg12 = (int)jarg12; 
   arg13 = (int)jarg13; 
   arg14 = (int)jarg14; 
-  arg15 = (switch_memory_pool_t *)jarg15; 
-  result = (switch_status_t)switch_ivr_menu_init(arg1,arg2,(char const *)arg3,(char const *)arg4,(char const *)arg5,(char const *)arg6,(char const *)arg7,(char const *)arg8,(char const *)arg9,arg10,arg11,arg12,arg13,arg14,arg15);
+  arg15 = (int)jarg15; 
+  arg16 = (switch_memory_pool_t *)jarg16; 
+  result = (switch_status_t)switch_ivr_menu_init(arg1,arg2,(char const *)arg3,(char const *)arg4,(char const *)arg5,(char const *)arg6,(char const *)arg7,(char const *)arg8,(char const *)arg9,arg10,arg11,arg12,arg13,arg14,arg15,arg16);
   jresult = result; 
   return jresult;
 }
@@ -19708,8 +19283,8 @@
   char *arg1 = (char *) 0 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  switch_status_t result;
   switch_size_t *argp3 ;
+  switch_status_t result;
   
   arg1 = (char *)jarg1; 
   arg2 = (char *)jarg2; 
@@ -19770,8 +19345,8 @@
   switch_size_t arg7 ;
   uint32_t arg8 ;
   char *arg9 = (char *) 0 ;
-  switch_status_t result;
   switch_size_t *argp7 ;
+  switch_status_t result;
   
   arg1 = (switch_core_session_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
@@ -19906,7 +19481,6 @@
   int result;
   
   result = (int) 16384;
-  
   jresult = result; 
   return jresult;
 }
@@ -19917,7 +19491,6 @@
   int result;
   
   result = (int) 64;
-  
   jresult = result; 
   return jresult;
 }
@@ -19928,7 +19501,6 @@
   int result;
   
   result = (int) 30;
-  
   jresult = result; 
   return jresult;
 }
@@ -19939,7 +19511,6 @@
   char *result = 0 ;
   
   result = (char *) "AES_CM_128_HMAC_SHA1_32";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -19950,7 +19521,6 @@
   char *result = 0 ;
   
   result = (char *) "AES_CM_128_HMAC_SHA1_80";
-  
   jresult = SWIG_csharp_string_callback((const char *)result); 
   return jresult;
 }
@@ -19963,7 +19533,6 @@
   arg1 = (switch_rtp_crypto_key *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->index = arg2;
-  
 }
 
 
@@ -19986,7 +19555,6 @@
   arg1 = (switch_rtp_crypto_key *)jarg1; 
   arg2 = (switch_rtp_crypto_key_type_t)jarg2; 
   if (arg1) (arg1)->type = arg2;
-  
 }
 
 
@@ -20041,7 +19609,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->keylen = arg2;
-  
 }
 
 
@@ -20052,7 +19619,7 @@
   
   arg1 = (switch_rtp_crypto_key *)jarg1; 
   result =  ((arg1)->keylen);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -20064,7 +19631,6 @@
   arg1 = (switch_rtp_crypto_key *)jarg1; 
   arg2 = (switch_rtp_crypto_key *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -20095,7 +19661,6 @@
   
   arg1 = (switch_rtp_crypto_key *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -20107,8 +19672,8 @@
   switch_rtp_crypto_key_type_t arg4 ;
   unsigned char *arg5 = (unsigned char *) 0 ;
   switch_size_t arg6 ;
-  switch_status_t result;
   switch_size_t *argp6 ;
+  switch_status_t result;
   
   arg1 = (switch_rtp_t *)jarg1; 
   arg2 = (switch_rtp_crypto_direction_t)jarg2; 
@@ -20254,19 +19819,21 @@
 }
 
 
-SWIGEXPORT int SWIGSTDCALL CSharp_switch_rtp_set_remote_address(void * jarg1, char * jarg2, unsigned short jarg3, void * jarg4) {
+SWIGEXPORT int SWIGSTDCALL CSharp_switch_rtp_set_remote_address(void * jarg1, char * jarg2, unsigned short jarg3, int jarg4, void * jarg5) {
   int jresult ;
   switch_rtp_t *arg1 = (switch_rtp_t *) 0 ;
   char *arg2 = (char *) 0 ;
   switch_port_t arg3 ;
-  char **arg4 = (char **) 0 ;
+  switch_bool_t arg4 ;
+  char **arg5 = (char **) 0 ;
   switch_status_t result;
   
   arg1 = (switch_rtp_t *)jarg1; 
   arg2 = (char *)jarg2; 
   arg3 = (switch_port_t)jarg3; 
-  arg4 = (char **)jarg4; 
-  result = (switch_status_t)switch_rtp_set_remote_address(arg1,(char const *)arg2,arg3,(char const **)arg4);
+  arg4 = (switch_bool_t)jarg4; 
+  arg5 = (char **)jarg5; 
+  result = (switch_status_t)switch_rtp_set_remote_address(arg1,(char const *)arg2,arg3,arg4,(char const **)arg5);
   jresult = result; 
   return jresult;
 }
@@ -20547,7 +20114,7 @@
   
   arg1 = (switch_rtp_t *)jarg1; 
   result = switch_rtp_has_dtmf(arg1);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -20561,7 +20128,7 @@
   arg1 = (switch_rtp_t *)jarg1; 
   arg2 = (switch_dtmf_t *)jarg2; 
   result = switch_rtp_dequeue_dtmf(arg1,arg2);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -20808,7 +20375,6 @@
   arg1 = (switch_log_node_t *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->line = arg2;
-  
 }
 
 
@@ -20856,7 +20422,6 @@
   arg1 = (switch_log_node_t *)jarg1; 
   arg2 = (switch_log_level_t)jarg2; 
   if (arg1) (arg1)->level = arg2;
-  
 }
 
 
@@ -20885,7 +20450,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->timestamp = arg2;
-  
 }
 
 
@@ -20896,7 +20460,7 @@
   
   arg1 = (switch_log_node_t *)jarg1; 
   result =  ((arg1)->timestamp);
-  jresult = new switch_time_t((switch_time_t &)result); 
+  jresult = new switch_time_t((const switch_time_t &)result); 
   return jresult;
 }
 
@@ -20975,7 +20539,6 @@
   
   arg1 = (switch_log_node_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -21072,7 +20635,6 @@
   int result;
   
   result = (int) 1024;
-  
   jresult = result; 
   return jresult;
 }
@@ -21115,7 +20677,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (char **)jarg2; 
   if (arg1) (arg1)->attr = arg2;
-  
 }
 
 
@@ -21204,7 +20765,6 @@
   }
   arg2 = *argp2; 
   if (arg1) (arg1)->off = arg2;
-  
 }
 
 
@@ -21215,7 +20775,7 @@
   
   arg1 = (switch_xml *)jarg1; 
   result =  ((arg1)->off);
-  jresult = new switch_size_t((switch_size_t &)result); 
+  jresult = new switch_size_t((const switch_size_t &)result); 
   return jresult;
 }
 
@@ -21227,7 +20787,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -21250,7 +20809,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
   if (arg1) (arg1)->sibling = arg2;
-  
 }
 
 
@@ -21273,7 +20831,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
   if (arg1) (arg1)->ordered = arg2;
-  
 }
 
 
@@ -21296,7 +20853,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
   if (arg1) (arg1)->child = arg2;
-  
 }
 
 
@@ -21319,7 +20875,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
   if (arg1) (arg1)->parent = arg2;
-  
 }
 
 
@@ -21342,7 +20897,6 @@
   arg1 = (switch_xml *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -21373,7 +20927,6 @@
   
   arg1 = (switch_xml *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -21381,8 +20934,8 @@
   void * jresult ;
   char *arg1 = (char *) 0 ;
   switch_size_t arg2 ;
-  switch_xml_t result;
   switch_size_t *argp2 ;
+  switch_xml_t result;
   
   arg1 = (char *)jarg1; 
   argp2 = (switch_size_t *)jarg2; 
@@ -21539,9 +21092,9 @@
   switch_size_t arg3 ;
   switch_size_t arg4 ;
   switch_bool_t arg5 ;
-  char *result = 0 ;
   switch_size_t *argp3 ;
   switch_size_t *argp4 ;
+  char *result = 0 ;
   
   arg1 = (switch_xml_t)jarg1; 
   arg2 = (char *)jarg2; 
@@ -21611,8 +21164,8 @@
   switch_xml_t arg1 = (switch_xml_t) 0 ;
   char *arg2 = (char *) 0 ;
   switch_size_t arg3 ;
-  switch_xml_t result;
   switch_size_t *argp3 ;
+  switch_xml_t result;
   
   arg1 = (switch_xml_t)jarg1; 
   arg2 = (char *)jarg2; 
@@ -21689,8 +21242,8 @@
   switch_xml_t arg1 = (switch_xml_t) 0 ;
   switch_xml_t arg2 = (switch_xml_t) 0 ;
   switch_size_t arg3 ;
-  switch_xml_t result;
   switch_size_t *argp3 ;
+  switch_xml_t result;
   
   arg1 = (switch_xml_t)jarg1; 
   arg2 = (switch_xml_t)jarg2; 
@@ -21897,7 +21450,6 @@
   arg1 = (switch_io_event_hook_outgoing_channel *)jarg1; 
   arg2 = (switch_outgoing_channel_hook_t)jarg2; 
   if (arg1) (arg1)->outgoing_channel = arg2;
-  
 }
 
 
@@ -21920,7 +21472,6 @@
   arg1 = (switch_io_event_hook_outgoing_channel *)jarg1; 
   arg2 = (switch_io_event_hook_outgoing_channel *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -21951,7 +21502,6 @@
   
   arg1 = (switch_io_event_hook_outgoing_channel *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -21962,7 +21512,6 @@
   arg1 = (switch_io_event_hook_receive_message *)jarg1; 
   arg2 = (switch_receive_message_hook_t)jarg2; 
   if (arg1) (arg1)->receive_message = arg2;
-  
 }
 
 
@@ -21985,7 +21534,6 @@
   arg1 = (switch_io_event_hook_receive_message *)jarg1; 
   arg2 = (switch_io_event_hook_receive_message *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22016,7 +21564,6 @@
   
   arg1 = (switch_io_event_hook_receive_message *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22027,7 +21574,6 @@
   arg1 = (switch_io_event_hook_receive_event *)jarg1; 
   arg2 = (switch_receive_event_hook_t)jarg2; 
   if (arg1) (arg1)->receive_event = arg2;
-  
 }
 
 
@@ -22050,7 +21596,6 @@
   arg1 = (switch_io_event_hook_receive_event *)jarg1; 
   arg2 = (switch_io_event_hook_receive_event *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22081,7 +21626,6 @@
   
   arg1 = (switch_io_event_hook_receive_event *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22092,7 +21636,6 @@
   arg1 = (switch_io_event_hook_read_frame *)jarg1; 
   arg2 = (switch_read_frame_hook_t)jarg2; 
   if (arg1) (arg1)->read_frame = arg2;
-  
 }
 
 
@@ -22115,7 +21658,6 @@
   arg1 = (switch_io_event_hook_read_frame *)jarg1; 
   arg2 = (switch_io_event_hook_read_frame *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22146,7 +21688,6 @@
   
   arg1 = (switch_io_event_hook_read_frame *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22157,7 +21698,6 @@
   arg1 = (switch_io_event_hook_video_read_frame *)jarg1; 
   arg2 = (switch_read_frame_hook_t)jarg2; 
   if (arg1) (arg1)->video_read_frame = arg2;
-  
 }
 
 
@@ -22180,7 +21720,6 @@
   arg1 = (switch_io_event_hook_video_read_frame *)jarg1; 
   arg2 = (switch_io_event_hook_video_read_frame *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22211,7 +21750,6 @@
   
   arg1 = (switch_io_event_hook_video_read_frame *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22222,7 +21760,6 @@
   arg1 = (switch_io_event_hook_write_frame *)jarg1; 
   arg2 = (switch_write_frame_hook_t)jarg2; 
   if (arg1) (arg1)->write_frame = arg2;
-  
 }
 
 
@@ -22245,7 +21782,6 @@
   arg1 = (switch_io_event_hook_write_frame *)jarg1; 
   arg2 = (switch_io_event_hook_write_frame *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22276,7 +21812,6 @@
   
   arg1 = (switch_io_event_hook_write_frame *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22287,7 +21822,6 @@
   arg1 = (switch_io_event_hook_video_write_frame *)jarg1; 
   arg2 = (switch_video_write_frame_hook_t)jarg2; 
   if (arg1) (arg1)->video_write_frame = arg2;
-  
 }
 
 
@@ -22310,7 +21844,6 @@
   arg1 = (switch_io_event_hook_video_write_frame *)jarg1; 
   arg2 = (switch_io_event_hook_video_write_frame *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22341,7 +21874,6 @@
   
   arg1 = (switch_io_event_hook_video_write_frame *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22352,7 +21884,6 @@
   arg1 = (switch_io_event_hook_kill_channel *)jarg1; 
   arg2 = (switch_kill_channel_hook_t)jarg2; 
   if (arg1) (arg1)->kill_channel = arg2;
-  
 }
 
 
@@ -22375,7 +21906,6 @@
   arg1 = (switch_io_event_hook_kill_channel *)jarg1; 
   arg2 = (switch_io_event_hook_kill_channel *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22406,7 +21936,6 @@
   
   arg1 = (switch_io_event_hook_kill_channel *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22417,7 +21946,6 @@
   arg1 = (switch_io_event_hook_send_dtmf *)jarg1; 
   arg2 = (switch_send_dtmf_hook_t)jarg2; 
   if (arg1) (arg1)->send_dtmf = arg2;
-  
 }
 
 
@@ -22440,7 +21968,6 @@
   arg1 = (switch_io_event_hook_send_dtmf *)jarg1; 
   arg2 = (switch_io_event_hook_send_dtmf *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22471,7 +21998,6 @@
   
   arg1 = (switch_io_event_hook_send_dtmf *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22482,7 +22008,6 @@
   arg1 = (switch_io_event_hook_recv_dtmf *)jarg1; 
   arg2 = (switch_recv_dtmf_hook_t)jarg2; 
   if (arg1) (arg1)->recv_dtmf = arg2;
-  
 }
 
 
@@ -22505,7 +22030,6 @@
   arg1 = (switch_io_event_hook_recv_dtmf *)jarg1; 
   arg2 = (switch_io_event_hook_recv_dtmf *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22536,7 +22060,6 @@
   
   arg1 = (switch_io_event_hook_recv_dtmf *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22547,7 +22070,6 @@
   arg1 = (switch_io_event_hook_state_change *)jarg1; 
   arg2 = (switch_state_change_hook_t)jarg2; 
   if (arg1) (arg1)->state_change = arg2;
-  
 }
 
 
@@ -22570,7 +22092,6 @@
   arg1 = (switch_io_event_hook_state_change *)jarg1; 
   arg2 = (switch_io_event_hook_state_change *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22601,7 +22122,6 @@
   
   arg1 = (switch_io_event_hook_state_change *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22612,7 +22132,6 @@
   arg1 = (switch_io_event_hook_resurrect_session *)jarg1; 
   arg2 = (switch_resurrect_session_hook_t)jarg2; 
   if (arg1) (arg1)->resurrect_session = arg2;
-  
 }
 
 
@@ -22635,7 +22154,6 @@
   arg1 = (switch_io_event_hook_resurrect_session *)jarg1; 
   arg2 = (switch_io_event_hook_resurrect_session *)jarg2; 
   if (arg1) (arg1)->next = arg2;
-  
 }
 
 
@@ -22666,7 +22184,6 @@
   
   arg1 = (switch_io_event_hook_resurrect_session *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -22677,7 +22194,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_outgoing_channel_t *)jarg2; 
   if (arg1) (arg1)->outgoing_channel = arg2;
-  
 }
 
 
@@ -22700,7 +22216,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_receive_message_t *)jarg2; 
   if (arg1) (arg1)->receive_message = arg2;
-  
 }
 
 
@@ -22723,7 +22238,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_receive_event_t *)jarg2; 
   if (arg1) (arg1)->receive_event = arg2;
-  
 }
 
 
@@ -22746,7 +22260,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_read_frame_t *)jarg2; 
   if (arg1) (arg1)->read_frame = arg2;
-  
 }
 
 
@@ -22769,7 +22282,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_video_read_frame_t *)jarg2; 
   if (arg1) (arg1)->video_read_frame = arg2;
-  
 }
 
 
@@ -22792,7 +22304,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_write_frame_t *)jarg2; 
   if (arg1) (arg1)->write_frame = arg2;
-  
 }
 
 
@@ -22815,7 +22326,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_video_write_frame_t *)jarg2; 
   if (arg1) (arg1)->video_write_frame = arg2;
-  
 }
 
 
@@ -22838,7 +22348,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_kill_channel_t *)jarg2; 
   if (arg1) (arg1)->kill_channel = arg2;
-  
 }
 
 
@@ -22861,7 +22370,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_send_dtmf_t *)jarg2; 
   if (arg1) (arg1)->send_dtmf = arg2;
-  
 }
 
 
@@ -22884,7 +22392,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_recv_dtmf_t *)jarg2; 
   if (arg1) (arg1)->recv_dtmf = arg2;
-  
 }
 
 
@@ -22907,7 +22414,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_state_change_t *)jarg2; 
   if (arg1) (arg1)->state_change = arg2;
-  
 }
 
 
@@ -22930,7 +22436,6 @@
   arg1 = (switch_io_event_hooks *)jarg1; 
   arg2 = (switch_io_event_hook_resurrect_session_t *)jarg2; 
   if (arg1) (arg1)->resurrect_session = arg2;
-  
 }
 
 
@@ -22961,7 +22466,6 @@
   
   arg1 = (switch_io_event_hooks *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -23308,7 +22812,6 @@
   arg1 = (switch_scheduler_task *)jarg1; 
   arg2 = (int64_t)jarg2; 
   if (arg1) (arg1)->created = arg2;
-  
 }
 
 
@@ -23331,7 +22834,6 @@
   arg1 = (switch_scheduler_task *)jarg1; 
   arg2 = (int64_t)jarg2; 
   if (arg1) (arg1)->runtime = arg2;
-  
 }
 
 
@@ -23354,7 +22856,6 @@
   arg1 = (switch_scheduler_task *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->cmd_id = arg2;
-  
 }
 
 
@@ -23407,7 +22908,6 @@
   arg1 = (switch_scheduler_task *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->cmd_arg = arg2;
-  
 }
 
 
@@ -23430,7 +22930,6 @@
   arg1 = (switch_scheduler_task *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->task_id = arg2;
-  
 }
 
 
@@ -23461,7 +22960,6 @@
   
   arg1 = (switch_scheduler_task *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -23474,8 +22972,8 @@
   uint32_t arg5 ;
   void *arg6 = (void *) 0 ;
   switch_scheduler_flag_t arg7 ;
-  uint32_t result;
   time_t *argp1 ;
+  uint32_t result;
   
   argp1 = (time_t *)jarg1; 
   if (!argp1) {
@@ -23536,7 +23034,6 @@
   arg1 = (switch_config *)jarg1; 
   arg2 = (FILE *)jarg2; 
   if (arg1) (arg1)->file = arg2;
-  
 }
 
 
@@ -23659,7 +23156,6 @@
   arg1 = (switch_config *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->lineno = arg2;
-  
 }
 
 
@@ -23682,7 +23178,6 @@
   arg1 = (switch_config *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->catno = arg2;
-  
 }
 
 
@@ -23705,7 +23200,6 @@
   arg1 = (switch_config *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->sectno = arg2;
-  
 }
 
 
@@ -23728,7 +23222,6 @@
   arg1 = (switch_config *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->lockto = arg2;
-  
 }
 
 
@@ -23759,7 +23252,6 @@
   
   arg1 = (switch_config *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -23819,7 +23311,7 @@
 }
 
 
-SWIGEXPORT void * SWIGSTDCALL CSharp_new_IvrMenu(void * jarg1, char * jarg2, char * jarg3, char * jarg4, char * jarg5, char * jarg6, char * jarg7, char * jarg8, int jarg9, int jarg10, int jarg11, int jarg12, int jarg13) {
+SWIGEXPORT void * SWIGSTDCALL CSharp_new_IvrMenu(void * jarg1, char * jarg2, char * jarg3, char * jarg4, char * jarg5, char * jarg6, char * jarg7, char * jarg8, int jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14) {
   void * jresult ;
   IVRMenu *arg1 = (IVRMenu *) 0 ;
   char *arg2 = (char *) 0 ;
@@ -23834,6 +23326,7 @@
   int arg11 ;
   int arg12 ;
   int arg13 ;
+  int arg14 ;
   IVRMenu *result = 0 ;
   
   arg1 = (IVRMenu *)jarg1; 
@@ -23849,7 +23342,8 @@
   arg11 = (int)jarg11; 
   arg12 = (int)jarg12; 
   arg13 = (int)jarg13; 
-  result = (IVRMenu *)new IVRMenu(arg1,(char const *)arg2,(char const *)arg3,(char const *)arg4,(char const *)arg5,(char const *)arg6,(char const *)arg7,(char const *)arg8,arg9,arg10,arg11,arg12,arg13);
+  arg14 = (int)jarg14; 
+  result = (IVRMenu *)new IVRMenu(arg1,(char const *)arg2,(char const *)arg3,(char const *)arg4,(char const *)arg5,(char const *)arg6,(char const *)arg7,(char const *)arg8,arg9,arg10,arg11,arg12,arg13,arg14);
   jresult = (void *)result; 
   return jresult;
 }
@@ -23860,7 +23354,6 @@
   
   arg1 = (IVRMenu *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -23905,7 +23398,6 @@
   
   arg1 = (API *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -23946,7 +23438,6 @@
   arg1 = (input_callback_state_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->function = arg2;
-  
 }
 
 
@@ -23969,7 +23460,6 @@
   arg1 = (input_callback_state_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->threadState = arg2;
-  
 }
 
 
@@ -23992,7 +23482,6 @@
   arg1 = (input_callback_state_t *)jarg1; 
   arg2 = (void *)jarg2; 
   if (arg1) (arg1)->extra = arg2;
-  
 }
 
 
@@ -24053,7 +23542,6 @@
   
   arg1 = (input_callback_state_t *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24064,7 +23552,6 @@
   arg1 = (DTMF *)jarg1; 
   arg2 = (char)jarg2; 
   if (arg1) (arg1)->digit = arg2;
-  
 }
 
 
@@ -24087,7 +23574,6 @@
   arg1 = (DTMF *)jarg1; 
   arg2 = (uint32_t)jarg2; 
   if (arg1) (arg1)->duration = arg2;
-  
 }
 
 
@@ -24122,7 +23608,6 @@
   
   arg1 = (DTMF *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24153,7 +23638,6 @@
   
   arg1 = (Stream *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24186,7 +23670,6 @@
   arg1 = (Event *)jarg1; 
   arg2 = (switch_event_t *)jarg2; 
   if (arg1) (arg1)->event = arg2;
-  
 }
 
 
@@ -24239,7 +23722,6 @@
   arg1 = (Event *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->mine = arg2;
-  
 }
 
 
@@ -24288,7 +23770,6 @@
   
   arg1 = (Event *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24421,7 +23902,6 @@
   arg1 = (EventConsumer *)jarg1; 
   arg2 = (switch_queue_t *)jarg2; 
   if (arg1) (arg1)->events = arg2;
-  
 }
 
 
@@ -24444,7 +23924,6 @@
   arg1 = (EventConsumer *)jarg1; 
   arg2 = (switch_event_types_t)jarg2; 
   if (arg1) (arg1)->e_event_id = arg2;
-  
 }
 
 
@@ -24467,7 +23946,6 @@
   arg1 = (EventConsumer *)jarg1; 
   arg2 = (switch_event_node_t *)jarg2; 
   if (arg1) (arg1)->node = arg2;
-  
 }
 
 
@@ -24592,7 +24070,6 @@
   
   arg1 = (EventConsumer *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24615,7 +24092,6 @@
   
   arg1 = (CoreSession *)jarg1; 
   delete arg1;
-  
 }
 
 
@@ -24626,7 +24102,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (switch_core_session_t *)jarg2; 
   if (arg1) (arg1)->session = arg2;
-  
 }
 
 
@@ -24649,7 +24124,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (switch_channel_t *)jarg2; 
   if (arg1) (arg1)->channel = arg2;
-  
 }
 
 
@@ -24672,7 +24146,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (unsigned int)jarg2; 
   if (arg1) (arg1)->flags = arg2;
-  
 }
 
 
@@ -24695,7 +24168,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (int)jarg2; 
   if (arg1) (arg1)->allocated = arg2;
-  
 }
 
 
@@ -24718,7 +24190,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (input_callback_state *)jarg2; 
   if (arg1) (arg1)->cb_state = *arg2;
-  
 }
 
 
@@ -24741,7 +24212,6 @@
   arg1 = (CoreSession *)jarg1; 
   arg2 = (switch_channel_state_t)jarg2; 
   if (arg1) (arg1)->hook_state = arg2;
-  
 }
 
 
@@ -25491,7 +24961,50 @@
   
   arg1 = (ManagedSession *)jarg1; 
   delete arg1;
+}
+
+
+SWIGEXPORT void SWIGSTDCALL CSharp_ManagedSession_dtmfDelegate_set(void * jarg1, void * jarg2) {
+  ManagedSession *arg1 = (ManagedSession *) 0 ;
+  inputFunction arg2 = (inputFunction) 0 ;
+  
+  arg1 = (ManagedSession *)jarg1; 
+  arg2 = (inputFunction)jarg2; 
+  if (arg1) (arg1)->dtmfDelegate = arg2;
+}
+
+
+SWIGEXPORT void * SWIGSTDCALL CSharp_ManagedSession_dtmfDelegate_get(void * jarg1) {
+  void * jresult ;
+  ManagedSession *arg1 = (ManagedSession *) 0 ;
+  inputFunction result;
+  
+  arg1 = (ManagedSession *)jarg1; 
+  result = (inputFunction) ((arg1)->dtmfDelegate);
+  jresult = (void *)result; 
+  return jresult;
+}
+
+
+SWIGEXPORT void SWIGSTDCALL CSharp_ManagedSession_hangupDelegate_set(void * jarg1, void * jarg2) {
+  ManagedSession *arg1 = (ManagedSession *) 0 ;
+  hangupFunction arg2 = (hangupFunction) 0 ;
+  
+  arg1 = (ManagedSession *)jarg1; 
+  arg2 = (hangupFunction)jarg2; 
+  if (arg1) (arg1)->hangupDelegate = arg2;
+}
+
+
+SWIGEXPORT void * SWIGSTDCALL CSharp_ManagedSession_hangupDelegate_get(void * jarg1) {
+  void * jresult ;
+  ManagedSession *arg1 = (ManagedSession *) 0 ;
+  hangupFunction result;
   
+  arg1 = (ManagedSession *)jarg1; 
+  result = (hangupFunction) ((arg1)->hangupDelegate);
+  jresult = (void *)result; 
+  return jresult;
 }
 
 

Modified: freeswitch/trunk/src/mod/languages/mod_managed/managed/swig.cs
==============================================================================
--- freeswitch/trunk/src/mod/languages/mod_managed/managed/swig.cs	(original)
+++ freeswitch/trunk/src/mod/languages/mod_managed/managed/swig.cs	Fri Oct  3 14:05:37 2008
@@ -1,63 +1,6 @@
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class Api : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
-
-  internal Api(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  internal static HandleRef getCPtr(Api obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~Api() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_Api(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
-
-  public Api() : this(freeswitchPINVOKE.new_Api(), true) {
-  }
-
-  public string Execute(string command, string data) {
-    string ret = freeswitchPINVOKE.Api_Execute(swigCPtr, command, data);
-    return ret;
-  }
-
-  public string ExecuteString(string command) {
-    string ret = freeswitchPINVOKE.Api_ExecuteString(swigCPtr, command);
-    return ret;
-  }
-
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -377,7 +320,7 @@
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -388,63 +331,70 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class DTMF : IDisposable {
+public partial class ManagedSession : CoreSession {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal DTMF(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal ManagedSession(IntPtr cPtr, bool cMemoryOwn) : base(freeswitchPINVOKE.ManagedSessionUpcast(cPtr), cMemoryOwn) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(DTMF obj) {
+  internal static HandleRef getCPtr(ManagedSession obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~DTMF() {
+  ~ManagedSession() {
     Dispose();
   }
 
-  public virtual void Dispose() {
+  public override void Dispose() {
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_DTMF(swigCPtr);
+        freeswitchPINVOKE.delete_ManagedSession(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
+      base.Dispose();
     }
   }
 
-  public char digit {
+  public ManagedSession() : this(freeswitchPINVOKE.new_ManagedSession__SWIG_0(), true) {
+  }
+
+  public ManagedSession(string uuid) : this(freeswitchPINVOKE.new_ManagedSession__SWIG_1(uuid), true) {
+  }
+
+  public ManagedSession(SWIGTYPE_p_switch_core_session session) : this(freeswitchPINVOKE.new_ManagedSession__SWIG_2(SWIGTYPE_p_switch_core_session.getCPtr(session)), true) {
+  }
+
+  public SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char dtmfDelegate {
     set {
-      freeswitchPINVOKE.DTMF_digit_set(swigCPtr, value);
+      freeswitchPINVOKE.ManagedSession_dtmfDelegate_set(swigCPtr, SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char.getCPtr(value));
     } 
     get {
-      char ret = freeswitchPINVOKE.DTMF_digit_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.ManagedSession_dtmfDelegate_get(swigCPtr);
+      SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char(cPtr, false);
       return ret;
     } 
   }
 
-  public uint duration {
+  public SWIGTYPE_p_f_void__void hangupDelegate {
     set {
-      freeswitchPINVOKE.DTMF_duration_set(swigCPtr, value);
+      freeswitchPINVOKE.ManagedSession_hangupDelegate_set(swigCPtr, SWIGTYPE_p_f_void__void.getCPtr(value));
     } 
     get {
-      uint ret = freeswitchPINVOKE.DTMF_duration_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.ManagedSession_hangupDelegate_get(swigCPtr);
+      SWIGTYPE_p_f_void__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_void__void(cPtr, false);
       return ret;
     } 
   }
 
-  public DTMF(char idigit, uint iduration) : this(freeswitchPINVOKE.new_DTMF(idigit, iduration), true) {
-  }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -455,9593 +405,9574 @@
 using System;
 using System.Runtime.InteropServices;
 
-public partial class Event : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+class freeswitchPINVOKE {
 
-  internal Event(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
-  }
+  protected class SWIGExceptionHelper {
 
-  internal static HandleRef getCPtr(Event obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+    public delegate void ExceptionDelegate(string message);
+    public delegate void ExceptionArgumentDelegate(string message, string paramName);
 
-  ~Event() {
-    Dispose();
-  }
+    static ExceptionDelegate applicationDelegate = new ExceptionDelegate(SetPendingApplicationException);
+    static ExceptionDelegate arithmeticDelegate = new ExceptionDelegate(SetPendingArithmeticException);
+    static ExceptionDelegate divideByZeroDelegate = new ExceptionDelegate(SetPendingDivideByZeroException);
+    static ExceptionDelegate indexOutOfRangeDelegate = new ExceptionDelegate(SetPendingIndexOutOfRangeException);
+    static ExceptionDelegate invalidCastDelegate = new ExceptionDelegate(SetPendingInvalidCastException);
+    static ExceptionDelegate invalidOperationDelegate = new ExceptionDelegate(SetPendingInvalidOperationException);
+    static ExceptionDelegate ioDelegate = new ExceptionDelegate(SetPendingIOException);
+    static ExceptionDelegate nullReferenceDelegate = new ExceptionDelegate(SetPendingNullReferenceException);
+    static ExceptionDelegate outOfMemoryDelegate = new ExceptionDelegate(SetPendingOutOfMemoryException);
+    static ExceptionDelegate overflowDelegate = new ExceptionDelegate(SetPendingOverflowException);
+    static ExceptionDelegate systemDelegate = new ExceptionDelegate(SetPendingSystemException);
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_Event(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+    static ExceptionArgumentDelegate argumentDelegate = new ExceptionArgumentDelegate(SetPendingArgumentException);
+    static ExceptionArgumentDelegate argumentNullDelegate = new ExceptionArgumentDelegate(SetPendingArgumentNullException);
+    static ExceptionArgumentDelegate argumentOutOfRangeDelegate = new ExceptionArgumentDelegate(SetPendingArgumentOutOfRangeException);
 
-  public switch_event InternalEvent {
-    set {
-      freeswitchPINVOKE.Event_InternalEvent_set(swigCPtr, switch_event.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.Event_InternalEvent_get(swigCPtr);
-      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
-      return ret;
-    } 
-  }
+    [DllImport("mod_managed", EntryPoint="SWIGRegisterExceptionCallbacks_freeswitch")]
+    public static extern void SWIGRegisterExceptionCallbacks_freeswitch(
+                                ExceptionDelegate applicationDelegate,
+                                ExceptionDelegate arithmeticDelegate,
+                                ExceptionDelegate divideByZeroDelegate, 
+                                ExceptionDelegate indexOutOfRangeDelegate, 
+                                ExceptionDelegate invalidCastDelegate,
+                                ExceptionDelegate invalidOperationDelegate,
+                                ExceptionDelegate ioDelegate,
+                                ExceptionDelegate nullReferenceDelegate,
+                                ExceptionDelegate outOfMemoryDelegate, 
+                                ExceptionDelegate overflowDelegate, 
+                                ExceptionDelegate systemExceptionDelegate);
 
-  public string serialized_string {
-    set {
-      freeswitchPINVOKE.Event_serialized_string_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.Event_serialized_string_get(swigCPtr);
-      return ret;
-    } 
-  }
+    [DllImport("mod_managed", EntryPoint="SWIGRegisterExceptionArgumentCallbacks_freeswitch")]
+    public static extern void SWIGRegisterExceptionCallbacksArgument_freeswitch(
+                                ExceptionArgumentDelegate argumentDelegate,
+                                ExceptionArgumentDelegate argumentNullDelegate,
+                                ExceptionArgumentDelegate argumentOutOfRangeDelegate);
 
-  public int mine {
-    set {
-      freeswitchPINVOKE.Event_mine_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.Event_mine_get(swigCPtr);
-      return ret;
-    } 
-  }
+    static void SetPendingApplicationException(string message) {
+      SWIGPendingException.Set(new System.ApplicationException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingArithmeticException(string message) {
+      SWIGPendingException.Set(new System.ArithmeticException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingDivideByZeroException(string message) {
+      SWIGPendingException.Set(new System.DivideByZeroException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingIndexOutOfRangeException(string message) {
+      SWIGPendingException.Set(new System.IndexOutOfRangeException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingInvalidCastException(string message) {
+      SWIGPendingException.Set(new System.InvalidCastException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingInvalidOperationException(string message) {
+      SWIGPendingException.Set(new System.InvalidOperationException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingIOException(string message) {
+      SWIGPendingException.Set(new System.IO.IOException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingNullReferenceException(string message) {
+      SWIGPendingException.Set(new System.NullReferenceException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingOutOfMemoryException(string message) {
+      SWIGPendingException.Set(new System.OutOfMemoryException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingOverflowException(string message) {
+      SWIGPendingException.Set(new System.OverflowException(message, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingSystemException(string message) {
+      SWIGPendingException.Set(new System.SystemException(message, SWIGPendingException.Retrieve()));
+    }
 
-  public Event(string type, string subclass_name) : this(freeswitchPINVOKE.new_Event__SWIG_0(type, subclass_name), true) {
-  }
+    static void SetPendingArgumentException(string message, string paramName) {
+      SWIGPendingException.Set(new System.ArgumentException(message, paramName, SWIGPendingException.Retrieve()));
+    }
+    static void SetPendingArgumentNullException(string message, string paramName) {
+      Exception e = SWIGPendingException.Retrieve();
+      if (e != null) message = message + " Inner Exception: " + e.Message;
+      SWIGPendingException.Set(new System.ArgumentNullException(paramName, message));
+    }
+    static void SetPendingArgumentOutOfRangeException(string message, string paramName) {
+      Exception e = SWIGPendingException.Retrieve();
+      if (e != null) message = message + " Inner Exception: " + e.Message;
+      SWIGPendingException.Set(new System.ArgumentOutOfRangeException(paramName, message));
+    }
 
-  public Event(switch_event wrap_me, int free_me) : this(freeswitchPINVOKE.new_Event__SWIG_1(switch_event.getCPtr(wrap_me), free_me), true) {
-  }
+    static SWIGExceptionHelper() {
+      SWIGRegisterExceptionCallbacks_freeswitch(
+                                applicationDelegate,
+                                arithmeticDelegate,
+                                divideByZeroDelegate,
+                                indexOutOfRangeDelegate,
+                                invalidCastDelegate,
+                                invalidOperationDelegate,
+                                ioDelegate,
+                                nullReferenceDelegate,
+                                outOfMemoryDelegate,
+                                overflowDelegate,
+                                systemDelegate);
 
-  public string Serialize(string format) {
-    string ret = freeswitchPINVOKE.Event_Serialize(swigCPtr, format);
-    return ret;
+      SWIGRegisterExceptionCallbacksArgument_freeswitch(
+                                argumentDelegate,
+                                argumentNullDelegate,
+                                argumentOutOfRangeDelegate);
+    }
   }
 
-  public bool SetPriority(switch_priority_t priority) {
-    bool ret = freeswitchPINVOKE.Event_SetPriority(swigCPtr, (int)priority);
-    return ret;
-  }
+  protected static SWIGExceptionHelper swigExceptionHelper = new SWIGExceptionHelper();
 
-  public string GetHeader(string header_name) {
-    string ret = freeswitchPINVOKE.Event_GetHeader(swigCPtr, header_name);
-    return ret;
-  }
+  public class SWIGPendingException {
+    [ThreadStatic]
+    private static Exception pendingException = null;
+    private static int numExceptionsPending = 0;
 
-  public string GetBody() {
-    string ret = freeswitchPINVOKE.Event_GetBody(swigCPtr);
-    return ret;
-  }
+    public static bool Pending {
+      get {
+        bool pending = false;
+        if (numExceptionsPending > 0)
+          if (pendingException != null)
+            pending = true;
+        return pending;
+      } 
+    }
 
-  public string GetEventType() {
-    string ret = freeswitchPINVOKE.Event_GetEventType(swigCPtr);
-    return ret;
-  }
+    public static void Set(Exception e) {
+      if (pendingException != null)
+        throw new ApplicationException("FATAL: An earlier pending exception from unmanaged code was missed and thus not thrown (" + pendingException.ToString() + ")", e);
+      pendingException = e;
+      lock(typeof(freeswitchPINVOKE)) {
+        numExceptionsPending++;
+      }
+    }
 
-  public bool AddBody(string value) {
-    bool ret = freeswitchPINVOKE.Event_AddBody(swigCPtr, value);
-    return ret;
+    public static Exception Retrieve() {
+      Exception e = null;
+      if (numExceptionsPending > 0) {
+        if (pendingException != null) {
+          e = pendingException;
+          pendingException = null;
+          lock(typeof(freeswitchPINVOKE)) {
+            numExceptionsPending--;
+          }
+        }
+      }
+      return e;
+    }
   }
 
-  public bool AddHeader(string header_name, string value) {
-    bool ret = freeswitchPINVOKE.Event_AddHeader(swigCPtr, header_name, value);
-    return ret;
-  }
 
-  public bool DeleteHeader(string header_name) {
-    bool ret = freeswitchPINVOKE.Event_DeleteHeader(swigCPtr, header_name);
-    return ret;
-  }
+  protected class SWIGStringHelper {
 
-  public bool Fire() {
-    bool ret = freeswitchPINVOKE.Event_Fire(swigCPtr);
-    return ret;
-  }
+    public delegate string SWIGStringDelegate(string message);
+    static SWIGStringDelegate stringDelegate = new SWIGStringDelegate(CreateString);
 
-}
+    [DllImport("mod_managed", EntryPoint="SWIGRegisterStringCallback_freeswitch")]
+    public static extern void SWIGRegisterStringCallback_freeswitch(SWIGStringDelegate stringDelegate);
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+    static string CreateString(string cString) {
+      return cString;
+    }
 
-namespace FreeSWITCH.Native {
+    static SWIGStringHelper() {
+      SWIGRegisterStringCallback_freeswitch(stringDelegate);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  static protected SWIGStringHelper swigStringHelper = new SWIGStringHelper();
 
-public class EventConsumer : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal EventConsumer(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_PEN_get")]
+  public static extern string FREESWITCH_PEN_get();
 
-  internal static HandleRef getCPtr(EventConsumer obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_OID_PREFIX_get")]
+  public static extern string FREESWITCH_OID_PREFIX_get();
 
-  ~EventConsumer() {
-    Dispose();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_ITAD_get")]
+  public static extern string FREESWITCH_ITAD_get();
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_EventConsumer(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp___EXTENSIONS___get")]
+  public static extern int __EXTENSIONS___get();
 
-  public SWIGTYPE_p_switch_queue_t events {
-    set {
-      freeswitchPINVOKE.EventConsumer_events_set(swigCPtr, SWIGTYPE_p_switch_queue_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.EventConsumer_events_get(swigCPtr);
-      SWIGTYPE_p_switch_queue_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_queue_t(cPtr, false);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp___BSD_VISIBLE_get")]
+  public static extern int __BSD_VISIBLE_get();
 
-  public switch_event_types_t e_event_id {
-    set {
-      freeswitchPINVOKE.EventConsumer_e_event_id_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_event_types_t ret = (switch_event_types_t)freeswitchPINVOKE.EventConsumer_e_event_id_get(swigCPtr);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BLANK_STRING_get")]
+  public static extern string SWITCH_BLANK_STRING_get();
 
-  public SWIGTYPE_p_switch_event_node node {
-    set {
-      freeswitchPINVOKE.EventConsumer_node_set(swigCPtr, SWIGTYPE_p_switch_event_node.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.EventConsumer_node_get(swigCPtr);
-      SWIGTYPE_p_switch_event_node ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_event_node(cPtr, false);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_ESC_get")]
+  public static extern string SWITCH_SEQ_ESC_get();
 
-  public string e_callback {
-    set {
-      freeswitchPINVOKE.EventConsumer_e_callback_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.EventConsumer_e_callback_get(swigCPtr);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_CHAR_get")]
+  public static extern char SWITCH_SEQ_HOME_CHAR_get();
 
-  public string e_subclass_name {
-    set {
-      freeswitchPINVOKE.EventConsumer_e_subclass_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.EventConsumer_e_subclass_name_get(swigCPtr);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_CHAR_STR_get")]
+  public static extern string SWITCH_SEQ_HOME_CHAR_STR_get();
 
-  public string e_cb_arg {
-    set {
-      freeswitchPINVOKE.EventConsumer_e_cb_arg_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.EventConsumer_e_cb_arg_get(swigCPtr);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_CHAR_get")]
+  public static extern char SWITCH_SEQ_CLEARLINE_CHAR_get();
 
-  public EventConsumer(string event_name, string subclass_name) : this(freeswitchPINVOKE.new_EventConsumer(event_name, subclass_name), true) {
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_CHAR_STR_get")]
+  public static extern string SWITCH_SEQ_CLEARLINE_CHAR_STR_get();
 
-  public Event pop(int block) {
-    IntPtr cPtr = freeswitchPINVOKE.EventConsumer_pop(swigCPtr, block);
-    Event ret = (cPtr == IntPtr.Zero) ? null : new Event(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINEEND_CHAR_get")]
+  public static extern string SWITCH_SEQ_CLEARLINEEND_CHAR_get();
 
-}
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR0_get")]
+  public static extern char SWITCH_SEQ_CLEARSCR_CHAR0_get();
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR1_get")]
+  public static extern char SWITCH_SEQ_CLEARSCR_CHAR1_get();
 
-namespace FreeSWITCH.Native {
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR_get")]
+  public static extern string SWITCH_SEQ_CLEARSCR_CHAR_get();
 
-using System;
-using System.Runtime.InteropServices;
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_AND_COLOR_get")]
+  public static extern string SWITCH_SEQ_AND_COLOR_get();
 
-public class freeswitch {
-  public static switch_directories SWITCH_GLOBAL_dirs {
-    set {
-      freeswitchPINVOKE.SWITCH_GLOBAL_dirs_set(switch_directories.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.SWITCH_GLOBAL_dirs_get();
-      switch_directories ret = (cPtr == IntPtr.Zero) ? null : new switch_directories(cPtr, false);
-      return ret;
-    } 
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_END_COLOR_get")]
+  public static extern string SWITCH_SEQ_END_COLOR_get();
 
-  public static int switch_core_db_close(SWIGTYPE_p_sqlite3 db) {
-    int ret = freeswitchPINVOKE.switch_core_db_close(SWIGTYPE_p_sqlite3.getCPtr(db));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_BLACK_get")]
+  public static extern string SWITCH_SEQ_F_BLACK_get();
 
-  public static int switch_core_db_open(string filename, SWIGTYPE_p_p_sqlite3 ppDb) {
-    int ret = freeswitchPINVOKE.switch_core_db_open(filename, SWIGTYPE_p_p_sqlite3.getCPtr(ppDb));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_RED_get")]
+  public static extern string SWITCH_SEQ_F_RED_get();
 
-  public static SWIGTYPE_p_unsigned_char switch_core_db_column_text(SWIGTYPE_p_sqlite3_stmt stmt, int iCol) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_db_column_text(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt), iCol);
-    SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_GREEN_get")]
+  public static extern string SWITCH_SEQ_F_GREEN_get();
 
-  public static string switch_core_db_column_name(SWIGTYPE_p_sqlite3_stmt stmt, int N) {
-    string ret = freeswitchPINVOKE.switch_core_db_column_name(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt), N);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_YELLOW_get")]
+  public static extern string SWITCH_SEQ_F_YELLOW_get();
 
-  public static int switch_core_db_column_count(SWIGTYPE_p_sqlite3_stmt pStmt) {
-    int ret = freeswitchPINVOKE.switch_core_db_column_count(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_BLUE_get")]
+  public static extern string SWITCH_SEQ_F_BLUE_get();
 
-  public static string switch_core_db_errmsg(SWIGTYPE_p_sqlite3 db) {
-    string ret = freeswitchPINVOKE.switch_core_db_errmsg(SWIGTYPE_p_sqlite3.getCPtr(db));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_MAGEN_get")]
+  public static extern string SWITCH_SEQ_F_MAGEN_get();
 
-  public static int switch_core_db_exec(SWIGTYPE_p_sqlite3 db, string sql, SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int callback, SWIGTYPE_p_void data, ref string errmsg) {
-    int ret = freeswitchPINVOKE.switch_core_db_exec(SWIGTYPE_p_sqlite3.getCPtr(db), sql, SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int.getCPtr(callback), SWIGTYPE_p_void.getCPtr(data), ref errmsg);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_CYAN_get")]
+  public static extern string SWITCH_SEQ_F_CYAN_get();
 
-  public static int switch_core_db_finalize(SWIGTYPE_p_sqlite3_stmt pStmt) {
-    int ret = freeswitchPINVOKE.switch_core_db_finalize(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_WHITE_get")]
+  public static extern string SWITCH_SEQ_F_WHITE_get();
 
-  public static int switch_core_db_prepare(SWIGTYPE_p_sqlite3 db, string zSql, int nBytes, SWIGTYPE_p_p_sqlite3_stmt ppStmt, ref string pzTail) {
-    int ret = freeswitchPINVOKE.switch_core_db_prepare(SWIGTYPE_p_sqlite3.getCPtr(db), zSql, nBytes, SWIGTYPE_p_p_sqlite3_stmt.getCPtr(ppStmt), ref pzTail);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_BLACK_get")]
+  public static extern string SWITCH_SEQ_B_BLACK_get();
 
-  public static int switch_core_db_step(SWIGTYPE_p_sqlite3_stmt stmt) {
-    int ret = freeswitchPINVOKE.switch_core_db_step(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_RED_get")]
+  public static extern string SWITCH_SEQ_B_RED_get();
 
-  public static int switch_core_db_reset(SWIGTYPE_p_sqlite3_stmt pStmt) {
-    int ret = freeswitchPINVOKE.switch_core_db_reset(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_GREEN_get")]
+  public static extern string SWITCH_SEQ_B_GREEN_get();
 
-  public static int switch_core_db_bind_int(SWIGTYPE_p_sqlite3_stmt pStmt, int i, int iValue) {
-    int ret = freeswitchPINVOKE.switch_core_db_bind_int(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, iValue);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_YELLOW_get")]
+  public static extern string SWITCH_SEQ_B_YELLOW_get();
 
-  public static int switch_core_db_bind_int64(SWIGTYPE_p_sqlite3_stmt pStmt, int i, long iValue) {
-    int ret = freeswitchPINVOKE.switch_core_db_bind_int64(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, iValue);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_BLUE_get")]
+  public static extern string SWITCH_SEQ_B_BLUE_get();
 
-  public static int switch_core_db_bind_text(SWIGTYPE_p_sqlite3_stmt pStmt, int i, string zData, int nData, SWIGTYPE_p_f_p_void__void xDel) {
-    int ret = freeswitchPINVOKE.switch_core_db_bind_text(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, zData, nData, SWIGTYPE_p_f_p_void__void.getCPtr(xDel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_MAGEN_get")]
+  public static extern string SWITCH_SEQ_B_MAGEN_get();
 
-  public static int switch_core_db_bind_double(SWIGTYPE_p_sqlite3_stmt pStmt, int i, double dValue) {
-    int ret = freeswitchPINVOKE.switch_core_db_bind_double(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, dValue);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_CYAN_get")]
+  public static extern string SWITCH_SEQ_B_CYAN_get();
 
-  public static long switch_core_db_last_insert_rowid(SWIGTYPE_p_sqlite3 db) {
-    long ret = freeswitchPINVOKE.switch_core_db_last_insert_rowid(SWIGTYPE_p_sqlite3.getCPtr(db));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_WHITE_get")]
+  public static extern string SWITCH_SEQ_B_WHITE_get();
 
-  public static int switch_core_db_get_table(SWIGTYPE_p_sqlite3 db, string sql, SWIGTYPE_p_p_p_char resultp, SWIGTYPE_p_int nrow, SWIGTYPE_p_int ncolumn, ref string errmsg) {
-    int ret = freeswitchPINVOKE.switch_core_db_get_table(SWIGTYPE_p_sqlite3.getCPtr(db), sql, SWIGTYPE_p_p_p_char.getCPtr(resultp), SWIGTYPE_p_int.getCPtr(nrow), SWIGTYPE_p_int.getCPtr(ncolumn), ref errmsg);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FBLACK_get")]
+  public static extern string SWITCH_SEQ_FBLACK_get();
 
-  public static void switch_core_db_free_table(ref string result) {
-    freeswitchPINVOKE.switch_core_db_free_table(ref result);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FRED_get")]
+  public static extern string SWITCH_SEQ_FRED_get();
 
-  public static void switch_core_db_free(string z) {
-    freeswitchPINVOKE.switch_core_db_free(z);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FGREEN_get")]
+  public static extern string SWITCH_SEQ_FGREEN_get();
 
-  public static int switch_core_db_changes(SWIGTYPE_p_sqlite3 db) {
-    int ret = freeswitchPINVOKE.switch_core_db_changes(SWIGTYPE_p_sqlite3.getCPtr(db));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FYELLOW_get")]
+  public static extern string SWITCH_SEQ_FYELLOW_get();
 
-  public static string switch_mprintf(string zFormat) {
-    string ret = freeswitchPINVOKE.switch_mprintf(zFormat);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FBLUE_get")]
+  public static extern string SWITCH_SEQ_FBLUE_get();
 
-  public static SWIGTYPE_p_real_pcre switch_regex_compile(string pattern, int options, ref string errorptr, SWIGTYPE_p_int erroroffset, SWIGTYPE_p_unsigned_char tables) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_regex_compile(pattern, options, ref errorptr, SWIGTYPE_p_int.getCPtr(erroroffset), SWIGTYPE_p_unsigned_char.getCPtr(tables));
-    SWIGTYPE_p_real_pcre ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_real_pcre(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FMAGEN_get")]
+  public static extern string SWITCH_SEQ_FMAGEN_get();
 
-  public static int switch_regex_copy_substring(string subject, SWIGTYPE_p_int ovector, int stringcount, int stringnumber, string buffer, int size) {
-    int ret = freeswitchPINVOKE.switch_regex_copy_substring(subject, SWIGTYPE_p_int.getCPtr(ovector), stringcount, stringnumber, buffer, size);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FCYAN_get")]
+  public static extern string SWITCH_SEQ_FCYAN_get();
 
-  public static void switch_regex_free(SWIGTYPE_p_void data) {
-    freeswitchPINVOKE.switch_regex_free(SWIGTYPE_p_void.getCPtr(data));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FWHITE_get")]
+  public static extern string SWITCH_SEQ_FWHITE_get();
 
-  public static int switch_regex_perform(string field, string expression, SWIGTYPE_p_p_real_pcre new_re, SWIGTYPE_p_int ovector, uint olen) {
-    int ret = freeswitchPINVOKE.switch_regex_perform(field, expression, SWIGTYPE_p_p_real_pcre.getCPtr(new_re), SWIGTYPE_p_int.getCPtr(ovector), olen);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BBLACK_get")]
+  public static extern string SWITCH_SEQ_BBLACK_get();
 
-  public static void switch_perform_substitution(SWIGTYPE_p_real_pcre re, int match_count, string data, string field_data, string substituted, SWIGTYPE_p_switch_size_t len, SWIGTYPE_p_int ovector) {
-    freeswitchPINVOKE.switch_perform_substitution(SWIGTYPE_p_real_pcre.getCPtr(re), match_count, data, field_data, substituted, SWIGTYPE_p_switch_size_t.getCPtr(len), SWIGTYPE_p_int.getCPtr(ovector));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BRED_get")]
+  public static extern string SWITCH_SEQ_BRED_get();
 
-  public static switch_status_t switch_regex_match(string target, string expression) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_regex_match(target, expression);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BGREEN_get")]
+  public static extern string SWITCH_SEQ_BGREEN_get();
 
-  public static switch_status_t switch_regex_match_partial(string target, string expression, SWIGTYPE_p_int partial_match) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_regex_match_partial(target, expression, SWIGTYPE_p_int.getCPtr(partial_match));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BYELLOW_get")]
+  public static extern string SWITCH_SEQ_BYELLOW_get();
 
-  public static switch_status_t switch_core_media_bug_add(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t callback, SWIGTYPE_p_void user_data, SWIGTYPE_p_time_t stop_time, uint flags, SWIGTYPE_p_p_switch_media_bug new_bug) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_add(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data), SWIGTYPE_p_time_t.getCPtr(stop_time), flags, SWIGTYPE_p_p_switch_media_bug.getCPtr(new_bug));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BBLUE_get")]
+  public static extern string SWITCH_SEQ_BBLUE_get();
 
-  public static SWIGTYPE_p_void switch_core_media_bug_get_user_data(SWIGTYPE_p_switch_media_bug bug) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_user_data(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BMAGEN_get")]
+  public static extern string SWITCH_SEQ_BMAGEN_get();
 
-  public static switch_frame switch_core_media_bug_get_write_replace_frame(SWIGTYPE_p_switch_media_bug bug) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_write_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
-    switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BCYAN_get")]
+  public static extern string SWITCH_SEQ_BCYAN_get();
 
-  public static void switch_core_media_bug_set_write_replace_frame(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
-    freeswitchPINVOKE.switch_core_media_bug_set_write_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BWHITE_get")]
+  public static extern string SWITCH_SEQ_BWHITE_get();
 
-  public static switch_frame switch_core_media_bug_get_read_replace_frame(SWIGTYPE_p_switch_media_bug bug) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_read_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
-    switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_get")]
+  public static extern string SWITCH_SEQ_HOME_get();
 
-  public static SWIGTYPE_p_switch_core_session switch_core_media_bug_get_session(SWIGTYPE_p_switch_media_bug bug) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_session(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
-    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_get")]
+  public static extern string SWITCH_SEQ_CLEARLINE_get();
 
-  public static uint switch_core_media_bug_test_flag(SWIGTYPE_p_switch_media_bug bug, uint flag) {
-    uint ret = freeswitchPINVOKE.switch_core_media_bug_test_flag(SWIGTYPE_p_switch_media_bug.getCPtr(bug), flag);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINEEND_get")]
+  public static extern string SWITCH_SEQ_CLEARLINEEND_get();
 
-  public static void switch_core_media_bug_set_read_replace_frame(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
-    freeswitchPINVOKE.switch_core_media_bug_set_read_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_get")]
+  public static extern string SWITCH_SEQ_CLEARSCR_get();
 
-  public static switch_status_t switch_core_media_bug_remove(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_media_bug bug) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_remove(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_media_bug.getCPtr(bug));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_DEFAULT_DTMF_DURATION_get")]
+  public static extern int SWITCH_DEFAULT_DTMF_DURATION_get();
 
-  public static switch_status_t switch_core_media_bug_close(SWIGTYPE_p_p_switch_media_bug bug) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_close(SWIGTYPE_p_p_switch_media_bug.getCPtr(bug));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_DTMF_DURATION_get")]
+  public static extern int SWITCH_MAX_DTMF_DURATION_get();
 
-  public static switch_status_t switch_core_media_bug_remove_all(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_remove_all(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PATH_SEPARATOR_get")]
+  public static extern string SWITCH_PATH_SEPARATOR_get();
 
-  public static switch_status_t switch_core_media_bug_read(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_read(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_URL_SEPARATOR_get")]
+  public static extern string SWITCH_URL_SEPARATOR_get();
 
-  public static switch_status_t switch_core_port_allocator_new(ushort start, ushort end, uint flags, SWIGTYPE_p_p_switch_core_port_allocator new_allocator) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_new(start, end, flags, SWIGTYPE_p_p_switch_core_port_allocator.getCPtr(new_allocator));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get")]
+  public static extern string SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get();
 
-  public static switch_status_t switch_core_port_allocator_request_port(SWIGTYPE_p_switch_core_port_allocator alloc, SWIGTYPE_p_unsigned_short port_ptr) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_request_port(SWIGTYPE_p_switch_core_port_allocator.getCPtr(alloc), SWIGTYPE_p_unsigned_short.getCPtr(port_ptr));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_READ_RESULT_VARIABLE_get")]
+  public static extern string SWITCH_READ_RESULT_VARIABLE_get();
 
-  public static switch_status_t switch_core_port_allocator_free_port(SWIGTYPE_p_switch_core_port_allocator alloc, ushort port) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_free_port(SWIGTYPE_p_switch_core_port_allocator.getCPtr(alloc), port);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_COPY_XML_CDR_VARIABLE_get")]
+  public static extern string SWITCH_COPY_XML_CDR_VARIABLE_get();
 
-  public static void switch_core_port_allocator_destroy(SWIGTYPE_p_p_switch_core_port_allocator alloc) {
-    freeswitchPINVOKE.switch_core_port_allocator_destroy(SWIGTYPE_p_p_switch_core_port_allocator.getCPtr(alloc));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CURRENT_APPLICATION_VARIABLE_get")]
+  public static extern string SWITCH_CURRENT_APPLICATION_VARIABLE_get();
 
-  public static switch_status_t switch_core_init(uint flags, switch_bool_t console, ref string err) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_init(flags, (int)console, ref err);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get")]
+  public static extern string SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get();
 
-  public static switch_status_t switch_core_init_and_modload(uint flags, switch_bool_t console, ref string err) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_init_and_modload(flags, (int)console, ref err);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get")]
+  public static extern string SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get();
 
-  public static uint switch_core_session_limit(uint new_limit) {
-    uint ret = freeswitchPINVOKE.switch_core_session_limit(new_limit);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get")]
+  public static extern string SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get();
 
-  public static uint switch_core_sessions_per_second(uint new_limit) {
-    uint ret = freeswitchPINVOKE.switch_core_sessions_per_second(new_limit);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CALL_TIMEOUT_VARIABLE_get")]
+  public static extern string SWITCH_CALL_TIMEOUT_VARIABLE_get();
 
-  public static switch_status_t switch_core_destroy() {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_destroy();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HOLDING_UUID_VARIABLE_get")]
+  public static extern string SWITCH_HOLDING_UUID_VARIABLE_get();
 
-  public static switch_status_t switch_core_session_signal_lock(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_signal_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_BRIDGE_END_VARIABLE_get")]
+  public static extern string SWITCH_API_BRIDGE_END_VARIABLE_get();
 
-  public static switch_status_t switch_core_session_signal_unlock(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_signal_unlock(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_HANGUP_HOOK_VARIABLE_get")]
+  public static extern string SWITCH_API_HANGUP_HOOK_VARIABLE_get();
 
-  public static switch_status_t switch_core_session_read_lock(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROCESS_CDR_VARIABLE_get")]
+  public static extern string SWITCH_PROCESS_CDR_VARIABLE_get();
 
-  public static void switch_core_session_write_lock(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_core_session_write_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_CHANNEL_VARIABLE_get")]
+  public static extern string SWITCH_BRIDGE_CHANNEL_VARIABLE_get();
 
-  public static void switch_core_session_rwunlock(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_core_session_rwunlock(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_NAME_VARIABLE_get")]
+  public static extern string SWITCH_CHANNEL_NAME_VARIABLE_get();
 
-  public static int switch_core_add_state_handler(switch_state_handler_table state_handler) {
-    int ret = freeswitchPINVOKE.switch_core_add_state_handler(switch_state_handler_table.getCPtr(state_handler));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_UUID_VARIABLE_get")]
+  public static extern string SWITCH_BRIDGE_UUID_VARIABLE_get();
 
-  public static void switch_core_remove_state_handler(switch_state_handler_table state_handler) {
-    freeswitchPINVOKE.switch_core_remove_state_handler(switch_state_handler_table.getCPtr(state_handler));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get")]
+  public static extern string SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get();
 
-  public static switch_state_handler_table switch_core_get_state_handler(int index) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_get_state_handler(index);
-    switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get")]
+  public static extern string SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get();
 
-  public static void switch_core_memory_pool_tag(SWIGTYPE_p_apr_pool_t pool, string tag) {
-    freeswitchPINVOKE.switch_core_memory_pool_tag(SWIGTYPE_p_apr_pool_t.getCPtr(pool), tag);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PLAYBACK_TERMINATOR_USED_get")]
+  public static extern string SWITCH_PLAYBACK_TERMINATOR_USED_get();
 
-  public static switch_status_t switch_core_perform_new_memory_pool(SWIGTYPE_p_p_apr_pool_t pool, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_new_memory_pool(SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get")]
+  public static extern string SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get();
 
-  public static switch_status_t switch_core_perform_destroy_memory_pool(SWIGTYPE_p_p_apr_pool_t pool, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_destroy_memory_pool(SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get")]
+  public static extern string SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get();
 
-  public static void switch_core_session_run(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_core_session_run(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYPASS_MEDIA_VARIABLE_get")]
+  public static extern string SWITCH_BYPASS_MEDIA_VARIABLE_get();
 
-  public static uint switch_core_session_running(SWIGTYPE_p_switch_core_session session) {
-    uint ret = freeswitchPINVOKE.switch_core_session_running(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROXY_MEDIA_VARIABLE_get")]
+  public static extern string SWITCH_PROXY_MEDIA_VARIABLE_get();
 
-  public static SWIGTYPE_p_void switch_core_perform_permanent_alloc(SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_permanent_alloc(SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get")]
+  public static extern string SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get();
 
-  public static SWIGTYPE_p_void switch_core_perform_alloc(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_alloc(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HOLD_MUSIC_VARIABLE_get")]
+  public static extern string SWITCH_HOLD_MUSIC_VARIABLE_get();
 
-  public static SWIGTYPE_p_void switch_core_perform_session_alloc(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_session_alloc(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXPORT_VARS_VARIABLE_get")]
+  public static extern string SWITCH_EXPORT_VARS_VARIABLE_get();
 
-  public static string switch_core_perform_permanent_strdup(string todup, string file, string func, int line) {
-    string ret = freeswitchPINVOKE.switch_core_perform_permanent_strdup(todup, file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_R_SDP_VARIABLE_get")]
+  public static extern string SWITCH_R_SDP_VARIABLE_get();
 
-  public static string switch_core_perform_session_strdup(SWIGTYPE_p_switch_core_session session, string todup, string file, string func, int line) {
-    string ret = freeswitchPINVOKE.switch_core_perform_session_strdup(SWIGTYPE_p_switch_core_session.getCPtr(session), todup, file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_L_SDP_VARIABLE_get")]
+  public static extern string SWITCH_L_SDP_VARIABLE_get();
 
-  public static string switch_core_perform_strdup(SWIGTYPE_p_apr_pool_t pool, string todup, string file, string func, int line) {
-    string ret = freeswitchPINVOKE.switch_core_perform_strdup(SWIGTYPE_p_apr_pool_t.getCPtr(pool), todup, file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_B_SDP_VARIABLE_get")]
+  public static extern string SWITCH_B_SDP_VARIABLE_get();
 
-  public static string switch_core_session_sprintf(SWIGTYPE_p_switch_core_session session, string fmt) {
-    string ret = freeswitchPINVOKE.switch_core_session_sprintf(SWIGTYPE_p_switch_core_session.getCPtr(session), fmt);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_VARIABLE_get")]
+  public static extern string SWITCH_BRIDGE_VARIABLE_get();
 
-  public static string switch_core_sprintf(SWIGTYPE_p_apr_pool_t pool, string fmt) {
-    string ret = freeswitchPINVOKE.switch_core_sprintf(SWIGTYPE_p_apr_pool_t.getCPtr(pool), fmt);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SIGNAL_BRIDGE_VARIABLE_get")]
+  public static extern string SWITCH_SIGNAL_BRIDGE_VARIABLE_get();
 
-  public static SWIGTYPE_p_apr_pool_t switch_core_session_get_pool(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_pool(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SIGNAL_BOND_VARIABLE_get")]
+  public static extern string SWITCH_SIGNAL_BOND_VARIABLE_get();
 
-  public static SWIGTYPE_p_switch_core_session switch_core_session_request(switch_endpoint_interface endpoint_interface, SWIGTYPE_p_p_apr_pool_t pool) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_request(switch_endpoint_interface.getCPtr(endpoint_interface), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool));
-    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ORIGINATOR_VARIABLE_get")]
+  public static extern string SWITCH_ORIGINATOR_VARIABLE_get();
 
-  public static void switch_core_session_perform_destroy(SWIGTYPE_p_p_switch_core_session session, string file, string func, int line) {
-    freeswitchPINVOKE.switch_core_session_perform_destroy(SWIGTYPE_p_p_switch_core_session.getCPtr(session), file, func, line);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ORIGINATOR_CODEC_VARIABLE_get")]
+  public static extern string SWITCH_ORIGINATOR_CODEC_VARIABLE_get();
 
-  public static uint switch_core_session_count() {
-    uint ret = freeswitchPINVOKE.switch_core_session_count();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_MEDIA_IP_VARIABLE_get")]
+  public static extern string SWITCH_LOCAL_MEDIA_IP_VARIABLE_get();
 
-  public static SWIGTYPE_p_switch_size_t switch_core_session_id() {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_id(), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get")]
+  public static extern string SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get();
 
-  public static SWIGTYPE_p_switch_core_session switch_core_session_request_by_name(string endpoint_name, SWIGTYPE_p_p_apr_pool_t pool) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_request_by_name(endpoint_name, SWIGTYPE_p_p_apr_pool_t.getCPtr(pool));
-    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_MEDIA_IP_VARIABLE_get")]
+  public static extern string SWITCH_REMOTE_MEDIA_IP_VARIABLE_get();
 
-  public static switch_status_t switch_core_session_thread_launch(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_thread_launch(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get")]
+  public static extern string SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get();
 
-  public static SWIGTYPE_p_switch_channel switch_core_session_get_channel(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_channel(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    SWIGTYPE_p_switch_channel ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_channel(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_VIDEO_IP_VARIABLE_get")]
+  public static extern string SWITCH_REMOTE_VIDEO_IP_VARIABLE_get();
 
-  public static void switch_core_session_signal_state_change(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_core_session_signal_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get")]
+  public static extern string SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get();
 
-  public static string switch_core_session_get_uuid(SWIGTYPE_p_switch_core_session session) {
-    string ret = freeswitchPINVOKE.switch_core_session_get_uuid(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_VIDEO_IP_VARIABLE_get")]
+  public static extern string SWITCH_LOCAL_VIDEO_IP_VARIABLE_get();
 
-  public static string switch_core_get_uuid() {
-    string ret = freeswitchPINVOKE.switch_core_get_uuid();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get")]
+  public static extern string SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get();
 
-  public static SWIGTYPE_p_switch_core_session switch_core_session_locate(string uuid_str) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_locate(uuid_str);
-    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get")]
+  public static extern string SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get();
 
-  public static string switch_core_get_variable(string varname) {
-    string ret = freeswitchPINVOKE.switch_core_get_variable(varname);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get")]
+  public static extern string SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get();
 
-  public static void switch_core_set_variable(string varname, string value) {
-    freeswitchPINVOKE.switch_core_set_variable(varname, value);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get")]
+  public static extern string SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get();
 
-  public static void switch_core_dump_variables(switch_stream_handle stream) {
-    freeswitchPINVOKE.switch_core_dump_variables(switch_stream_handle.getCPtr(stream));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_FORWARDS_VARIABLE_get")]
+  public static extern string SWITCH_MAX_FORWARDS_VARIABLE_get();
 
-  public static void switch_core_session_hupall(switch_call_cause_t cause) {
-    freeswitchPINVOKE.switch_core_session_hupall((int)cause);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_DISABLE_APP_LOG_VARIABLE_get")]
+  public static extern string SWITCH_DISABLE_APP_LOG_VARIABLE_get();
 
-  public static void switch_core_session_hupall_matching_var(string var_name, string var_val, switch_call_cause_t cause) {
-    freeswitchPINVOKE.switch_core_session_hupall_matching_var(var_name, var_val, (int)cause);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SPEECH_KEY_get")]
+  public static extern string SWITCH_SPEECH_KEY_get();
 
-  public static void switch_core_session_hupall_endpoint(switch_endpoint_interface endpoint_interface, switch_call_cause_t cause) {
-    freeswitchPINVOKE.switch_core_session_hupall_endpoint(switch_endpoint_interface.getCPtr(endpoint_interface), (int)cause);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_UUID_BRIDGE_get")]
+  public static extern string SWITCH_UUID_BRIDGE_get();
 
-  public static switch_status_t switch_core_session_message_send(string uuid_str, switch_core_session_message message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_message_send(uuid_str, switch_core_session_message.getCPtr(message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BITS_PER_BYTE_get")]
+  public static extern int SWITCH_BITS_PER_BYTE_get();
 
-  public static switch_status_t switch_core_session_queue_message(SWIGTYPE_p_switch_core_session session, switch_core_session_message message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_message(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_session_message.getCPtr(message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_digit_set")]
+  public static extern void switch_dtmf_t_digit_set(HandleRef jarg1, char jarg2);
 
-  public static switch_status_t switch_core_session_pass_indication(SWIGTYPE_p_switch_core_session session, switch_core_session_message_types_t indication) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_pass_indication(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)indication);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_digit_get")]
+  public static extern char switch_dtmf_t_digit_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_queue_indication(SWIGTYPE_p_switch_core_session session, switch_core_session_message_types_t indication) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_indication(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)indication);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_duration_set")]
+  public static extern void switch_dtmf_t_duration_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_session_dequeue_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_core_session_message message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_core_session_message.getCPtr(message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_duration_get")]
+  public static extern uint switch_dtmf_t_duration_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_flush_message(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_flush_message(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_dtmf_t")]
+  public static extern IntPtr new_switch_dtmf_t();
 
-  public static switch_status_t switch_core_session_event_send(string uuid_str, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_event_send(uuid_str, SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_dtmf_t")]
+  public static extern void delete_switch_dtmf_t(HandleRef jarg1);
 
-  public static switch_app_log switch_core_session_get_app_log(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_app_log(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_app_log ret = (cPtr == IntPtr.Zero) ? null : new switch_app_log(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buf_set")]
+  public static extern void switch_bitpack_t_buf_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_core_session_exec(SWIGTYPE_p_switch_core_session session, switch_application_interface application_interface, string arg) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_exec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_application_interface.getCPtr(application_interface), arg);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buf_get")]
+  public static extern IntPtr switch_bitpack_t_buf_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_execute_application(SWIGTYPE_p_switch_core_session session, string app, string arg) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_execute_application(SWIGTYPE_p_switch_core_session.getCPtr(session), app, arg);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buflen_set")]
+  public static extern void switch_bitpack_t_buflen_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_session_execute_exten(SWIGTYPE_p_switch_core_session session, string exten, string dialplan, string context) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_execute_exten(SWIGTYPE_p_switch_core_session.getCPtr(session), exten, dialplan, context);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buflen_get")]
+  public static extern uint switch_bitpack_t_buflen_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_cur_set")]
+  public static extern void switch_bitpack_t_cur_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static SWIGTYPE_p_void switch_core_session_get_private(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_private(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_cur_get")]
+  public static extern IntPtr switch_bitpack_t_cur_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_set_private(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void private_info) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_private(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(private_info));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bytes_set")]
+  public static extern void switch_bitpack_t_bytes_set(HandleRef jarg1, uint jarg2);
 
-  public static int switch_core_session_add_stream(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void private_info) {
-    int ret = freeswitchPINVOKE.switch_core_session_add_stream(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(private_info));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bytes_get")]
+  public static extern uint switch_bitpack_t_bytes_get(HandleRef jarg1);
 
-  public static SWIGTYPE_p_void switch_core_session_get_stream(SWIGTYPE_p_switch_core_session session, int index) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_stream(SWIGTYPE_p_switch_core_session.getCPtr(session), index);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_tot_set")]
+  public static extern void switch_bitpack_t_bits_tot_set(HandleRef jarg1, uint jarg2);
 
-  public static int switch_core_session_get_stream_count(SWIGTYPE_p_switch_core_session session) {
-    int ret = freeswitchPINVOKE.switch_core_session_get_stream_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_tot_get")]
+  public static extern uint switch_bitpack_t_bits_tot_get(HandleRef jarg1);
 
-  public static void switch_core_session_launch_thread(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void func, SWIGTYPE_p_void obj) {
-    freeswitchPINVOKE.switch_core_session_launch_thread(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void.getCPtr(func), SWIGTYPE_p_void.getCPtr(obj));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_cur_set")]
+  public static extern void switch_bitpack_t_bits_cur_set(HandleRef jarg1, byte jarg2);
 
-  public static void switch_core_thread_session_end(switch_core_thread_session thread_session) {
-    freeswitchPINVOKE.switch_core_thread_session_end(switch_core_thread_session.getCPtr(thread_session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_cur_get")]
+  public static extern byte switch_bitpack_t_bits_cur_get(HandleRef jarg1);
 
-  public static void switch_core_service_session(SWIGTYPE_p_switch_core_session session, switch_core_thread_session thread_session, int stream_id) {
-    freeswitchPINVOKE.switch_core_service_session(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_thread_session.getCPtr(thread_session), stream_id);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_rem_set")]
+  public static extern void switch_bitpack_t_bits_rem_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_call_cause_t switch_core_session_outgoing_channel(SWIGTYPE_p_switch_core_session session, switch_event var_event, string endpoint_name, switch_caller_profile caller_profile, SWIGTYPE_p_p_switch_core_session new_session, SWIGTYPE_p_p_apr_pool_t pool, uint flags) {
-    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_core_session_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_event.getCPtr(var_event), endpoint_name, switch_caller_profile.getCPtr(caller_profile), SWIGTYPE_p_p_switch_core_session.getCPtr(new_session), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_rem_get")]
+  public static extern byte switch_bitpack_t_bits_rem_get(HandleRef jarg1);
 
-  public static switch_call_cause_t switch_core_session_resurrect_channel(string endpoint_name, SWIGTYPE_p_p_switch_core_session new_session, SWIGTYPE_p_p_apr_pool_t pool, SWIGTYPE_p_void data) {
-    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_core_session_resurrect_channel(endpoint_name, SWIGTYPE_p_p_switch_core_session.getCPtr(new_session), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_void.getCPtr(data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_frame_bits_set")]
+  public static extern void switch_bitpack_t_frame_bits_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_session_receive_message(SWIGTYPE_p_switch_core_session session, switch_core_session_message message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_session_message.getCPtr(message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_frame_bits_get")]
+  public static extern byte switch_bitpack_t_frame_bits_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_queue_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_shiftby_set")]
+  public static extern void switch_bitpack_t_shiftby_set(HandleRef jarg1, byte jarg2);
 
-  public static uint switch_core_session_event_count(SWIGTYPE_p_switch_core_session session) {
-    uint ret = freeswitchPINVOKE.switch_core_session_event_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_shiftby_get")]
+  public static extern byte switch_bitpack_t_shiftby_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_dequeue_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_this_byte_set")]
+  public static extern void switch_bitpack_t_this_byte_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_session_queue_private_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_private_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_this_byte_get")]
+  public static extern byte switch_bitpack_t_this_byte_get(HandleRef jarg1);
 
-  public static uint switch_core_session_private_event_count(SWIGTYPE_p_switch_core_session session) {
-    uint ret = freeswitchPINVOKE.switch_core_session_private_event_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_under_set")]
+  public static extern void switch_bitpack_t_under_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_session_dequeue_private_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_private_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_under_get")]
+  public static extern byte switch_bitpack_t_under_get(HandleRef jarg1);
 
-  public static uint switch_core_session_flush_private_events(SWIGTYPE_p_switch_core_session session) {
-    uint ret = freeswitchPINVOKE.switch_core_session_flush_private_events(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_over_set")]
+  public static extern void switch_bitpack_t_over_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_session_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_frame frame, uint flags, int stream_id) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_frame.getCPtr(frame), flags, stream_id);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_over_get")]
+  public static extern byte switch_bitpack_t_over_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_read_video_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_frame frame, uint flags, int stream_id) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_video_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_frame.getCPtr(frame), flags, stream_id);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_mode_set")]
+  public static extern void switch_bitpack_t_mode_set(HandleRef jarg1, int jarg2);
 
-  public static switch_status_t switch_core_session_write_video_frame(SWIGTYPE_p_switch_core_session session, switch_frame frame, uint flags, int stream_id) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_write_video_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_frame.getCPtr(frame), flags, stream_id);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_mode_get")]
+  public static extern int switch_bitpack_t_mode_get(HandleRef jarg1);
 
-  public static void switch_core_session_reset(SWIGTYPE_p_switch_core_session session, switch_bool_t flush_dtmf) {
-    freeswitchPINVOKE.switch_core_session_reset(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)flush_dtmf);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_bitpack_t")]
+  public static extern IntPtr new_switch_bitpack_t();
 
-  public static switch_status_t switch_core_session_write_frame(SWIGTYPE_p_switch_core_session session, switch_frame frame, uint flags, int stream_id) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_frame.getCPtr(frame), flags, stream_id);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_bitpack_t")]
+  public static extern void delete_switch_bitpack_t(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_perform_kill_channel(SWIGTYPE_p_switch_core_session session, string file, string func, int line, switch_signal_t sig) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_perform_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), file, func, line, (int)sig);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_base_dir_set")]
+  public static extern void switch_directories_base_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_session_send_dtmf(SWIGTYPE_p_switch_core_session session, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_base_dir_get")]
+  public static extern string switch_directories_base_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_session_send_dtmf_string(SWIGTYPE_p_switch_core_session session, string dtmf_string) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_send_dtmf_string(SWIGTYPE_p_switch_core_session.getCPtr(session), dtmf_string);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_mod_dir_set")]
+  public static extern void switch_directories_mod_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_session_recv_dtmf(SWIGTYPE_p_switch_core_session session, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_mod_dir_get")]
+  public static extern string switch_directories_mod_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_hash_init(SWIGTYPE_p_p_switch_hash hash, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_init(SWIGTYPE_p_p_switch_hash.getCPtr(hash), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_conf_dir_set")]
+  public static extern void switch_directories_conf_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_hash_destroy(SWIGTYPE_p_p_switch_hash hash) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_destroy(SWIGTYPE_p_p_switch_hash.getCPtr(hash));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_conf_dir_get")]
+  public static extern string switch_directories_conf_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_hash_insert(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_void data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_insert(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_void.getCPtr(data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_log_dir_set")]
+  public static extern void switch_directories_log_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_hash_insert_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_void data, SWIGTYPE_p_switch_mutex_t mutex) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_insert_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_log_dir_get")]
+  public static extern string switch_directories_log_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_hash_delete(SWIGTYPE_p_switch_hash hash, string key) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_delete(SWIGTYPE_p_switch_hash.getCPtr(hash), key);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_db_dir_set")]
+  public static extern void switch_directories_db_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_hash_delete_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_switch_mutex_t mutex) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_delete_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_db_dir_get")]
+  public static extern string switch_directories_db_dir_get(HandleRef jarg1);
 
-  public static SWIGTYPE_p_void switch_core_hash_find(SWIGTYPE_p_switch_hash hash, string key) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_hash_find(SWIGTYPE_p_switch_hash.getCPtr(hash), key);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_script_dir_set")]
+  public static extern void switch_directories_script_dir_set(HandleRef jarg1, string jarg2);
 
-  public static SWIGTYPE_p_void switch_core_hash_find_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_switch_mutex_t mutex) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_hash_find_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_script_dir_get")]
+  public static extern string switch_directories_script_dir_get(HandleRef jarg1);
 
-  public static SWIGTYPE_p_HashElem switch_hash_first(string depricate_me, SWIGTYPE_p_switch_hash hash) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_hash_first(depricate_me, SWIGTYPE_p_switch_hash.getCPtr(hash));
-    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_temp_dir_set")]
+  public static extern void switch_directories_temp_dir_set(HandleRef jarg1, string jarg2);
 
-  public static SWIGTYPE_p_HashElem switch_hash_next(SWIGTYPE_p_HashElem hi) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_hash_next(SWIGTYPE_p_HashElem.getCPtr(hi));
-    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_temp_dir_get")]
+  public static extern string switch_directories_temp_dir_get(HandleRef jarg1);
 
-  public static void switch_hash_this(SWIGTYPE_p_HashElem hi, SWIGTYPE_p_p_void key, SWIGTYPE_p_switch_ssize_t klen, SWIGTYPE_p_p_void val) {
-    freeswitchPINVOKE.switch_hash_this(SWIGTYPE_p_HashElem.getCPtr(hi), SWIGTYPE_p_p_void.getCPtr(key), SWIGTYPE_p_switch_ssize_t.getCPtr(klen), SWIGTYPE_p_p_void.getCPtr(val));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_htdocs_dir_set")]
+  public static extern void switch_directories_htdocs_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_timer_init(switch_timer timer, string timer_name, int interval, int samples, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_init(switch_timer.getCPtr(timer), timer_name, interval, samples, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_htdocs_dir_get")]
+  public static extern string switch_directories_htdocs_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_timer_next(switch_timer timer) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_next(switch_timer.getCPtr(timer));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_grammar_dir_set")]
+  public static extern void switch_directories_grammar_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_timer_step(switch_timer timer) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_step(switch_timer.getCPtr(timer));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_grammar_dir_get")]
+  public static extern string switch_directories_grammar_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_timer_sync(switch_timer timer) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_sync(switch_timer.getCPtr(timer));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_storage_dir_set")]
+  public static extern void switch_directories_storage_dir_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_timer_check(switch_timer timer, switch_bool_t step) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_check(switch_timer.getCPtr(timer), (int)step);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_storage_dir_get")]
+  public static extern string switch_directories_storage_dir_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_timer_destroy(switch_timer timer) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_destroy(switch_timer.getCPtr(timer));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directories")]
+  public static extern IntPtr new_switch_directories();
 
-  public static switch_status_t switch_core_codec_init(switch_codec codec, string codec_name, string fmtp, uint rate, int ms, int channels, uint flags, switch_codec_settings codec_settings, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_init(switch_codec.getCPtr(codec), codec_name, fmtp, rate, ms, channels, flags, switch_codec_settings.getCPtr(codec_settings), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directories")]
+  public static extern void delete_switch_directories(HandleRef jarg1);
 
-  public static switch_status_t switch_core_codec_copy(switch_codec codec, switch_codec new_codec, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_copy(switch_codec.getCPtr(codec), switch_codec.getCPtr(new_codec), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_GLOBAL_dirs_set")]
+  public static extern void SWITCH_GLOBAL_dirs_set(HandleRef jarg1);
 
-  public static switch_status_t switch_core_codec_encode(switch_codec codec, switch_codec other_codec, SWIGTYPE_p_void decoded_data, uint decoded_data_len, uint decoded_rate, SWIGTYPE_p_void encoded_data, SWIGTYPE_p_unsigned_long encoded_data_len, SWIGTYPE_p_unsigned_long encoded_rate, SWIGTYPE_p_unsigned_int flag) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_encode(switch_codec.getCPtr(codec), switch_codec.getCPtr(other_codec), SWIGTYPE_p_void.getCPtr(decoded_data), decoded_data_len, decoded_rate, SWIGTYPE_p_void.getCPtr(encoded_data), SWIGTYPE_p_unsigned_long.getCPtr(encoded_data_len), SWIGTYPE_p_unsigned_long.getCPtr(encoded_rate), SWIGTYPE_p_unsigned_int.getCPtr(flag));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_GLOBAL_dirs_get")]
+  public static extern IntPtr SWITCH_GLOBAL_dirs_get();
 
-  public static switch_status_t switch_core_codec_decode(switch_codec codec, switch_codec other_codec, SWIGTYPE_p_void encoded_data, uint encoded_data_len, uint encoded_rate, SWIGTYPE_p_void decoded_data, SWIGTYPE_p_unsigned_long decoded_data_len, SWIGTYPE_p_unsigned_long decoded_rate, SWIGTYPE_p_unsigned_int flag) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_decode(switch_codec.getCPtr(codec), switch_codec.getCPtr(other_codec), SWIGTYPE_p_void.getCPtr(encoded_data), encoded_data_len, encoded_rate, SWIGTYPE_p_void.getCPtr(decoded_data), SWIGTYPE_p_unsigned_long.getCPtr(decoded_data_len), SWIGTYPE_p_unsigned_long.getCPtr(decoded_rate), SWIGTYPE_p_unsigned_int.getCPtr(flag));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STACKS_get")]
+  public static extern int SWITCH_MAX_STACKS_get();
 
-  public static switch_status_t switch_core_codec_destroy(switch_codec codec) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_destroy(switch_codec.getCPtr(codec));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_THREAD_STACKSIZE_get")]
+  public static extern int SWITCH_THREAD_STACKSIZE_get();
 
-  public static switch_status_t switch_core_session_set_read_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SYSTEM_THREAD_STACKSIZE_get")]
+  public static extern int SWITCH_SYSTEM_THREAD_STACKSIZE_get();
 
-  public static void switch_core_session_unset_read_codec(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_core_session_unset_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_INTERVAL_get")]
+  public static extern int SWITCH_MAX_INTERVAL_get();
 
-  public static switch_codec switch_core_session_get_read_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_INTERVAL_PAD_get")]
+  public static extern int SWITCH_INTERVAL_PAD_get();
 
-  public static switch_codec switch_core_session_get_effective_read_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_effective_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_SAMPLE_LEN_get")]
+  public static extern int SWITCH_MAX_SAMPLE_LEN_get();
 
-  public static switch_status_t switch_core_session_set_write_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYTES_PER_SAMPLE_get")]
+  public static extern int SWITCH_BYTES_PER_SAMPLE_get();
 
-  public static switch_codec switch_core_session_get_write_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RECOMMENDED_BUFFER_SIZE_get")]
+  public static extern int SWITCH_RECOMMENDED_BUFFER_SIZE_get();
 
-  public static switch_codec switch_core_session_get_effective_write_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_effective_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_CODECS_get")]
+  public static extern int SWITCH_MAX_CODECS_get();
 
-  public static switch_status_t switch_core_session_set_video_read_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_video_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STATE_HANDLERS_get")]
+  public static extern int SWITCH_MAX_STATE_HANDLERS_get();
 
-  public static switch_codec switch_core_session_get_video_read_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_video_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_QUEUE_LEN_get")]
+  public static extern int SWITCH_CORE_QUEUE_LEN_get();
 
-  public static switch_status_t switch_core_session_set_video_write_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_video_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get")]
+  public static extern int SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get();
 
-  public static switch_codec switch_core_session_get_video_write_codec(SWIGTYPE_p_switch_core_session session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_video_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CNG_PAYLOAD_get")]
+  public static extern int SWITCH_RTP_CNG_PAYLOAD_get();
 
-  public static SWIGTYPE_p_sqlite3 switch_core_db_open_file(string filename) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_db_open_file(filename);
-    SWIGTYPE_p_sqlite3 ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_sqlite3(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_version_set")]
+  public static extern void switch_rtp_hdr_t_version_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_db_persistant_execute(SWIGTYPE_p_sqlite3 db, string sql, uint retries) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_db_persistant_execute(SWIGTYPE_p_sqlite3.getCPtr(db), sql, retries);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_version_get")]
+  public static extern uint switch_rtp_hdr_t_version_get(HandleRef jarg1);
 
-  public static void switch_core_db_test_reactive(SWIGTYPE_p_sqlite3 db, string test_sql, string drop_sql, string reactive_sql) {
-    freeswitchPINVOKE.switch_core_db_test_reactive(SWIGTYPE_p_sqlite3.getCPtr(db), test_sql, drop_sql, reactive_sql);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_p_set")]
+  public static extern void switch_rtp_hdr_t_p_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_perform_file_open(string file, string func, int line, switch_file_handle fh, string file_path, byte channels, uint rate, uint flags, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_file_open(file, func, line, switch_file_handle.getCPtr(fh), file_path, channels, rate, flags, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_p_get")]
+  public static extern uint switch_rtp_hdr_t_p_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_file_read(switch_file_handle fh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t len) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_read(switch_file_handle.getCPtr(fh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(len));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_x_set")]
+  public static extern void switch_rtp_hdr_t_x_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_file_write(switch_file_handle fh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t len) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_write(switch_file_handle.getCPtr(fh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(len));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_x_get")]
+  public static extern uint switch_rtp_hdr_t_x_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_file_seek(switch_file_handle fh, SWIGTYPE_p_unsigned_int cur_pos, long samples, int whence) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_seek(switch_file_handle.getCPtr(fh), SWIGTYPE_p_unsigned_int.getCPtr(cur_pos), samples, whence);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_cc_set")]
+  public static extern void switch_rtp_hdr_t_cc_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_file_set_string(switch_file_handle fh, switch_audio_col_t col, string arg2) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_set_string(switch_file_handle.getCPtr(fh), (int)col, arg2);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_cc_get")]
+  public static extern uint switch_rtp_hdr_t_cc_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_file_get_string(switch_file_handle fh, switch_audio_col_t col, ref string arg2) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_get_string(switch_file_handle.getCPtr(fh), (int)col, ref arg2);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_m_set")]
+  public static extern void switch_rtp_hdr_t_m_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_file_close(switch_file_handle fh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_close(switch_file_handle.getCPtr(fh));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_m_get")]
+  public static extern uint switch_rtp_hdr_t_m_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_speech_open(switch_speech_handle sh, string module_name, string voice_name, uint rate, uint interval, SWIGTYPE_p_unsigned_long flags, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_open(switch_speech_handle.getCPtr(sh), module_name, voice_name, rate, interval, SWIGTYPE_p_unsigned_long.getCPtr(flags), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_pt_set")]
+  public static extern void switch_rtp_hdr_t_pt_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_speech_feed_tts(switch_speech_handle sh, string text, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_feed_tts(switch_speech_handle.getCPtr(sh), text, SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_pt_get")]
+  public static extern uint switch_rtp_hdr_t_pt_get(HandleRef jarg1);
 
-  public static void switch_core_speech_flush_tts(switch_speech_handle sh) {
-    freeswitchPINVOKE.switch_core_speech_flush_tts(switch_speech_handle.getCPtr(sh));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_seq_set")]
+  public static extern void switch_rtp_hdr_t_seq_set(HandleRef jarg1, uint jarg2);
 
-  public static void switch_core_speech_text_param_tts(switch_speech_handle sh, string param, string val) {
-    freeswitchPINVOKE.switch_core_speech_text_param_tts(switch_speech_handle.getCPtr(sh), param, val);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_seq_get")]
+  public static extern uint switch_rtp_hdr_t_seq_get(HandleRef jarg1);
 
-  public static void switch_core_speech_numeric_param_tts(switch_speech_handle sh, string param, int val) {
-    freeswitchPINVOKE.switch_core_speech_numeric_param_tts(switch_speech_handle.getCPtr(sh), param, val);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ts_set")]
+  public static extern void switch_rtp_hdr_t_ts_set(HandleRef jarg1, uint jarg2);
 
-  public static void switch_core_speech_float_param_tts(switch_speech_handle sh, string param, double val) {
-    freeswitchPINVOKE.switch_core_speech_float_param_tts(switch_speech_handle.getCPtr(sh), param, val);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ts_get")]
+  public static extern uint switch_rtp_hdr_t_ts_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_speech_read_tts(switch_speech_handle sh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen, SWIGTYPE_p_unsigned_long rate, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_read_tts(switch_speech_handle.getCPtr(sh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen), SWIGTYPE_p_unsigned_long.getCPtr(rate), SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ssrc_set")]
+  public static extern void switch_rtp_hdr_t_ssrc_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_speech_close(switch_speech_handle sh, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_close(switch_speech_handle.getCPtr(sh), SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ssrc_get")]
+  public static extern uint switch_rtp_hdr_t_ssrc_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_asr_open(switch_asr_handle ah, string module_name, string codec, int rate, string dest, SWIGTYPE_p_unsigned_long flags, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_open(switch_asr_handle.getCPtr(ah), module_name, codec, rate, dest, SWIGTYPE_p_unsigned_long.getCPtr(flags), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_rtp_hdr_t")]
+  public static extern IntPtr new_switch_rtp_hdr_t();
 
-  public static switch_status_t switch_core_asr_close(switch_asr_handle ah, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_close(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_rtp_hdr_t")]
+  public static extern void delete_switch_rtp_hdr_t(HandleRef jarg1);
 
-  public static switch_status_t switch_core_asr_feed(switch_asr_handle ah, SWIGTYPE_p_void data, uint len, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_feed(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_void.getCPtr(data), len, SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_input_callback_set")]
+  public static extern void switch_input_args_t_input_callback_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_core_asr_check_results(switch_asr_handle ah, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_check_results(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_input_callback_get")]
+  public static extern IntPtr switch_input_args_t_input_callback_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_asr_get_results(switch_asr_handle ah, ref string xmlstr, SWIGTYPE_p_unsigned_long flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_get_results(switch_asr_handle.getCPtr(ah), ref xmlstr, SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buf_set")]
+  public static extern void switch_input_args_t_buf_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_core_asr_load_grammar(switch_asr_handle ah, string grammar, string path) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_load_grammar(switch_asr_handle.getCPtr(ah), grammar, path);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buf_get")]
+  public static extern IntPtr switch_input_args_t_buf_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_asr_unload_grammar(switch_asr_handle ah, string grammar) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_unload_grammar(switch_asr_handle.getCPtr(ah), grammar);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buflen_set")]
+  public static extern void switch_input_args_t_buflen_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_core_asr_pause(switch_asr_handle ah) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_pause(switch_asr_handle.getCPtr(ah));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buflen_get")]
+  public static extern uint switch_input_args_t_buflen_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_asr_resume(switch_asr_handle ah) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_resume(switch_asr_handle.getCPtr(ah));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_read_frame_callback_set")]
+  public static extern void switch_input_args_t_read_frame_callback_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_core_directory_open(switch_directory_handle dh, string module_name, string source, string dsn, string passwd, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_open(switch_directory_handle.getCPtr(dh), module_name, source, dsn, passwd, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_read_frame_callback_get")]
+  public static extern IntPtr switch_input_args_t_read_frame_callback_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_directory_query(switch_directory_handle dh, string arg1, string query) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_query(switch_directory_handle.getCPtr(dh), arg1, query);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_user_data_set")]
+  public static extern void switch_input_args_t_user_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_core_directory_next(switch_directory_handle dh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_next(switch_directory_handle.getCPtr(dh));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_user_data_get")]
+  public static extern IntPtr switch_input_args_t_user_data_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_directory_next_pair(switch_directory_handle dh, ref string var, ref string val) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_next_pair(switch_directory_handle.getCPtr(dh), ref var, ref val);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_input_args_t")]
+  public static extern IntPtr new_switch_input_args_t();
 
-  public static switch_status_t switch_core_directory_close(switch_directory_handle dh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_close(switch_directory_handle.getCPtr(dh));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_input_args_t")]
+  public static extern void delete_switch_input_args_t(HandleRef jarg1);
 
-  public static SWIGTYPE_p_FILE switch_core_data_channel(switch_text_channel_t channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_data_channel((int)channel);
-    SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_VERSION_get")]
+  public static extern int SWITCH_API_VERSION_get();
 
-  public static switch_bool_t switch_core_ready() {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_core_ready();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_switch_api_version_set")]
+  public static extern void switch_loadable_module_function_table_t_switch_api_version_set(HandleRef jarg1, int jarg2);
 
-  public static uint switch_core_flags() {
-    uint ret = freeswitchPINVOKE.switch_core_flags();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_switch_api_version_get")]
+  public static extern int switch_loadable_module_function_table_t_switch_api_version_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_management_exec(string relative_oid, switch_management_action_t action, string data, SWIGTYPE_p_switch_size_t datalen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_management_exec(relative_oid, (int)action, data, SWIGTYPE_p_switch_size_t.getCPtr(datalen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_load_set")]
+  public static extern void switch_loadable_module_function_table_t_load_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static int set_high_priority() {
-    int ret = freeswitchPINVOKE.set_high_priority();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_load_get")]
+  public static extern IntPtr switch_loadable_module_function_table_t_load_get(HandleRef jarg1);
 
-  public static int change_user_group(string user, string group) {
-    int ret = freeswitchPINVOKE.change_user_group(user, group);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_shutdown_set")]
+  public static extern void switch_loadable_module_function_table_t_shutdown_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_core_runtime_loop(int bg) {
-    freeswitchPINVOKE.switch_core_runtime_loop(bg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_shutdown_get")]
+  public static extern IntPtr switch_loadable_module_function_table_t_shutdown_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_set_console(string console) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_set_console(console);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_runtime_set")]
+  public static extern void switch_loadable_module_function_table_t_runtime_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_core_measure_time(SWIGTYPE_p_switch_time_t total_ms, switch_core_time_duration duration) {
-    freeswitchPINVOKE.switch_core_measure_time(SWIGTYPE_p_switch_time_t.getCPtr(total_ms), switch_core_time_duration.getCPtr(duration));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_runtime_get")]
+  public static extern IntPtr switch_loadable_module_function_table_t_runtime_get(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_time_t switch_core_uptime() {
-    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_core_uptime(), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_loadable_module_function_table_t")]
+  public static extern IntPtr new_switch_loadable_module_function_table_t();
 
-  public static int switch_core_session_ctl(switch_session_ctl_t cmd, SWIGTYPE_p_int val) {
-    int ret = freeswitchPINVOKE.switch_core_session_ctl((int)cmd, SWIGTYPE_p_int.getCPtr(val));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_loadable_module_function_table_t")]
+  public static extern void delete_switch_loadable_module_function_table_t(HandleRef jarg1);
 
-  public static SWIGTYPE_p_FILE switch_core_get_console() {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_get_console();
-    SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_close")]
+  public static extern int switch_core_db_close(HandleRef jarg1);
 
-  public static void switch_core_launch_thread(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void func, SWIGTYPE_p_void obj, SWIGTYPE_p_apr_pool_t pool) {
-    freeswitchPINVOKE.switch_core_launch_thread(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void.getCPtr(func), SWIGTYPE_p_void.getCPtr(obj), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_open")]
+  public static extern int switch_core_db_open(string jarg1, HandleRef jarg2);
 
-  public static void switch_core_set_globals() {
-    freeswitchPINVOKE.switch_core_set_globals();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_text")]
+  public static extern IntPtr switch_core_db_column_text(HandleRef jarg1, int jarg2);
 
-  public static byte switch_core_session_compare(SWIGTYPE_p_switch_core_session a, SWIGTYPE_p_switch_core_session b) {
-    byte ret = freeswitchPINVOKE.switch_core_session_compare(SWIGTYPE_p_switch_core_session.getCPtr(a), SWIGTYPE_p_switch_core_session.getCPtr(b));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_name")]
+  public static extern string switch_core_db_column_name(HandleRef jarg1, int jarg2);
 
-  public static byte switch_core_session_check_interface(SWIGTYPE_p_switch_core_session session, switch_endpoint_interface endpoint_interface) {
-    byte ret = freeswitchPINVOKE.switch_core_session_check_interface(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_endpoint_interface.getCPtr(endpoint_interface));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_count")]
+  public static extern int switch_core_db_column_count(HandleRef jarg1);
 
-  public static SWIGTYPE_p_HashElem switch_core_mime_index() {
-    IntPtr cPtr = freeswitchPINVOKE.switch_core_mime_index();
-    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_errmsg")]
+  public static extern string switch_core_db_errmsg(HandleRef jarg1);
 
-  public static string switch_core_mime_ext2type(string ext) {
-    string ret = freeswitchPINVOKE.switch_core_mime_ext2type(ext);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_exec")]
+  public static extern int switch_core_db_exec(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, ref string jarg5);
 
-  public static switch_status_t switch_core_mime_add_type(string type, string ext) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_mime_add_type(type, ext);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_finalize")]
+  public static extern int switch_core_db_finalize(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_loadable_module_interface switch_loadable_module_create_module_interface(SWIGTYPE_p_apr_pool_t pool, string name) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_create_module_interface(SWIGTYPE_p_apr_pool_t.getCPtr(pool), name);
-    SWIGTYPE_p_switch_loadable_module_interface ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_loadable_module_interface(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_prepare")]
+  public static extern int switch_core_db_prepare(HandleRef jarg1, string jarg2, int jarg3, HandleRef jarg4, ref string jarg5);
 
-  public static SWIGTYPE_p_void switch_loadable_module_create_interface(SWIGTYPE_p_switch_loadable_module_interface mod, switch_module_interface_name_t iname) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_create_interface(SWIGTYPE_p_switch_loadable_module_interface.getCPtr(mod), (int)iname);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_step")]
+  public static extern int switch_core_db_step(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_time_t switch_timestamp_now() {
-    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_timestamp_now(), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_reset")]
+  public static extern int switch_core_db_reset(HandleRef jarg1);
 
-  public static void switch_core_memory_reclaim() {
-    freeswitchPINVOKE.switch_core_memory_reclaim();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_int")]
+  public static extern int switch_core_db_bind_int(HandleRef jarg1, int jarg2, int jarg3);
 
-  public static void switch_core_memory_reclaim_events() {
-    freeswitchPINVOKE.switch_core_memory_reclaim_events();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_int64")]
+  public static extern int switch_core_db_bind_int64(HandleRef jarg1, int jarg2, long jarg3);
 
-  public static void switch_core_memory_reclaim_logger() {
-    freeswitchPINVOKE.switch_core_memory_reclaim_logger();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_text")]
+  public static extern int switch_core_db_bind_text(HandleRef jarg1, int jarg2, string jarg3, int jarg4, HandleRef jarg5);
 
-  public static void switch_core_memory_reclaim_all() {
-    freeswitchPINVOKE.switch_core_memory_reclaim_all();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_double")]
+  public static extern int switch_core_db_bind_double(HandleRef jarg1, int jarg2, double jarg3);
 
-  public static void switch_core_setrlimits() {
-    freeswitchPINVOKE.switch_core_setrlimits();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_last_insert_rowid")]
+  public static extern long switch_core_db_last_insert_rowid(HandleRef jarg1);
 
-  public static void switch_time_sync() {
-    freeswitchPINVOKE.switch_time_sync();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_get_table")]
+  public static extern int switch_core_db_get_table(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, ref string jarg6);
 
-  public static SWIGTYPE_p_time_t switch_timestamp(SWIGTYPE_p_time_t t) {
-    SWIGTYPE_p_time_t ret = new SWIGTYPE_p_time_t(freeswitchPINVOKE.switch_timestamp(SWIGTYPE_p_time_t.getCPtr(t)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_free_table")]
+  public static extern void switch_core_db_free_table(ref string jarg1);
 
-  public static void switch_load_network_lists(switch_bool_t reload) {
-    freeswitchPINVOKE.switch_load_network_lists((int)reload);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_free")]
+  public static extern void switch_core_db_free(string jarg1);
 
-  public static switch_bool_t switch_check_network_list_ip_token(string ip_str, string list_name, ref string token) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_check_network_list_ip_token(ip_str, list_name, ref token);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_changes")]
+  public static extern int switch_core_db_changes(HandleRef jarg1);
 
-  public static void switch_time_set_monotonic(switch_bool_t enable) {
-    freeswitchPINVOKE.switch_time_set_monotonic((int)enable);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_OK_get")]
+  public static extern int SWITCH_CORE_DB_OK_get();
 
-  public static uint switch_core_max_dtmf_duration(uint duration) {
-    uint ret = freeswitchPINVOKE.switch_core_max_dtmf_duration(duration);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ERROR_get")]
+  public static extern int SWITCH_CORE_DB_ERROR_get();
 
-  public static uint switch_core_default_dtmf_duration(uint duration) {
-    uint ret = freeswitchPINVOKE.switch_core_default_dtmf_duration(duration);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_INTERNAL_get")]
+  public static extern int SWITCH_CORE_DB_INTERNAL_get();
 
-  public static switch_status_t switch_console_set_complete(string arg0) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_set_complete(arg0);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_PERM_get")]
+  public static extern int SWITCH_CORE_DB_PERM_get();
 
-  public static switch_status_t switch_console_set_alias(string arg0) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_set_alias(arg0);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ABORT_get")]
+  public static extern int SWITCH_CORE_DB_ABORT_get();
 
-  public static void switch_console_loop() {
-    freeswitchPINVOKE.switch_console_loop();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_BUSY_get")]
+  public static extern int SWITCH_CORE_DB_BUSY_get();
 
-  public static switch_status_t switch_console_stream_raw_write(switch_stream_handle handle, SWIGTYPE_p_unsigned_char data, SWIGTYPE_p_switch_size_t datalen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_stream_raw_write(switch_stream_handle.getCPtr(handle), SWIGTYPE_p_unsigned_char.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_LOCKED_get")]
+  public static extern int SWITCH_CORE_DB_LOCKED_get();
 
-  public static switch_bool_t switch_is_moh(string s) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_moh(s);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOMEM_get")]
+  public static extern int SWITCH_CORE_DB_NOMEM_get();
 
-  public static switch_status_t switch_b64_encode(SWIGTYPE_p_unsigned_char arg0, SWIGTYPE_p_switch_size_t ilen, SWIGTYPE_p_unsigned_char arg2, SWIGTYPE_p_switch_size_t olen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_b64_encode(SWIGTYPE_p_unsigned_char.getCPtr(arg0), SWIGTYPE_p_switch_size_t.getCPtr(ilen), SWIGTYPE_p_unsigned_char.getCPtr(arg2), SWIGTYPE_p_switch_size_t.getCPtr(olen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_READONLY_get")]
+  public static extern int SWITCH_CORE_DB_READONLY_get();
 
-  public static SWIGTYPE_p_switch_size_t switch_b64_decode(string arg0, string arg1, SWIGTYPE_p_switch_size_t olen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_b64_decode(arg0, arg1, SWIGTYPE_p_switch_size_t.getCPtr(olen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_INTERRUPT_get")]
+  public static extern int SWITCH_CORE_DB_INTERRUPT_get();
 
-  public static string switch_amp_encode(string s, string buf, SWIGTYPE_p_switch_size_t len) {
-    string ret = freeswitchPINVOKE.switch_amp_encode(s, buf, SWIGTYPE_p_switch_size_t.getCPtr(len));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_IOERR_get")]
+  public static extern int SWITCH_CORE_DB_IOERR_get();
 
-  public static switch_bool_t switch_is_digit_string(string s) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_digit_string(s);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CORRUPT_get")]
+  public static extern int SWITCH_CORE_DB_CORRUPT_get();
 
-  public static SWIGTYPE_p_switch_size_t switch_fd_read_line(int fd, string buf, SWIGTYPE_p_switch_size_t len) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_fd_read_line(fd, buf, SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOTFOUND_get")]
+  public static extern int SWITCH_CORE_DB_NOTFOUND_get();
 
-  public static switch_status_t switch_find_local_ip(string buf, int len, int family) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_find_local_ip(buf, len, family);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_FULL_get")]
+  public static extern int SWITCH_CORE_DB_FULL_get();
 
-  public static string get_addr(string buf, SWIGTYPE_p_switch_size_t len, SWIGTYPE_p_sockaddr sa, SWIGTYPE_p_socklen_t salen) {
-    string ret = freeswitchPINVOKE.get_addr(buf, SWIGTYPE_p_switch_size_t.getCPtr(len), SWIGTYPE_p_sockaddr.getCPtr(sa), SWIGTYPE_p_socklen_t.getCPtr(salen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CANTOPEN_get")]
+  public static extern int SWITCH_CORE_DB_CANTOPEN_get();
 
-  public static ushort get_port(SWIGTYPE_p_sockaddr sa) {
-    ushort ret = freeswitchPINVOKE.get_port(SWIGTYPE_p_sockaddr.getCPtr(sa));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_PROTOCOL_get")]
+  public static extern int SWITCH_CORE_DB_PROTOCOL_get();
 
-  public static int switch_build_uri(string uri, SWIGTYPE_p_switch_size_t size, string scheme, string user, SWIGTYPE_p_switch_sockaddr_t sa, int flags) {
-    int ret = freeswitchPINVOKE.switch_build_uri(uri, SWIGTYPE_p_switch_size_t.getCPtr(size), scheme, user, SWIGTYPE_p_switch_sockaddr_t.getCPtr(sa), flags);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_EMPTY_get")]
+  public static extern int SWITCH_CORE_DB_EMPTY_get();
 
-  public static string switch_priority_name(switch_priority_t priority) {
-    string ret = freeswitchPINVOKE.switch_priority_name((int)priority);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_SCHEMA_get")]
+  public static extern int SWITCH_CORE_DB_SCHEMA_get();
 
-  public static char switch_rfc2833_to_char(int arg0) {
-    char ret = freeswitchPINVOKE.switch_rfc2833_to_char(arg0);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_TOOBIG_get")]
+  public static extern int SWITCH_CORE_DB_TOOBIG_get();
 
-  public static byte switch_char_to_rfc2833(char key) {
-    byte ret = freeswitchPINVOKE.switch_char_to_rfc2833(key);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CONSTRAINT_get")]
+  public static extern int SWITCH_CORE_DB_CONSTRAINT_get();
 
-  public static string switch_clean_string(string s) {
-    string ret = freeswitchPINVOKE.switch_clean_string(s);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_MISMATCH_get")]
+  public static extern int SWITCH_CORE_DB_MISMATCH_get();
 
-  public static string switch_safe_strdup(string it) {
-    string ret = freeswitchPINVOKE.switch_safe_strdup(it);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_MISUSE_get")]
+  public static extern int SWITCH_CORE_DB_MISUSE_get();
 
-  public static switch_bool_t switch_strstr(string s, string q) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_strstr(s, q);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOLFS_get")]
+  public static extern int SWITCH_CORE_DB_NOLFS_get();
 
-  public static SWIGTYPE_p_switch_time_t switch_str_time(string arg0) {
-    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_str_time(arg0), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_AUTH_get")]
+  public static extern int SWITCH_CORE_DB_AUTH_get();
 
-  public static uint switch_separate_string(string buf, char delim, ref string array, uint arraylen) {
-    uint ret = freeswitchPINVOKE.switch_separate_string(buf, delim, ref array, arraylen);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_FORMAT_get")]
+  public static extern int SWITCH_CORE_DB_FORMAT_get();
 
-  public static switch_bool_t switch_is_number(string str) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_number(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_RANGE_get")]
+  public static extern int SWITCH_CORE_DB_RANGE_get();
 
-  public static string switch_strip_spaces(string str) {
-    string ret = freeswitchPINVOKE.switch_strip_spaces(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOTADB_get")]
+  public static extern int SWITCH_CORE_DB_NOTADB_get();
 
-  public static string switch_separate_paren_args(string str) {
-    string ret = freeswitchPINVOKE.switch_separate_paren_args(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ROW_get")]
+  public static extern int SWITCH_CORE_DB_ROW_get();
 
-  public static string switch_stristr(string instr, string str) {
-    string ret = freeswitchPINVOKE.switch_stristr(instr, str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_DONE_get")]
+  public static extern int SWITCH_CORE_DB_DONE_get();
 
-  public static switch_bool_t switch_is_lan_addr(string ip) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_lan_addr(ip);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_mprintf")]
+  public static extern string switch_mprintf(string jarg1);
 
-  public static string switch_replace_char(string str, char from, char to, switch_bool_t dup) {
-    string ret = freeswitchPINVOKE.switch_replace_char(str, from, to, (int)dup);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_compile")]
+  public static extern IntPtr switch_regex_compile(string jarg1, int jarg2, ref string jarg3, HandleRef jarg4, HandleRef jarg5);
 
-  public static switch_bool_t switch_ast2regex(string pat, string rbuf, uint len) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_ast2regex(pat, rbuf, len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_copy_substring")]
+  public static extern int switch_regex_copy_substring(string jarg1, HandleRef jarg2, int jarg3, int jarg4, string jarg5, int jarg6);
 
-  public static string switch_escape_char(SWIGTYPE_p_apr_pool_t pool, string arg1, string delim, char esc) {
-    string ret = freeswitchPINVOKE.switch_escape_char(SWIGTYPE_p_apr_pool_t.getCPtr(pool), arg1, delim, esc);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_free")]
+  public static extern void switch_regex_free(HandleRef jarg1);
 
-  public static int switch_socket_waitfor(SWIGTYPE_p_switch_pollfd_t poll, int ms) {
-    int ret = freeswitchPINVOKE.switch_socket_waitfor(SWIGTYPE_p_switch_pollfd_t.getCPtr(poll), ms);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_perform")]
+  public static extern int switch_regex_perform(string jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, uint jarg5);
 
-  public static string switch_cut_path(string arg0) {
-    string ret = freeswitchPINVOKE.switch_cut_path(arg0);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_perform_substitution")]
+  public static extern void switch_perform_substitution(HandleRef jarg1, int jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6, HandleRef jarg7);
 
-  public static string switch_string_replace(string arg0, string search, string replace) {
-    string ret = freeswitchPINVOKE.switch_string_replace(arg0, search, replace);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_match")]
+  public static extern int switch_regex_match(string jarg1, string jarg2);
 
-  public static switch_status_t switch_string_match(string arg0, uint string_len, string search, uint search_len) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_string_match(arg0, string_len, search, search_len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_match_partial")]
+  public static extern int switch_regex_match_partial(string jarg1, string jarg2, HandleRef jarg3);
 
-  public static uint switch_url_encode(string url, string buf, uint len) {
-    uint ret = freeswitchPINVOKE.switch_url_encode(url, buf, len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get")]
+  public static extern int SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get();
 
-  public static string switch_url_decode(string s) {
-    string ret = freeswitchPINVOKE.switch_url_decode(s);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STREAMS_get")]
+  public static extern int SWITCH_MAX_STREAMS_get();
 
-  public static switch_bool_t switch_simple_email(string to, string from, string headers, string body, string file) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_simple_email(to, from, headers, body, file);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_mms_set")]
+  public static extern void switch_core_time_duration_mms_set(HandleRef jarg1, uint jarg2);
 
-  public static string switch_find_end_paren(string s, char open, char close) {
-    string ret = freeswitchPINVOKE.switch_find_end_paren(s, open, close);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_mms_get")]
+  public static extern uint switch_core_time_duration_mms_get(HandleRef jarg1);
 
-  public static int switch_parse_cidr(string arg0, SWIGTYPE_p_unsigned_long ip, SWIGTYPE_p_unsigned_long mask, SWIGTYPE_p_unsigned_long bitp) {
-    int ret = freeswitchPINVOKE.switch_parse_cidr(arg0, SWIGTYPE_p_unsigned_long.getCPtr(ip), SWIGTYPE_p_unsigned_long.getCPtr(mask), SWIGTYPE_p_unsigned_long.getCPtr(bitp));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_ms_set")]
+  public static extern void switch_core_time_duration_ms_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_network_list_create(SWIGTYPE_p_p_switch_network_list list, switch_bool_t default_type, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_create(SWIGTYPE_p_p_switch_network_list.getCPtr(list), (int)default_type, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_ms_get")]
+  public static extern uint switch_core_time_duration_ms_get(HandleRef jarg1);
 
-  public static switch_status_t switch_network_list_add_cidr_token(SWIGTYPE_p_switch_network_list list, string cidr_str, switch_bool_t ok, string token) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_add_cidr_token(SWIGTYPE_p_switch_network_list.getCPtr(list), cidr_str, (int)ok, token);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_sec_set")]
+  public static extern void switch_core_time_duration_sec_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_status_t switch_network_list_add_host_mask(SWIGTYPE_p_switch_network_list list, string host, string mask_str, switch_bool_t ok) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_add_host_mask(SWIGTYPE_p_switch_network_list.getCPtr(list), host, mask_str, (int)ok);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_sec_get")]
+  public static extern uint switch_core_time_duration_sec_get(HandleRef jarg1);
 
-  public static switch_bool_t switch_network_list_validate_ip_token(SWIGTYPE_p_switch_network_list list, uint ip, ref string token) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_network_list_validate_ip_token(SWIGTYPE_p_switch_network_list.getCPtr(list), ip, ref token);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_min_set")]
+  public static extern void switch_core_time_duration_min_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_caller_extension switch_caller_extension_new(SWIGTYPE_p_switch_core_session session, string extension_name, string extension_number) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_new(SWIGTYPE_p_switch_core_session.getCPtr(session), extension_name, extension_number);
-    switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_min_get")]
+  public static extern uint switch_core_time_duration_min_get(HandleRef jarg1);
 
-  public static switch_status_t switch_caller_extension_clone(SWIGTYPE_p_p_switch_caller_extension new_ext, switch_caller_extension orig, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_caller_extension_clone(SWIGTYPE_p_p_switch_caller_extension.getCPtr(new_ext), switch_caller_extension.getCPtr(orig), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_hr_set")]
+  public static extern void switch_core_time_duration_hr_set(HandleRef jarg1, uint jarg2);
 
-  public static void switch_caller_extension_add_application(SWIGTYPE_p_switch_core_session session, switch_caller_extension caller_extension, string application_name, string extra_data) {
-    freeswitchPINVOKE.switch_caller_extension_add_application(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_caller_extension.getCPtr(caller_extension), application_name, extra_data);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_hr_get")]
+  public static extern uint switch_core_time_duration_hr_get(HandleRef jarg1);
 
-  public static string switch_caller_get_field_by_name(switch_caller_profile caller_profile, string name) {
-    string ret = freeswitchPINVOKE.switch_caller_get_field_by_name(switch_caller_profile.getCPtr(caller_profile), name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_day_set")]
+  public static extern void switch_core_time_duration_day_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_caller_profile switch_caller_profile_new(SWIGTYPE_p_apr_pool_t pool, string username, string dialplan, string caller_id_name, string caller_id_number, string network_addr, string ani, string aniii, string rdnis, string source, string context, string destination_number) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_new(SWIGTYPE_p_apr_pool_t.getCPtr(pool), username, dialplan, caller_id_name, caller_id_number, network_addr, ani, aniii, rdnis, source, context, destination_number);
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_day_get")]
+  public static extern uint switch_core_time_duration_day_get(HandleRef jarg1);
 
-  public static switch_caller_profile switch_caller_profile_clone(SWIGTYPE_p_switch_core_session session, switch_caller_profile tocopy) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_clone(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_caller_profile.getCPtr(tocopy));
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_yr_set")]
+  public static extern void switch_core_time_duration_yr_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_caller_profile switch_caller_profile_dup(SWIGTYPE_p_apr_pool_t pool, switch_caller_profile tocopy) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_dup(SWIGTYPE_p_apr_pool_t.getCPtr(pool), switch_caller_profile.getCPtr(tocopy));
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_yr_get")]
+  public static extern uint switch_core_time_duration_yr_get(HandleRef jarg1);
 
-  public static void switch_caller_profile_event_set_data(switch_caller_profile caller_profile, string prefix, switch_event arg2) {
-    freeswitchPINVOKE.switch_caller_profile_event_set_data(switch_caller_profile.getCPtr(caller_profile), prefix, switch_event.getCPtr(arg2));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_time_duration")]
+  public static extern IntPtr new_switch_core_time_duration();
 
-  public static switch_channel_state_t switch_channel_get_state(SWIGTYPE_p_switch_channel channel) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_get_state(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_time_duration")]
+  public static extern void delete_switch_core_time_duration(HandleRef jarg1);
 
-  public static switch_channel_state_t switch_channel_get_running_state(SWIGTYPE_p_switch_channel channel) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_get_running_state(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_app_set")]
+  public static extern void switch_app_log_app_set(HandleRef jarg1, string jarg2);
 
-  public static byte switch_channel_ready(SWIGTYPE_p_switch_channel channel) {
-    byte ret = freeswitchPINVOKE.switch_channel_ready(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_app_get")]
+  public static extern string switch_app_log_app_get(HandleRef jarg1);
 
-  public static void switch_channel_wait_for_state(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_switch_channel other_channel, switch_channel_state_t want_state) {
-    freeswitchPINVOKE.switch_channel_wait_for_state(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_switch_channel.getCPtr(other_channel), (int)want_state);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_arg_set")]
+  public static extern void switch_app_log_arg_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_channel_wait_for_flag(SWIGTYPE_p_switch_channel channel, uint want_flag, switch_bool_t pres, uint to, SWIGTYPE_p_switch_channel super_channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_wait_for_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), want_flag, (int)pres, to, SWIGTYPE_p_switch_channel.getCPtr(super_channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_arg_get")]
+  public static extern string switch_app_log_arg_get(HandleRef jarg1);
 
-  public static switch_channel_state_t switch_channel_perform_set_state(SWIGTYPE_p_switch_channel channel, string file, string func, int line, switch_channel_state_t state) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_set_state(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line, (int)state);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_next_set")]
+  public static extern void switch_app_log_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_channel_state_t switch_channel_perform_set_running_state(SWIGTYPE_p_switch_channel channel, switch_channel_state_t state, string file, string func, int line) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_set_running_state(SWIGTYPE_p_switch_channel.getCPtr(channel), (int)state, file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_next_get")]
+  public static extern IntPtr switch_app_log_next_get(HandleRef jarg1);
 
-  public static switch_call_cause_t switch_channel_str2cause(string str) {
-    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_str2cause(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_app_log")]
+  public static extern IntPtr new_switch_app_log();
 
-  public static switch_call_cause_t switch_channel_get_cause(SWIGTYPE_p_switch_channel channel) {
-    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_get_cause(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_app_log")]
+  public static extern void delete_switch_app_log(HandleRef jarg1);
 
-  public static string switch_channel_cause2str(switch_call_cause_t cause) {
-    string ret = freeswitchPINVOKE.switch_channel_cause2str((int)cause);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_from_set")]
+  public static extern void switch_core_session_message_from_set(HandleRef jarg1, string jarg2);
 
-  public static switch_channel_timetable switch_channel_get_timetable(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_timetable(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_from_get")]
+  public static extern string switch_core_session_message_from_get(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_alloc(SWIGTYPE_p_p_switch_channel channel, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_alloc(SWIGTYPE_p_p_switch_channel.getCPtr(channel), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_message_id_set")]
+  public static extern void switch_core_session_message_message_id_set(HandleRef jarg1, int jarg2);
 
-  public static switch_status_t switch_channel_init(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_switch_core_session session, switch_channel_state_t state, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_init(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_switch_core_session.getCPtr(session), (int)state, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_message_id_get")]
+  public static extern int switch_core_session_message_message_id_get(HandleRef jarg1);
 
-  public static void switch_channel_presence(SWIGTYPE_p_switch_channel channel, string rpid, string status, string id) {
-    freeswitchPINVOKE.switch_channel_presence(SWIGTYPE_p_switch_channel.getCPtr(channel), rpid, status, id);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_arg_set")]
+  public static extern void switch_core_session_message_numeric_arg_set(HandleRef jarg1, int jarg2);
 
-  public static void switch_channel_uninit(SWIGTYPE_p_switch_channel channel) {
-    freeswitchPINVOKE.switch_channel_uninit(SWIGTYPE_p_switch_channel.getCPtr(channel));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_arg_get")]
+  public static extern int switch_core_session_message_numeric_arg_get(HandleRef jarg1);
 
-  public static void switch_channel_set_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
-    freeswitchPINVOKE.switch_channel_set_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_set")]
+  public static extern void switch_core_session_message_string_arg_set(HandleRef jarg1, string jarg2);
 
-  public static switch_caller_profile switch_channel_get_caller_profile(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_get")]
+  public static extern string switch_core_session_message_string_arg_get(HandleRef jarg1);
 
-  public static void switch_channel_set_originator_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
-    freeswitchPINVOKE.switch_channel_set_originator_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_size_set")]
+  public static extern void switch_core_session_message_string_arg_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_caller_profile switch_channel_get_originator_caller_profile(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_originator_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_size_get")]
+  public static extern IntPtr switch_core_session_message_string_arg_size_get(HandleRef jarg1);
 
-  public static void switch_channel_set_originatee_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
-    freeswitchPINVOKE.switch_channel_set_originatee_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_set")]
+  public static extern void switch_core_session_message_pointer_arg_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_caller_profile switch_channel_get_originatee_caller_profile(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_originatee_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_get")]
+  public static extern IntPtr switch_core_session_message_pointer_arg_get(HandleRef jarg1);
 
-  public static string switch_channel_get_uuid(SWIGTYPE_p_switch_channel channel) {
-    string ret = freeswitchPINVOKE.switch_channel_get_uuid(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_size_set")]
+  public static extern void switch_core_session_message_pointer_arg_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_channel_set_variable(SWIGTYPE_p_switch_channel channel, string varname, string value) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_variable(SWIGTYPE_p_switch_channel.getCPtr(channel), varname, value);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_size_get")]
+  public static extern IntPtr switch_core_session_message_pointer_arg_size_get(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_set_variable_partner(SWIGTYPE_p_switch_channel channel, string varname, string value) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_variable_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), varname, value);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_reply_set")]
+  public static extern void switch_core_session_message_numeric_reply_set(HandleRef jarg1, int jarg2);
 
-  public static string switch_channel_get_variable_partner(SWIGTYPE_p_switch_channel channel, string varname) {
-    string ret = freeswitchPINVOKE.switch_channel_get_variable_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), varname);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_reply_get")]
+  public static extern int switch_core_session_message_numeric_reply_get(HandleRef jarg1);
 
-  public static string switch_channel_get_variable(SWIGTYPE_p_switch_channel channel, string varname) {
-    string ret = freeswitchPINVOKE.switch_channel_get_variable(SWIGTYPE_p_switch_channel.getCPtr(channel), varname);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_set")]
+  public static extern void switch_core_session_message_string_reply_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_channel_get_variables(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_p_switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_get_variables(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_get")]
+  public static extern string switch_core_session_message_string_reply_get(HandleRef jarg1);
 
-  public static switch_event_header switch_channel_variable_first(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_variable_first(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_size_set")]
+  public static extern void switch_core_session_message_string_reply_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_channel_variable_last(SWIGTYPE_p_switch_channel channel) {
-    freeswitchPINVOKE.switch_channel_variable_last(SWIGTYPE_p_switch_channel.getCPtr(channel));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_size_get")]
+  public static extern IntPtr switch_core_session_message_string_reply_size_get(HandleRef jarg1);
 
-  public static void switch_channel_set_caller_extension(SWIGTYPE_p_switch_channel channel, switch_caller_extension caller_extension) {
-    freeswitchPINVOKE.switch_channel_set_caller_extension(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_extension.getCPtr(caller_extension));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_set")]
+  public static extern void switch_core_session_message_pointer_reply_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_caller_extension switch_channel_get_caller_extension(SWIGTYPE_p_switch_channel channel) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_caller_extension(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_get")]
+  public static extern IntPtr switch_core_session_message_pointer_reply_get(HandleRef jarg1);
 
-  public static uint switch_channel_test_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
-    uint ret = freeswitchPINVOKE.switch_channel_test_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_size_set")]
+  public static extern void switch_core_session_message_pointer_reply_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_channel_set_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
-    freeswitchPINVOKE.switch_channel_set_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_size_get")]
+  public static extern IntPtr switch_core_session_message_pointer_reply_size_get(HandleRef jarg1);
 
-  public static switch_bool_t switch_channel_set_flag_partner(SWIGTYPE_p_switch_channel channel, uint flags) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_channel_set_flag_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_flags_set")]
+  public static extern void switch_core_session_message_flags_set(HandleRef jarg1, uint jarg2);
 
-  public static switch_bool_t switch_channel_clear_flag_partner(SWIGTYPE_p_switch_channel channel, uint flags) {
-    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_channel_clear_flag_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_flags_get")]
+  public static extern uint switch_core_session_message_flags_get(HandleRef jarg1);
 
-  public static void switch_channel_set_state_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
-    freeswitchPINVOKE.switch_channel_set_state_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_session_message")]
+  public static extern IntPtr new_switch_core_session_message();
 
-  public static void switch_channel_clear_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
-    freeswitchPINVOKE.switch_channel_clear_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_session_message")]
+  public static extern void delete_switch_core_session_message(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_perform_answer(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_answer(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_running_set")]
+  public static extern void switch_core_thread_session_running_set(HandleRef jarg1, int jarg2);
 
-  public static switch_status_t switch_channel_perform_mark_answered(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_answered(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_running_get")]
+  public static extern int switch_core_thread_session_running_get(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_perform_ring_ready(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_ring_ready(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_mutex_set")]
+  public static extern void switch_core_thread_session_mutex_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_channel_perform_pre_answer(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_pre_answer(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_mutex_get")]
+  public static extern IntPtr switch_core_thread_session_mutex_get(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_perform_mark_pre_answered(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_pre_answered(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_objs_set")]
+  public static extern void switch_core_thread_session_objs_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_channel_perform_mark_ring_ready(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_ring_ready(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_objs_get")]
+  public static extern IntPtr switch_core_thread_session_objs_get(HandleRef jarg1);
 
-  public static int switch_channel_add_state_handler(SWIGTYPE_p_switch_channel channel, switch_state_handler_table state_handler) {
-    int ret = freeswitchPINVOKE.switch_channel_add_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_state_handler_table.getCPtr(state_handler));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_input_callback_set")]
+  public static extern void switch_core_thread_session_input_callback_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_channel_clear_state_handler(SWIGTYPE_p_switch_channel channel, switch_state_handler_table state_handler) {
-    freeswitchPINVOKE.switch_channel_clear_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_state_handler_table.getCPtr(state_handler));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_input_callback_get")]
+  public static extern IntPtr switch_core_thread_session_input_callback_get(HandleRef jarg1);
 
-  public static switch_state_handler_table switch_channel_get_state_handler(SWIGTYPE_p_switch_channel channel, int index) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), index);
-    switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_pool_set")]
+  public static extern void switch_core_thread_session_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_channel_set_private(SWIGTYPE_p_switch_channel channel, string key, SWIGTYPE_p_void private_info) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_private(SWIGTYPE_p_switch_channel.getCPtr(channel), key, SWIGTYPE_p_void.getCPtr(private_info));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_pool_get")]
+  public static extern IntPtr switch_core_thread_session_pool_get(HandleRef jarg1);
 
-  public static SWIGTYPE_p_void switch_channel_get_private(SWIGTYPE_p_switch_channel channel, string key) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_private(SWIGTYPE_p_switch_channel.getCPtr(channel), key);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_thread_session")]
+  public static extern IntPtr new_switch_core_thread_session();
 
-  public static switch_status_t switch_channel_set_name(SWIGTYPE_p_switch_channel channel, string name) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_name(SWIGTYPE_p_switch_channel.getCPtr(channel), name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_thread_session")]
+  public static extern void delete_switch_core_thread_session(HandleRef jarg1);
 
-  public static string switch_channel_get_name(SWIGTYPE_p_switch_channel channel) {
-    string ret = freeswitchPINVOKE.switch_channel_get_name(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_add")]
+  public static extern int switch_core_media_bug_add(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, uint jarg5, HandleRef jarg6);
 
-  public static switch_channel_state_t switch_channel_perform_hangup(SWIGTYPE_p_switch_channel channel, string file, string func, int line, switch_call_cause_t hangup_cause) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_hangup(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line, (int)hangup_cause);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_user_data")]
+  public static extern IntPtr switch_core_media_bug_get_user_data(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_channel_has_dtmf(SWIGTYPE_p_switch_channel channel) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_channel_has_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_write_replace_frame")]
+  public static extern IntPtr switch_core_media_bug_get_write_replace_frame(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_queue_dtmf(SWIGTYPE_p_switch_channel channel, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_queue_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_set_write_replace_frame")]
+  public static extern void switch_core_media_bug_set_write_replace_frame(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_channel_queue_dtmf_string(SWIGTYPE_p_switch_channel channel, string dtmf_string) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_queue_dtmf_string(SWIGTYPE_p_switch_channel.getCPtr(channel), dtmf_string);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_read_replace_frame")]
+  public static extern IntPtr switch_core_media_bug_get_read_replace_frame(HandleRef jarg1);
 
-  public static switch_status_t switch_channel_dequeue_dtmf(SWIGTYPE_p_switch_channel channel, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_dequeue_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_session")]
+  public static extern IntPtr switch_core_media_bug_get_session(HandleRef jarg1);
 
-  public static void switch_channel_flush_dtmf(SWIGTYPE_p_switch_channel channel) {
-    freeswitchPINVOKE.switch_channel_flush_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_test_flag")]
+  public static extern uint switch_core_media_bug_test_flag(HandleRef jarg1, uint jarg2);
 
-  public static SWIGTYPE_p_switch_size_t switch_channel_dequeue_dtmf_string(SWIGTYPE_p_switch_channel channel, string dtmf_str, SWIGTYPE_p_switch_size_t len) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_channel_dequeue_dtmf_string(SWIGTYPE_p_switch_channel.getCPtr(channel), dtmf_str, SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_set_read_replace_frame")]
+  public static extern void switch_core_media_bug_set_read_replace_frame(HandleRef jarg1, HandleRef jarg2);
 
-  public static string switch_channel_state_name(switch_channel_state_t state) {
-    string ret = freeswitchPINVOKE.switch_channel_state_name((int)state);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_remove")]
+  public static extern int switch_core_media_bug_remove(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_channel_state_t switch_channel_name_state(string name) {
-    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_name_state(name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_close")]
+  public static extern int switch_core_media_bug_close(HandleRef jarg1);
 
-  public static void switch_channel_event_set_data(SWIGTYPE_p_switch_channel channel, switch_event arg1) {
-    freeswitchPINVOKE.switch_channel_event_set_data(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_event.getCPtr(arg1));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_remove_all")]
+  public static extern int switch_core_media_bug_remove_all(HandleRef jarg1);
 
-  public static string switch_channel_expand_variables(SWIGTYPE_p_switch_channel channel, string arg1) {
-    string ret = freeswitchPINVOKE.switch_channel_expand_variables(SWIGTYPE_p_switch_channel.getCPtr(channel), arg1);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_read")]
+  public static extern int switch_core_media_bug_read(HandleRef jarg1, HandleRef jarg2);
 
-  public static string switch_channel_build_param_string(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile, string prefix) {
-    string ret = freeswitchPINVOKE.switch_channel_build_param_string(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile), prefix);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_new")]
+  public static extern int switch_core_port_allocator_new(ushort jarg1, ushort jarg2, uint jarg3, HandleRef jarg4);
 
-  public static switch_status_t switch_channel_set_timestamps(SWIGTYPE_p_switch_channel channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_timestamps(SWIGTYPE_p_switch_channel.getCPtr(channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_request_port")]
+  public static extern int switch_core_port_allocator_request_port(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_buffer_create(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t max_len) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_create(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(max_len));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_free_port")]
+  public static extern int switch_core_port_allocator_free_port(HandleRef jarg1, ushort jarg2);
 
-  public static switch_status_t switch_buffer_create_dynamic(SWIGTYPE_p_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t blocksize, SWIGTYPE_p_switch_size_t start_len, SWIGTYPE_p_switch_size_t max_len) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_create_dynamic(SWIGTYPE_p_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(blocksize), SWIGTYPE_p_switch_size_t.getCPtr(start_len), SWIGTYPE_p_switch_size_t.getCPtr(max_len));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_destroy")]
+  public static extern void switch_core_port_allocator_destroy(HandleRef jarg1);
 
-  public static void switch_buffer_add_mutex(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_switch_mutex_t mutex) {
-    freeswitchPINVOKE.switch_buffer_add_mutex(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_init")]
+  public static extern int switch_core_init(uint jarg1, int jarg2, ref string jarg3);
 
-  public static void switch_buffer_lock(SWIGTYPE_p_switch_buffer buffer) {
-    freeswitchPINVOKE.switch_buffer_lock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_init_and_modload")]
+  public static extern int switch_core_init_and_modload(uint jarg1, int jarg2, ref string jarg3);
 
-  public static switch_status_t switch_buffer_trylock(SWIGTYPE_p_switch_buffer buffer) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_trylock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_limit")]
+  public static extern uint switch_core_session_limit(uint jarg1);
 
-  public static void switch_buffer_unlock(SWIGTYPE_p_switch_buffer buffer) {
-    freeswitchPINVOKE.switch_buffer_unlock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_sessions_per_second")]
+  public static extern uint switch_core_sessions_per_second(uint jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_len(SWIGTYPE_p_switch_buffer buffer) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_len(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_destroy")]
+  public static extern int switch_core_destroy();
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_freespace(SWIGTYPE_p_switch_buffer buffer) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_freespace(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_lock")]
+  public static extern int switch_core_session_signal_lock(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_inuse(SWIGTYPE_p_switch_buffer buffer) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_inuse(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_unlock")]
+  public static extern int switch_core_session_signal_unlock(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_read(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_read(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_lock")]
+  public static extern int switch_core_session_read_lock(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_read_loop(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_read_loop(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_lock")]
+  public static extern void switch_core_session_write_lock(HandleRef jarg1);
 
-  public static void switch_buffer_set_loops(SWIGTYPE_p_switch_buffer buffer, int loops) {
-    freeswitchPINVOKE.switch_buffer_set_loops(SWIGTYPE_p_switch_buffer.getCPtr(buffer), loops);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_rwunlock")]
+  public static extern void switch_core_session_rwunlock(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_write(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_write(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_add_state_handler")]
+  public static extern int switch_core_add_state_handler(HandleRef jarg1);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_toss(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t datalen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_toss(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_remove_state_handler")]
+  public static extern void switch_core_remove_state_handler(HandleRef jarg1);
 
-  public static void switch_buffer_zero(SWIGTYPE_p_switch_buffer buffer) {
-    freeswitchPINVOKE.switch_buffer_zero(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_state_handler")]
+  public static extern IntPtr switch_core_get_state_handler(int jarg1);
 
-  public static void switch_buffer_destroy(SWIGTYPE_p_p_switch_buffer buffer) {
-    freeswitchPINVOKE.switch_buffer_destroy(SWIGTYPE_p_p_switch_buffer.getCPtr(buffer));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_pool_tag")]
+  public static extern void switch_core_memory_pool_tag(HandleRef jarg1, string jarg2);
 
-  public static SWIGTYPE_p_switch_size_t switch_buffer_zwrite(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_zwrite(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_new_memory_pool")]
+  public static extern int switch_core_perform_new_memory_pool(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static switch_status_t switch_event_init(SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_destroy_memory_pool")]
+  public static extern int switch_core_perform_destroy_memory_pool(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static switch_status_t switch_event_shutdown() {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_shutdown();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_run")]
+  public static extern void switch_core_session_run(HandleRef jarg1);
 
-  public static switch_status_t switch_event_create_subclass(SWIGTYPE_p_p_switch_event arg0, switch_event_types_t event_id, string subclass_name) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_create_subclass(SWIGTYPE_p_p_switch_event.getCPtr(arg0), (int)event_id, subclass_name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_running")]
+  public static extern uint switch_core_session_running(HandleRef jarg1);
 
-  public static switch_status_t switch_event_set_priority(switch_event arg0, switch_priority_t priority) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_set_priority(switch_event.getCPtr(arg0), (int)priority);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_permanent_alloc")]
+  public static extern IntPtr switch_core_perform_permanent_alloc(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static string switch_event_get_header(switch_event arg0, string header_name) {
-    string ret = freeswitchPINVOKE.switch_event_get_header(switch_event.getCPtr(arg0), header_name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_alloc")]
+  public static extern IntPtr switch_core_perform_alloc(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, int jarg5);
 
-  public static string switch_event_get_body(switch_event arg0) {
-    string ret = freeswitchPINVOKE.switch_event_get_body(switch_event.getCPtr(arg0));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_session_alloc")]
+  public static extern IntPtr switch_core_perform_session_alloc(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, int jarg5);
 
-  public static switch_status_t switch_event_add_header_string(switch_event arg0, switch_stack_t stack, string header_name, string data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_add_header_string(switch_event.getCPtr(arg0), (int)stack, header_name, data);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_permanent_strdup")]
+  public static extern string switch_core_perform_permanent_strdup(string jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static switch_status_t switch_event_del_header(switch_event arg0, string header_name) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_del_header(switch_event.getCPtr(arg0), header_name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_session_strdup")]
+  public static extern string switch_core_perform_session_strdup(HandleRef jarg1, string jarg2, string jarg3, string jarg4, int jarg5);
 
-  public static void switch_event_destroy(SWIGTYPE_p_p_switch_event arg0) {
-    freeswitchPINVOKE.switch_event_destroy(SWIGTYPE_p_p_switch_event.getCPtr(arg0));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_strdup")]
+  public static extern string switch_core_perform_strdup(HandleRef jarg1, string jarg2, string jarg3, string jarg4, int jarg5);
 
-  public static switch_status_t switch_event_dup(SWIGTYPE_p_p_switch_event arg0, switch_event todup) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_dup(SWIGTYPE_p_p_switch_event.getCPtr(arg0), switch_event.getCPtr(todup));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_sprintf")]
+  public static extern string switch_core_session_sprintf(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_event_fire_detailed(string file, string func, int line, SWIGTYPE_p_p_switch_event arg3, SWIGTYPE_p_void user_data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_fire_detailed(file, func, line, SWIGTYPE_p_p_switch_event.getCPtr(arg3), SWIGTYPE_p_void.getCPtr(user_data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_sprintf")]
+  public static extern string switch_core_sprintf(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_event_bind(string id, switch_event_types_t arg1, string subclass_name, SWIGTYPE_p_f_p_switch_event__void callback, SWIGTYPE_p_void user_data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_bind(id, (int)arg1, subclass_name, SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_pool")]
+  public static extern IntPtr switch_core_session_get_pool(HandleRef jarg1);
 
-  public static switch_status_t switch_event_bind_removable(string id, switch_event_types_t arg1, string subclass_name, SWIGTYPE_p_f_p_switch_event__void callback, SWIGTYPE_p_void user_data, SWIGTYPE_p_p_switch_event_node node) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_bind_removable(id, (int)arg1, subclass_name, SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data), SWIGTYPE_p_p_switch_event_node.getCPtr(node));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_request")]
+  public static extern IntPtr switch_core_session_request(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_event_unbind(SWIGTYPE_p_p_switch_event_node node) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_unbind(SWIGTYPE_p_p_switch_event_node.getCPtr(node));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_perform_destroy")]
+  public static extern void switch_core_session_perform_destroy(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static switch_status_t switch_event_unbind_callback(SWIGTYPE_p_f_p_switch_event__void callback) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_unbind_callback(SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_count")]
+  public static extern uint switch_core_session_count();
 
-  public static string switch_event_name(switch_event_types_t arg0) {
-    string ret = freeswitchPINVOKE.switch_event_name((int)arg0);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_id")]
+  public static extern IntPtr switch_core_session_id();
 
-  public static switch_status_t switch_name_event(string name, SWIGTYPE_p_switch_event_types_t type) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_name_event(name, SWIGTYPE_p_switch_event_types_t.getCPtr(type));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_request_by_name")]
+  public static extern IntPtr switch_core_session_request_by_name(string jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_event_reserve_subclass_detailed(string owner, string subclass_name) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_reserve_subclass_detailed(owner, subclass_name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_thread_launch")]
+  public static extern int switch_core_session_thread_launch(HandleRef jarg1);
 
-  public static switch_status_t switch_event_free_subclass_detailed(string owner, string subclass_name) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_free_subclass_detailed(owner, subclass_name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_channel")]
+  public static extern IntPtr switch_core_session_get_channel(HandleRef jarg1);
 
-  public static switch_status_t switch_event_serialize(switch_event arg0, ref string str, switch_bool_t encode) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_serialize(switch_event.getCPtr(arg0), ref str, (int)encode);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_state_change")]
+  public static extern void switch_core_session_signal_state_change(HandleRef jarg1);
 
-  public static switch_status_t switch_event_running() {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_running();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_uuid")]
+  public static extern string switch_core_session_get_uuid(HandleRef jarg1);
 
-  public static string switch_event_expand_headers(switch_event arg0, string arg1) {
-    string ret = freeswitchPINVOKE.switch_event_expand_headers(switch_event.getCPtr(arg0), arg1);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_uuid")]
+  public static extern string switch_core_get_uuid();
 
-  public static switch_status_t switch_event_create_pres_in_detailed(string file, string func, int line, string proto, string login, string from, string from_domain, string status, string event_type, string alt_event_type, int event_count, string unique_id, string channel_state, string answer_state, string call_direction) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_create_pres_in_detailed(file, func, line, proto, login, from, from_domain, status, event_type, alt_event_type, event_count, unique_id, channel_state, answer_state, call_direction);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_locate")]
+  public static extern IntPtr switch_core_session_locate(string jarg1);
 
-  public static void switch_event_deliver(SWIGTYPE_p_p_switch_event arg0) {
-    freeswitchPINVOKE.switch_event_deliver(SWIGTYPE_p_p_switch_event.getCPtr(arg0));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_variable")]
+  public static extern string switch_core_get_variable(string jarg1);
 
-  public static string switch_event_build_param_string(switch_event arg0, string prefix, SWIGTYPE_p_switch_hash vars_map) {
-    string ret = freeswitchPINVOKE.switch_event_build_param_string(switch_event.getCPtr(arg0), prefix, SWIGTYPE_p_switch_hash.getCPtr(vars_map));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_variable")]
+  public static extern void switch_core_set_variable(string jarg1, string jarg2);
 
-  public static switch_status_t switch_resample_create(SWIGTYPE_p_p_switch_audio_resampler_t new_resampler, int from_rate, SWIGTYPE_p_switch_size_t from_size, int to_rate, uint to_size, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_resample_create(SWIGTYPE_p_p_switch_audio_resampler_t.getCPtr(new_resampler), from_rate, SWIGTYPE_p_switch_size_t.getCPtr(from_size), to_rate, to_size, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_dump_variables")]
+  public static extern void switch_core_dump_variables(HandleRef jarg1);
 
-  public static void switch_resample_destroy(SWIGTYPE_p_p_switch_audio_resampler_t resampler) {
-    freeswitchPINVOKE.switch_resample_destroy(SWIGTYPE_p_p_switch_audio_resampler_t.getCPtr(resampler));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall")]
+  public static extern void switch_core_session_hupall(int jarg1);
 
-  public static uint switch_resample_process(switch_audio_resampler_t resampler, SWIGTYPE_p_float src, int srclen, SWIGTYPE_p_float dst, uint dstlen, int last) {
-    uint ret = freeswitchPINVOKE.switch_resample_process(switch_audio_resampler_t.getCPtr(resampler), SWIGTYPE_p_float.getCPtr(src), srclen, SWIGTYPE_p_float.getCPtr(dst), dstlen, last);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall_matching_var")]
+  public static extern void switch_core_session_hupall_matching_var(string jarg1, string jarg2, int jarg3);
 
-  public static SWIGTYPE_p_switch_size_t switch_float_to_short(SWIGTYPE_p_float f, SWIGTYPE_p_short s, SWIGTYPE_p_switch_size_t len) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_float_to_short(SWIGTYPE_p_float.getCPtr(f), SWIGTYPE_p_short.getCPtr(s), SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall_endpoint")]
+  public static extern void switch_core_session_hupall_endpoint(HandleRef jarg1, int jarg2);
 
-  public static int switch_char_to_float(string c, SWIGTYPE_p_float f, int len) {
-    int ret = freeswitchPINVOKE.switch_char_to_float(c, SWIGTYPE_p_float.getCPtr(f), len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_send")]
+  public static extern int switch_core_session_message_send(string jarg1, HandleRef jarg2);
 
-  public static int switch_float_to_char(SWIGTYPE_p_float f, string c, int len) {
-    int ret = freeswitchPINVOKE.switch_float_to_char(SWIGTYPE_p_float.getCPtr(f), c, len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_message")]
+  public static extern int switch_core_session_queue_message(HandleRef jarg1, HandleRef jarg2);
 
-  public static int switch_short_to_float(SWIGTYPE_p_short s, SWIGTYPE_p_float f, int len) {
-    int ret = freeswitchPINVOKE.switch_short_to_float(SWIGTYPE_p_short.getCPtr(s), SWIGTYPE_p_float.getCPtr(f), len);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_pass_indication")]
+  public static extern int switch_core_session_pass_indication(HandleRef jarg1, int jarg2);
 
-  public static void switch_swap_linear(SWIGTYPE_p_short buf, int len) {
-    freeswitchPINVOKE.switch_swap_linear(SWIGTYPE_p_short.getCPtr(buf), len);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_indication")]
+  public static extern int switch_core_session_queue_indication(HandleRef jarg1, int jarg2);
 
-  public static void switch_generate_sln_silence(SWIGTYPE_p_short data, uint samples, uint divisor) {
-    freeswitchPINVOKE.switch_generate_sln_silence(SWIGTYPE_p_short.getCPtr(data), samples, divisor);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_message")]
+  public static extern int switch_core_session_dequeue_message(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_change_sln_volume(SWIGTYPE_p_short data, uint samples, int vol) {
-    freeswitchPINVOKE.switch_change_sln_volume(SWIGTYPE_p_short.getCPtr(data), samples, vol);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_flush_message")]
+  public static extern int switch_core_session_flush_message(HandleRef jarg1);
 
-  public static uint switch_merge_sln(SWIGTYPE_p_short data, uint samples, SWIGTYPE_p_short other_data, uint other_samples) {
-    uint ret = freeswitchPINVOKE.switch_merge_sln(SWIGTYPE_p_short.getCPtr(data), samples, SWIGTYPE_p_short.getCPtr(other_data), other_samples);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_event_send")]
+  public static extern int switch_core_session_event_send(string jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_deactivate_unicast(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_deactivate_unicast(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_app_log")]
+  public static extern IntPtr switch_core_session_get_app_log(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_activate_unicast(SWIGTYPE_p_switch_core_session session, string local_ip, ushort local_port, string remote_ip, ushort remote_port, string transport, string flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_activate_unicast(SWIGTYPE_p_switch_core_session.getCPtr(session), local_ip, local_port, remote_ip, remote_port, transport, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_exec")]
+  public static extern int switch_core_session_exec(HandleRef jarg1, HandleRef jarg2, string jarg3);
 
-  public static switch_status_t switch_ivr_generate_xml_cdr(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_xml xml_cdr) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_generate_xml_cdr(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_xml.getCPtr(xml_cdr));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_execute_application")]
+  public static extern int switch_core_session_execute_application(HandleRef jarg1, string jarg2, string jarg3);
 
-  public static int switch_ivr_set_xml_profile_data(switch_xml xml, switch_caller_profile caller_profile, int off) {
-    int ret = freeswitchPINVOKE.switch_ivr_set_xml_profile_data(switch_xml.getCPtr(xml), switch_caller_profile.getCPtr(caller_profile), off);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_execute_exten")]
+  public static extern int switch_core_session_execute_exten(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  public static int switch_ivr_set_xml_chan_vars(switch_xml xml, SWIGTYPE_p_switch_channel channel, int off) {
-    int ret = freeswitchPINVOKE.switch_ivr_set_xml_chan_vars(switch_xml.getCPtr(xml), SWIGTYPE_p_switch_channel.getCPtr(channel), off);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_receive_event")]
+  public static extern int switch_core_session_receive_event(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_parse_event(SWIGTYPE_p_switch_core_session session, switch_event arg1) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_event(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_event.getCPtr(arg1));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_private")]
+  public static extern IntPtr switch_core_session_get_private(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_parse_all_events(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_all_events(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_private")]
+  public static extern int switch_core_session_set_private(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_parse_next_event(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_next_event(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_add_stream")]
+  public static extern int switch_core_session_add_stream(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_sleep(SWIGTYPE_p_switch_core_session session, uint ms, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_sleep(SWIGTYPE_p_switch_core_session.getCPtr(session), ms, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_stream")]
+  public static extern IntPtr switch_core_session_get_stream(HandleRef jarg1, int jarg2);
 
-  public static switch_status_t switch_ivr_park(SWIGTYPE_p_switch_core_session session, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_park(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_stream_count")]
+  public static extern int switch_core_session_get_stream_count(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_collect_digits_callback(SWIGTYPE_p_switch_core_session session, switch_input_args_t args, uint timeout) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_collect_digits_callback(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_input_args_t.getCPtr(args), timeout);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_launch_thread")]
+  public static extern void switch_core_session_launch_thread(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_collect_digits_count(SWIGTYPE_p_switch_core_session session, string buf, SWIGTYPE_p_switch_size_t buflen, SWIGTYPE_p_switch_size_t maxdigits, string terminators, string terminator, uint first_timeout, uint digit_timeout, uint abs_timeout) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_collect_digits_count(SWIGTYPE_p_switch_core_session.getCPtr(session), buf, SWIGTYPE_p_switch_size_t.getCPtr(buflen), SWIGTYPE_p_switch_size_t.getCPtr(maxdigits), terminators, terminator, first_timeout, digit_timeout, abs_timeout);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_end")]
+  public static extern void switch_core_thread_session_end(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_detect_speech(SWIGTYPE_p_switch_core_session session, string mod_name, string grammar, string path, string dest, switch_asr_handle ah) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session), mod_name, grammar, path, dest, switch_asr_handle.getCPtr(ah));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_service_session")]
+  public static extern void switch_core_service_session(HandleRef jarg1, HandleRef jarg2, int jarg3);
 
-  public static switch_status_t switch_ivr_stop_detect_speech(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_outgoing_channel")]
+  public static extern int switch_core_session_outgoing_channel(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5, HandleRef jarg6, uint jarg7);
 
-  public static switch_status_t switch_ivr_pause_detect_speech(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_pause_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_resurrect_channel")]
+  public static extern int switch_core_session_resurrect_channel(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static switch_status_t switch_ivr_resume_detect_speech(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_resume_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_receive_message")]
+  public static extern int switch_core_session_receive_message(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_detect_speech_load_grammar(SWIGTYPE_p_switch_core_session session, string grammar, string path) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech_load_grammar(SWIGTYPE_p_switch_core_session.getCPtr(session), grammar, path);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_event")]
+  public static extern int switch_core_session_queue_event(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_detect_speech_unload_grammar(SWIGTYPE_p_switch_core_session session, string grammar) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech_unload_grammar(SWIGTYPE_p_switch_core_session.getCPtr(session), grammar);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_event_count")]
+  public static extern uint switch_core_session_event_count(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_record_session(SWIGTYPE_p_switch_core_session session, string file, uint limit, switch_file_handle fh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_record_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file, limit, switch_file_handle.getCPtr(fh));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_event")]
+  public static extern int switch_core_session_dequeue_event(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_eavesdrop_session(SWIGTYPE_p_switch_core_session session, string uuid, string require_group, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_eavesdrop_session(SWIGTYPE_p_switch_core_session.getCPtr(session), uuid, require_group, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_private_event")]
+  public static extern int switch_core_session_queue_private_event(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_displace_session(SWIGTYPE_p_switch_core_session session, string file, uint limit, string flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_displace_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file, limit, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_private_event_count")]
+  public static extern uint switch_core_session_private_event_count(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_stop_displace_session(SWIGTYPE_p_switch_core_session session, string file) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_displace_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_private_event")]
+  public static extern int switch_core_session_dequeue_private_event(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_stop_record_session(SWIGTYPE_p_switch_core_session session, string file) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_record_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_flush_private_events")]
+  public static extern uint switch_core_session_flush_private_events(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_inband_dtmf_session(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_inband_dtmf_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_frame")]
+  public static extern int switch_core_session_read_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
 
-  public static switch_status_t switch_ivr_stop_inband_dtmf_session(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_inband_dtmf_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_video_frame")]
+  public static extern int switch_core_session_read_video_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
 
-  public static switch_status_t switch_ivr_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session session, switch_bool_t read_stream) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)read_stream);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_video_frame")]
+  public static extern int switch_core_session_write_video_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
 
-  public static switch_status_t switch_ivr_stop_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_reset")]
+  public static extern void switch_core_session_reset(HandleRef jarg1, int jarg2);
 
-  public static void switch_ivr_session_echo(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_ivr_session_echo(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_frame")]
+  public static extern int switch_core_session_write_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
 
-  public static switch_status_t switch_ivr_stop_tone_detect_session(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_tone_detect_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_perform_kill_channel")]
+  public static extern int switch_core_session_perform_kill_channel(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
 
-  public static switch_status_t switch_ivr_tone_detect_session(SWIGTYPE_p_switch_core_session session, string key, string tone_spec, string flags, SWIGTYPE_p_time_t timeout, string app, string data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_tone_detect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), key, tone_spec, flags, SWIGTYPE_p_time_t.getCPtr(timeout), app, data);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_send_dtmf")]
+  public static extern int switch_core_session_send_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_play_file(SWIGTYPE_p_switch_core_session session, switch_file_handle fh, string file, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_play_file(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_file_handle.getCPtr(fh), file, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_send_dtmf_string")]
+  public static extern int switch_core_session_send_dtmf_string(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_ivr_wait_for_silence(SWIGTYPE_p_switch_core_session session, uint thresh, uint silence_hits, uint listen_hits, uint timeout_ms, string file) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_wait_for_silence(SWIGTYPE_p_switch_core_session.getCPtr(session), thresh, silence_hits, listen_hits, timeout_ms, file);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_recv_dtmf")]
+  public static extern int switch_core_session_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_gentones(SWIGTYPE_p_switch_core_session session, string script, int loops, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_gentones(SWIGTYPE_p_switch_core_session.getCPtr(session), script, loops, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_init")]
+  public static extern int switch_core_hash_init(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_record_file(SWIGTYPE_p_switch_core_session session, switch_file_handle fh, string file, switch_input_args_t args, uint limit) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_record_file(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_file_handle.getCPtr(fh), file, switch_input_args_t.getCPtr(args), limit);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_destroy")]
+  public static extern int switch_core_hash_destroy(HandleRef jarg1);
 
-  public static switch_status_t switch_play_and_get_digits(SWIGTYPE_p_switch_core_session session, uint min_digits, uint max_digits, uint max_tries, uint timeout, string valid_terminators, string audio_file, string bad_input_audio_file, SWIGTYPE_p_void digit_buffer, uint digit_buffer_length, string digits_regex) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_play_and_get_digits(SWIGTYPE_p_switch_core_session.getCPtr(session), min_digits, max_digits, max_tries, timeout, valid_terminators, audio_file, bad_input_audio_file, SWIGTYPE_p_void.getCPtr(digit_buffer), digit_buffer_length, digits_regex);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_insert")]
+  public static extern int switch_core_hash_insert(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_speak_text_handle(SWIGTYPE_p_switch_core_session session, switch_speech_handle sh, switch_codec codec, switch_timer timer, string text, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_speak_text_handle(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_speech_handle.getCPtr(sh), switch_codec.getCPtr(codec), switch_timer.getCPtr(timer), text, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_insert_locked")]
+  public static extern int switch_core_hash_insert_locked(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static void switch_ivr_clear_speech_cache(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_ivr_clear_speech_cache(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_delete")]
+  public static extern int switch_core_hash_delete(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_ivr_speak_text(SWIGTYPE_p_switch_core_session session, string tts_name, string voice_name, string text, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_speak_text(SWIGTYPE_p_switch_core_session.getCPtr(session), tts_name, voice_name, text, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_delete_locked")]
+  public static extern int switch_core_hash_delete_locked(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_originate(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_core_session bleg, SWIGTYPE_p_switch_call_cause_t cause, string bridgeto, uint timelimit_sec, switch_state_handler_table table, string cid_name_override, string cid_num_override, switch_caller_profile caller_profile_override, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_originate(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_core_session.getCPtr(bleg), SWIGTYPE_p_switch_call_cause_t.getCPtr(cause), bridgeto, timelimit_sec, switch_state_handler_table.getCPtr(table), cid_name_override, cid_num_override, switch_caller_profile.getCPtr(caller_profile_override), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_find")]
+  public static extern IntPtr switch_core_hash_find(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_ivr_multi_threaded_bridge(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t dtmf_callback, SWIGTYPE_p_void session_data, SWIGTYPE_p_void peer_session_data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_multi_threaded_bridge(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session), SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(dtmf_callback), SWIGTYPE_p_void.getCPtr(session_data), SWIGTYPE_p_void.getCPtr(peer_session_data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_find_locked")]
+  public static extern IntPtr switch_core_hash_find_locked(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_signal_bridge(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_signal_bridge(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session));
-    return ret;
-  }
-
-  public static switch_status_t switch_ivr_session_transfer(SWIGTYPE_p_switch_core_session session, string extension, string dialplan, string context) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_session_transfer(SWIGTYPE_p_switch_core_session.getCPtr(session), extension, dialplan, context);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_first")]
+  public static extern IntPtr switch_hash_first(string jarg1, HandleRef jarg2);
 
-  public static uint switch_ivr_schedule_transfer(SWIGTYPE_p_time_t runtime, string uuid, string extension, string dialplan, string context) {
-    uint ret = freeswitchPINVOKE.switch_ivr_schedule_transfer(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, extension, dialplan, context);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_next")]
+  public static extern IntPtr switch_hash_next(HandleRef jarg1);
 
-  public static uint switch_ivr_schedule_hangup(SWIGTYPE_p_time_t runtime, string uuid, switch_call_cause_t cause, switch_bool_t bleg) {
-    uint ret = freeswitchPINVOKE.switch_ivr_schedule_hangup(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, (int)cause, (int)bleg);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_this")]
+  public static extern void switch_hash_this(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static switch_status_t switch_ivr_uuid_bridge(string originator_uuid, string originatee_uuid) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_uuid_bridge(originator_uuid, originatee_uuid);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_init")]
+  public static extern int switch_core_timer_init(HandleRef jarg1, string jarg2, int jarg3, int jarg4, HandleRef jarg5);
 
-  public static switch_status_t switch_ivr_media(string uuid, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_media(uuid, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_next")]
+  public static extern int switch_core_timer_next(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_nomedia(string uuid, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_nomedia(uuid, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_step")]
+  public static extern int switch_core_timer_step(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_hold_uuid(string uuid, string message, switch_bool_t moh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_hold_uuid(uuid, message, (int)moh);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_sync")]
+  public static extern int switch_core_timer_sync(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_unhold_uuid(string uuid) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unhold_uuid(uuid);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_check")]
+  public static extern int switch_core_timer_check(HandleRef jarg1, int jarg2);
 
-  public static switch_status_t switch_ivr_hold(SWIGTYPE_p_switch_core_session session, string message, switch_bool_t moh) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_hold(SWIGTYPE_p_switch_core_session.getCPtr(session), message, (int)moh);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_destroy")]
+  public static extern int switch_core_timer_destroy(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_unhold(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unhold(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_init")]
+  public static extern int switch_core_codec_init(HandleRef jarg1, string jarg2, string jarg3, uint jarg4, int jarg5, int jarg6, uint jarg7, HandleRef jarg8, HandleRef jarg9);
 
-  public static uint switch_ivr_schedule_broadcast(SWIGTYPE_p_time_t runtime, string uuid, string path, uint flags) {
-    uint ret = freeswitchPINVOKE.switch_ivr_schedule_broadcast(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, path, flags);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_copy")]
+  public static extern int switch_core_codec_copy(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_broadcast(string uuid, string path, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_broadcast(uuid, path, flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_encode")]
+  public static extern int switch_core_codec_encode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8, HandleRef jarg9);
 
-  public static switch_status_t switch_ivr_transfer_variable(SWIGTYPE_p_switch_core_session sessa, SWIGTYPE_p_switch_core_session sessb, string var) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_transfer_variable(SWIGTYPE_p_switch_core_session.getCPtr(sessa), SWIGTYPE_p_switch_core_session.getCPtr(sessb), var);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_decode")]
+  public static extern int switch_core_codec_decode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8, HandleRef jarg9);
 
-  public static switch_status_t switch_ivr_digit_stream_parser_new(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_p_switch_ivr_digit_stream_parser parser) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_new(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_p_switch_ivr_digit_stream_parser.getCPtr(parser));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_destroy")]
+  public static extern int switch_core_codec_destroy(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_parser_destroy(SWIGTYPE_p_switch_ivr_digit_stream_parser parser) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_destroy(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_read_codec")]
+  public static extern int switch_core_session_set_read_codec(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_digit_stream_new(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, SWIGTYPE_p_p_switch_ivr_digit_stream stream) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_new(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), SWIGTYPE_p_p_switch_ivr_digit_stream.getCPtr(stream));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_unset_read_codec")]
+  public static extern void switch_core_session_unset_read_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_destroy(SWIGTYPE_p_switch_ivr_digit_stream stream) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_destroy(SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_read_codec")]
+  public static extern IntPtr switch_core_session_get_read_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_parser_set_event(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, string digits, SWIGTYPE_p_void data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_set_event(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digits, SWIGTYPE_p_void.getCPtr(data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_effective_read_codec")]
+  public static extern IntPtr switch_core_session_get_effective_read_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_parser_del_event(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, string digits) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_del_event(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digits);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_write_codec")]
+  public static extern int switch_core_session_set_write_codec(HandleRef jarg1, HandleRef jarg2);
 
-  public static SWIGTYPE_p_void switch_ivr_digit_stream_parser_feed(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, SWIGTYPE_p_switch_ivr_digit_stream stream, char digit) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_ivr_digit_stream_parser_feed(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream), digit);
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_write_codec")]
+  public static extern IntPtr switch_core_session_get_write_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_reset(SWIGTYPE_p_switch_ivr_digit_stream stream) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_reset(SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_effective_write_codec")]
+  public static extern IntPtr switch_core_session_get_effective_write_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_digit_stream_parser_set_terminator(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, char digit) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_set_terminator(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digit);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_video_read_codec")]
+  public static extern int switch_core_session_set_video_read_codec(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_menu_init(SWIGTYPE_p_p_switch_ivr_menu new_menu, SWIGTYPE_p_switch_ivr_menu main, string name, string greeting_sound, string short_greeting_sound, string invalid_sound, string exit_sound, string confirm_macro, string confirm_key, int confirm_attempts, int inter_timeout, int digit_len, int timeout, int max_failures, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_init(SWIGTYPE_p_p_switch_ivr_menu.getCPtr(new_menu), SWIGTYPE_p_switch_ivr_menu.getCPtr(main), name, greeting_sound, short_greeting_sound, invalid_sound, exit_sound, confirm_macro, confirm_key, confirm_attempts, inter_timeout, digit_len, timeout, max_failures, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_video_read_codec")]
+  public static extern IntPtr switch_core_session_get_video_read_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_menu_bind_action(SWIGTYPE_p_switch_ivr_menu menu, switch_ivr_action_t ivr_action, string arg, string bind) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_bind_action(SWIGTYPE_p_switch_ivr_menu.getCPtr(menu), (int)ivr_action, arg, bind);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_video_write_codec")]
+  public static extern int switch_core_session_set_video_write_codec(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_menu_bind_function(SWIGTYPE_p_switch_ivr_menu menu, SWIGTYPE_p_switch_ivr_menu_action_function_t function, string arg, string bind) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_bind_function(SWIGTYPE_p_switch_ivr_menu.getCPtr(menu), SWIGTYPE_p_switch_ivr_menu_action_function_t.getCPtr(function), arg, bind);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_video_write_codec")]
+  public static extern IntPtr switch_core_session_get_video_write_codec(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_menu_execute(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_ivr_menu stack, string name, SWIGTYPE_p_void obj) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_execute(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_ivr_menu.getCPtr(stack), name, SWIGTYPE_p_void.getCPtr(obj));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_open_file")]
+  public static extern IntPtr switch_core_db_open_file(string jarg1);
 
-  public static switch_status_t switch_ivr_menu_stack_free(SWIGTYPE_p_switch_ivr_menu stack) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_free(SWIGTYPE_p_switch_ivr_menu.getCPtr(stack));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_persistant_execute")]
+  public static extern int switch_core_db_persistant_execute(HandleRef jarg1, string jarg2, uint jarg3);
 
-  public static switch_status_t switch_ivr_menu_stack_xml_build(SWIGTYPE_p_switch_ivr_menu_xml_ctx xml_menu_ctx, SWIGTYPE_p_p_switch_ivr_menu menu_stack, switch_xml xml_menus, switch_xml xml_menu) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_build(SWIGTYPE_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), SWIGTYPE_p_p_switch_ivr_menu.getCPtr(menu_stack), switch_xml.getCPtr(xml_menus), switch_xml.getCPtr(xml_menu));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_test_reactive")]
+  public static extern void switch_core_db_test_reactive(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  public static switch_status_t switch_ivr_menu_str2action(string action_name, SWIGTYPE_p_switch_ivr_action_t action) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_str2action(action_name, SWIGTYPE_p_switch_ivr_action_t.getCPtr(action));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_get")]
+  public static extern string SWITCH_CORE_DB_get();
 
-  public static switch_status_t switch_ivr_menu_stack_xml_add_custom(SWIGTYPE_p_switch_ivr_menu_xml_ctx xml_menu_ctx, string name, SWIGTYPE_p_switch_ivr_menu_action_function_t function) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_add_custom(SWIGTYPE_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), name, SWIGTYPE_p_switch_ivr_menu_action_function_t.getCPtr(function));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_file_open")]
+  public static extern int switch_core_perform_file_open(string jarg1, string jarg2, int jarg3, HandleRef jarg4, string jarg5, byte jarg6, uint jarg7, uint jarg8, HandleRef jarg9);
 
-  public static switch_status_t switch_ivr_menu_stack_xml_init(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx xml_menu_ctx, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_init(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_read")]
+  public static extern int switch_core_file_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_phrase_macro(SWIGTYPE_p_switch_core_session session, string macro_name, string data, string lang, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_phrase_macro(SWIGTYPE_p_switch_core_session.getCPtr(session), macro_name, data, lang, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_write")]
+  public static extern int switch_core_file_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static void switch_ivr_delay_echo(SWIGTYPE_p_switch_core_session session, uint delay_ms) {
-    freeswitchPINVOKE.switch_ivr_delay_echo(SWIGTYPE_p_switch_core_session.getCPtr(session), delay_ms);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_seek")]
+  public static extern int switch_core_file_seek(HandleRef jarg1, HandleRef jarg2, long jarg3, int jarg4);
 
-  public static switch_status_t switch_ivr_find_bridged_uuid(string uuid, string b_uuid, SWIGTYPE_p_switch_size_t blen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_find_bridged_uuid(uuid, b_uuid, SWIGTYPE_p_switch_size_t.getCPtr(blen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_set_string")]
+  public static extern int switch_core_file_set_string(HandleRef jarg1, int jarg2, string jarg3);
 
-  public static void switch_ivr_intercept_session(SWIGTYPE_p_switch_core_session session, string uuid, switch_bool_t bleg) {
-    freeswitchPINVOKE.switch_ivr_intercept_session(SWIGTYPE_p_switch_core_session.getCPtr(session), uuid, (int)bleg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_get_string")]
+  public static extern int switch_core_file_get_string(HandleRef jarg1, int jarg2, ref string jarg3);
 
-  public static void switch_ivr_park_session(SWIGTYPE_p_switch_core_session session) {
-    freeswitchPINVOKE.switch_ivr_park_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_close")]
+  public static extern int switch_core_file_close(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_wait_for_answer(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_wait_for_answer(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_open")]
+  public static extern int switch_core_speech_open(HandleRef jarg1, string jarg2, string jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7);
 
-  public static switch_status_t switch_ivr_read(SWIGTYPE_p_switch_core_session session, uint min_digits, uint max_digits, string prompt_audio_file, string var_name, string digit_buffer, SWIGTYPE_p_switch_size_t digit_buffer_length, uint timeout, string valid_terminators) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_read(SWIGTYPE_p_switch_core_session.getCPtr(session), min_digits, max_digits, prompt_audio_file, var_name, digit_buffer, SWIGTYPE_p_switch_size_t.getCPtr(digit_buffer_length), timeout, valid_terminators);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_feed_tts")]
+  public static extern int switch_core_speech_feed_tts(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_ivr_bind_dtmf_meta_session(SWIGTYPE_p_switch_core_session session, uint key, uint bind_flags, string app) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_bind_dtmf_meta_session(SWIGTYPE_p_switch_core_session.getCPtr(session), key, bind_flags, app);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_flush_tts")]
+  public static extern void switch_core_speech_flush_tts(HandleRef jarg1);
 
-  public static switch_status_t switch_ivr_unbind_dtmf_meta_session(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unbind_dtmf_meta_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_text_param_tts")]
+  public static extern void switch_core_speech_text_param_tts(HandleRef jarg1, string jarg2, string jarg3);
 
-  public static switch_status_t switch_ivr_soft_hold(SWIGTYPE_p_switch_core_session session, string unhold_key, string moh_a, string moh_b) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_soft_hold(SWIGTYPE_p_switch_core_session.getCPtr(session), unhold_key, moh_a, moh_b);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_numeric_param_tts")]
+  public static extern void switch_core_speech_numeric_param_tts(HandleRef jarg1, string jarg2, int jarg3);
 
-  public static switch_status_t switch_ivr_say(SWIGTYPE_p_switch_core_session session, string tosay, string module_name, string say_type, string say_method, switch_input_args_t args) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_say(SWIGTYPE_p_switch_core_session.getCPtr(session), tosay, module_name, say_type, say_method, switch_input_args_t.getCPtr(args));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_float_param_tts")]
+  public static extern void switch_core_speech_float_param_tts(HandleRef jarg1, string jarg2, double jarg3);
 
-  public static switch_say_method_t switch_ivr_get_say_method_by_name(string name) {
-    switch_say_method_t ret = (switch_say_method_t)freeswitchPINVOKE.switch_ivr_get_say_method_by_name(name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_read_tts")]
+  public static extern int switch_core_speech_read_tts(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5);
 
-  public static switch_say_type_t switch_ivr_get_say_type_by_name(string name) {
-    switch_say_type_t ret = (switch_say_type_t)freeswitchPINVOKE.switch_ivr_get_say_type_by_name(name);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_close")]
+  public static extern int switch_core_speech_close(HandleRef jarg1, HandleRef jarg2);
 
-  public static switch_status_t switch_ivr_set_user(SWIGTYPE_p_switch_core_session session, string data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_set_user(SWIGTYPE_p_switch_core_session.getCPtr(session), data);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_open")]
+  public static extern int switch_core_asr_open(HandleRef jarg1, string jarg2, string jarg3, int jarg4, string jarg5, HandleRef jarg6, HandleRef jarg7);
 
-  public static switch_status_t switch_rtp_add_crypto_key(SWIGTYPE_p_switch_rtp rtp_session, switch_rtp_crypto_direction_t direction, uint index, switch_rtp_crypto_key_type_t type, SWIGTYPE_p_unsigned_char key, SWIGTYPE_p_switch_size_t keylen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_add_crypto_key(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), (int)direction, index, (int)type, SWIGTYPE_p_unsigned_char.getCPtr(key), SWIGTYPE_p_switch_size_t.getCPtr(keylen));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_close")]
+  public static extern int switch_core_asr_close(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_rtp_get_random(SWIGTYPE_p_void buf, uint len) {
-    freeswitchPINVOKE.switch_rtp_get_random(SWIGTYPE_p_void.getCPtr(buf), len);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_feed")]
+  public static extern int switch_core_asr_feed(HandleRef jarg1, HandleRef jarg2, uint jarg3, HandleRef jarg4);
 
-  public static void switch_rtp_init(SWIGTYPE_p_apr_pool_t pool) {
-    freeswitchPINVOKE.switch_rtp_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_check_results")]
+  public static extern int switch_core_asr_check_results(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_rtp_shutdown() {
-    freeswitchPINVOKE.switch_rtp_shutdown();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_get_results")]
+  public static extern int switch_core_asr_get_results(HandleRef jarg1, ref string jarg2, HandleRef jarg3);
 
-  public static ushort switch_rtp_set_start_port(ushort port) {
-    ushort ret = freeswitchPINVOKE.switch_rtp_set_start_port(port);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_load_grammar")]
+  public static extern int switch_core_asr_load_grammar(HandleRef jarg1, string jarg2, string jarg3);
 
-  public static ushort switch_rtp_set_end_port(ushort port) {
-    ushort ret = freeswitchPINVOKE.switch_rtp_set_end_port(port);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_unload_grammar")]
+  public static extern int switch_core_asr_unload_grammar(HandleRef jarg1, string jarg2);
 
-  public static ushort switch_rtp_request_port(string ip) {
-    ushort ret = freeswitchPINVOKE.switch_rtp_request_port(ip);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_pause")]
+  public static extern int switch_core_asr_pause(HandleRef jarg1);
 
-  public static void switch_rtp_release_port(string ip, ushort port) {
-    freeswitchPINVOKE.switch_rtp_release_port(ip, port);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_resume")]
+  public static extern int switch_core_asr_resume(HandleRef jarg1);
 
-  public static switch_status_t switch_rtp_create(SWIGTYPE_p_p_switch_rtp new_rtp_session, byte payload, uint samples_per_interval, uint ms_per_packet, uint flags, string timer_name, ref string err, SWIGTYPE_p_apr_pool_t pool) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_create(SWIGTYPE_p_p_switch_rtp.getCPtr(new_rtp_session), payload, samples_per_interval, ms_per_packet, flags, timer_name, ref err, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_open")]
+  public static extern int switch_core_directory_open(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
 
-  public static SWIGTYPE_p_switch_rtp switch_rtp_new(string rx_host, ushort rx_port, string tx_host, ushort tx_port, byte payload, uint samples_per_interval, uint ms_per_packet, uint flags, string timer_name, ref string err, SWIGTYPE_p_apr_pool_t pool) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_new(rx_host, rx_port, tx_host, tx_port, payload, samples_per_interval, ms_per_packet, flags, timer_name, ref err, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
-    SWIGTYPE_p_switch_rtp ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_rtp(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_query")]
+  public static extern int switch_core_directory_query(HandleRef jarg1, string jarg2, string jarg3);
 
-  public static switch_status_t switch_rtp_set_remote_address(SWIGTYPE_p_switch_rtp rtp_session, string host, ushort port, ref string err) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_set_remote_address(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), host, port, ref err);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_next")]
+  public static extern int switch_core_directory_next(HandleRef jarg1);
 
-  public static string switch_rtp_get_remote_host(SWIGTYPE_p_switch_rtp rtp_session) {
-    string ret = freeswitchPINVOKE.switch_rtp_get_remote_host(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_next_pair")]
+  public static extern int switch_core_directory_next_pair(HandleRef jarg1, ref string jarg2, ref string jarg3);
 
-  public static ushort switch_rtp_get_remote_port(SWIGTYPE_p_switch_rtp rtp_session) {
-    ushort ret = freeswitchPINVOKE.switch_rtp_get_remote_port(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_close")]
+  public static extern int switch_core_directory_close(HandleRef jarg1);
 
-  public static void switch_rtp_set_max_missed_packets(SWIGTYPE_p_switch_rtp rtp_session, uint max) {
-    freeswitchPINVOKE.switch_rtp_set_max_missed_packets(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), max);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_data_channel")]
+  public static extern IntPtr switch_core_data_channel(int jarg1);
 
-  public static switch_status_t switch_rtp_set_local_address(SWIGTYPE_p_switch_rtp rtp_session, string host, ushort port, ref string err) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_set_local_address(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), host, port, ref err);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_ready")]
+  public static extern int switch_core_ready();
 
-  public static void switch_rtp_kill_socket(SWIGTYPE_p_switch_rtp rtp_session) {
-    freeswitchPINVOKE.switch_rtp_kill_socket(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_flags")]
+  public static extern uint switch_core_flags();
 
-  public static void switch_rtp_break(SWIGTYPE_p_switch_rtp rtp_session) {
-    freeswitchPINVOKE.switch_rtp_break(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_management_exec")]
+  public static extern int switch_core_management_exec(string jarg1, int jarg2, string jarg3, HandleRef jarg4);
 
-  public static byte switch_rtp_ready(SWIGTYPE_p_switch_rtp rtp_session) {
-    byte ret = freeswitchPINVOKE.switch_rtp_ready(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_set_high_priority")]
+  public static extern int set_high_priority();
 
-  public static void switch_rtp_destroy(SWIGTYPE_p_p_switch_rtp rtp_session) {
-    freeswitchPINVOKE.switch_rtp_destroy(SWIGTYPE_p_p_switch_rtp.getCPtr(rtp_session));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_change_user_group")]
+  public static extern int change_user_group(string jarg1, string jarg2);
 
-  public static switch_status_t switch_rtp_activate_ice(SWIGTYPE_p_switch_rtp rtp_session, string login, string rlogin) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_ice(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), login, rlogin);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_runtime_loop")]
+  public static extern void switch_core_runtime_loop(int jarg1);
 
-  public static switch_status_t switch_rtp_activate_jitter_buffer(SWIGTYPE_p_switch_rtp rtp_session, uint queue_frames) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_jitter_buffer(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), queue_frames);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_console")]
+  public static extern int switch_core_set_console(string jarg1);
 
-  public static void switch_rtp_set_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
-    freeswitchPINVOKE.switch_rtp_set_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_measure_time")]
+  public static extern void switch_core_measure_time(HandleRef jarg1, HandleRef jarg2);
 
-  public static uint switch_rtp_test_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
-    uint ret = freeswitchPINVOKE.switch_rtp_test_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_uptime")]
+  public static extern IntPtr switch_core_uptime();
 
-  public static void switch_rtp_clear_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
-    freeswitchPINVOKE.switch_rtp_clear_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_ctl")]
+  public static extern int switch_core_session_ctl(int jarg1, HandleRef jarg2);
 
-  public static SWIGTYPE_p_switch_socket_t switch_rtp_get_rtp_socket(SWIGTYPE_p_switch_rtp rtp_session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_get_rtp_socket(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    SWIGTYPE_p_switch_socket_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_socket_t(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_console")]
+  public static extern IntPtr switch_core_get_console();
 
-  public static void switch_rtp_set_default_samples_per_interval(SWIGTYPE_p_switch_rtp rtp_session, ushort samples_per_interval) {
-    freeswitchPINVOKE.switch_rtp_set_default_samples_per_interval(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), samples_per_interval);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_launch_thread")]
+  public static extern void switch_core_launch_thread(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static uint switch_rtp_get_default_samples_per_interval(SWIGTYPE_p_switch_rtp rtp_session) {
-    uint ret = freeswitchPINVOKE.switch_rtp_get_default_samples_per_interval(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_globals")]
+  public static extern void switch_core_set_globals();
 
-  public static void switch_rtp_set_default_payload(SWIGTYPE_p_switch_rtp rtp_session, byte payload) {
-    freeswitchPINVOKE.switch_rtp_set_default_payload(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), payload);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_compare")]
+  public static extern byte switch_core_session_compare(HandleRef jarg1, HandleRef jarg2);
 
-  public static uint switch_rtp_get_default_payload(SWIGTYPE_p_switch_rtp rtp_session) {
-    uint ret = freeswitchPINVOKE.switch_rtp_get_default_payload(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_check_interface")]
+  public static extern byte switch_core_session_check_interface(HandleRef jarg1, HandleRef jarg2);
 
-  public static void switch_rtp_set_invald_handler(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void on_invalid) {
-    freeswitchPINVOKE.switch_rtp_set_invald_handler(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void.getCPtr(on_invalid));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_index")]
+  public static extern IntPtr switch_core_mime_index();
 
-  public static switch_status_t switch_rtp_read(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void data, SWIGTYPE_p_unsigned_long datalen, SWIGTYPE_p_unsigned_char payload_type, SWIGTYPE_p_unsigned_long flags, uint io_flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_read(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_unsigned_long.getCPtr(datalen), SWIGTYPE_p_unsigned_char.getCPtr(payload_type), SWIGTYPE_p_unsigned_long.getCPtr(flags), io_flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_ext2type")]
+  public static extern string switch_core_mime_ext2type(string jarg1);
 
-  public static switch_status_t switch_rtp_queue_rfc2833(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_queue_rfc2833(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_add_type")]
+  public static extern int switch_core_mime_add_type(string jarg1, string jarg2);
 
-  public static switch_status_t switch_rtp_queue_rfc2833_in(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_queue_rfc2833_in(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_create_module_interface")]
+  public static extern IntPtr switch_loadable_module_create_module_interface(HandleRef jarg1, string jarg2);
 
-  public static SWIGTYPE_p_switch_size_t switch_rtp_has_dtmf(SWIGTYPE_p_switch_rtp rtp_session) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_has_dtmf(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_create_interface")]
+  public static extern IntPtr switch_loadable_module_create_interface(HandleRef jarg1, int jarg2);
 
-  public static SWIGTYPE_p_switch_size_t switch_rtp_dequeue_dtmf(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
-    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_dequeue_dtmf(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf)), true);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timestamp_now")]
+  public static extern IntPtr switch_timestamp_now();
 
-  public static switch_status_t switch_rtp_zerocopy_read(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_p_void data, SWIGTYPE_p_unsigned_long datalen, SWIGTYPE_p_unsigned_char payload_type, SWIGTYPE_p_unsigned_long flags, uint io_flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_zerocopy_read(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_p_void.getCPtr(data), SWIGTYPE_p_unsigned_long.getCPtr(datalen), SWIGTYPE_p_unsigned_char.getCPtr(payload_type), SWIGTYPE_p_unsigned_long.getCPtr(flags), io_flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim")]
+  public static extern void switch_core_memory_reclaim();
 
-  public static switch_status_t switch_rtp_zerocopy_read_frame(SWIGTYPE_p_switch_rtp rtp_session, switch_frame frame, uint io_flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_zerocopy_read_frame(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_frame.getCPtr(frame), io_flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_events")]
+  public static extern void switch_core_memory_reclaim_events();
 
-  public static switch_status_t switch_rtp_enable_vad(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_switch_core_session session, switch_codec codec, uint flags) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_enable_vad(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec), flags);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_logger")]
+  public static extern void switch_core_memory_reclaim_logger();
 
-  public static switch_status_t switch_rtp_disable_vad(SWIGTYPE_p_switch_rtp rtp_session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_disable_vad(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_all")]
+  public static extern void switch_core_memory_reclaim_all();
 
-  public static int switch_rtp_write_frame(SWIGTYPE_p_switch_rtp rtp_session, switch_frame frame) {
-    int ret = freeswitchPINVOKE.switch_rtp_write_frame(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_frame.getCPtr(frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_setrlimits")]
+  public static extern void switch_core_setrlimits();
 
-  public static int switch_rtp_write_manual(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void data, uint datalen, byte m, byte payload, uint ts, SWIGTYPE_p_unsigned_long flags) {
-    int ret = freeswitchPINVOKE.switch_rtp_write_manual(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(data), datalen, m, payload, ts, SWIGTYPE_p_unsigned_long.getCPtr(flags));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_time_sync")]
+  public static extern void switch_time_sync();
 
-  public static uint switch_rtp_get_ssrc(SWIGTYPE_p_switch_rtp rtp_session) {
-    uint ret = freeswitchPINVOKE.switch_rtp_get_ssrc(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timestamp")]
+  public static extern IntPtr switch_timestamp(HandleRef jarg1);
 
-  public static void switch_rtp_set_private(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void private_data) {
-    freeswitchPINVOKE.switch_rtp_set_private(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(private_data));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_strftime_tz")]
+  public static extern int switch_strftime_tz(string jarg1, string jarg2, string jarg3, uint jarg4);
 
-  public static void switch_rtp_set_telephony_event(SWIGTYPE_p_switch_rtp rtp_session, byte te) {
-    freeswitchPINVOKE.switch_rtp_set_telephony_event(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), te);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_load_network_lists")]
+  public static extern void switch_load_network_lists(int jarg1);
 
-  public static void switch_rtp_set_cng_pt(SWIGTYPE_p_switch_rtp rtp_session, byte pt) {
-    freeswitchPINVOKE.switch_rtp_set_cng_pt(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), pt);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_check_network_list_ip_token")]
+  public static extern int switch_check_network_list_ip_token(string jarg1, string jarg2, ref string jarg3);
 
-  public static SWIGTYPE_p_void switch_rtp_get_private(SWIGTYPE_p_switch_rtp rtp_session) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_get_private(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
-    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_time_set_monotonic")]
+  public static extern void switch_time_set_monotonic(int jarg1);
 
-  public static switch_status_t switch_rtp_activate_stun_ping(SWIGTYPE_p_switch_rtp rtp_session, string stun_ip, ushort stun_port, uint packet_count, switch_bool_t funny) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_stun_ping(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), stun_ip, stun_port, packet_count, (int)funny);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_max_dtmf_duration")]
+  public static extern uint switch_core_max_dtmf_duration(uint jarg1);
 
-  public static switch_status_t switch_log_init(SWIGTYPE_p_apr_pool_t pool, switch_bool_t colorize) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool), (int)colorize);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_default_dtmf_duration")]
+  public static extern uint switch_core_default_dtmf_duration(uint jarg1);
 
-  public static switch_status_t switch_log_shutdown() {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_shutdown();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_set_complete")]
+  public static extern int switch_console_set_complete(string jarg1);
 
-  public static switch_status_t switch_log_bind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t function, switch_log_level_t level, switch_bool_t is_console) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_bind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t.getCPtr(function), (int)level, (int)is_console);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_set_alias")]
+  public static extern int switch_console_set_alias(string jarg1);
 
-  public static switch_status_t switch_log_unbind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t function) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_unbind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t.getCPtr(function));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_system")]
+  public static extern int switch_system(string jarg1, int jarg2);
 
-  public static string switch_log_level2str(switch_log_level_t level) {
-    string ret = freeswitchPINVOKE.switch_log_level2str((int)level);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CMD_CHUNK_LEN_get")]
+  public static extern int SWITCH_CMD_CHUNK_LEN_get();
 
-  public static switch_log_level_t switch_log_str2level(string str) {
-    switch_log_level_t ret = (switch_log_level_t)freeswitchPINVOKE.switch_log_str2level(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_loop")]
+  public static extern void switch_console_loop();
 
-  public static uint switch_log_str2mask(string str) {
-    uint ret = freeswitchPINVOKE.switch_log_str2mask(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_stream_raw_write")]
+  public static extern int switch_console_stream_raw_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  public static switch_xml switch_xml_parse_str(string s, SWIGTYPE_p_switch_size_t len) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_str(s, SWIGTYPE_p_switch_size_t.getCPtr(len));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SMAX_get")]
+  public static extern int SWITCH_SMAX_get();
 
-  public static switch_xml switch_xml_parse_fd(int fd) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_fd(fd);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SMIN_get")]
+  public static extern int SWITCH_SMIN_get();
 
-  public static switch_xml switch_xml_parse_file(string file) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_file(file);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_moh")]
+  public static extern int switch_is_moh(string jarg1);
 
-  public static switch_xml switch_xml_parse_file_simple(string file) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_file_simple(file);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_b64_encode")]
+  public static extern int switch_b64_encode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static switch_xml switch_xml_parse_fp(SWIGTYPE_p_FILE fp) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_fp(SWIGTYPE_p_FILE.getCPtr(fp));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_b64_decode")]
+  public static extern IntPtr switch_b64_decode(string jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_xml switch_xml_child(switch_xml xml, string name) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_child(switch_xml.getCPtr(xml), name);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_amp_encode")]
+  public static extern string switch_amp_encode(string jarg1, string jarg2, HandleRef jarg3);
 
-  public static switch_xml switch_xml_find_child(switch_xml node, string childname, string attrname, string value) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_find_child(switch_xml.getCPtr(node), childname, attrname, value);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_digit_string")]
+  public static extern int switch_is_digit_string(string jarg1);
 
-  public static string switch_xml_attr(switch_xml xml, string attr) {
-    string ret = freeswitchPINVOKE.switch_xml_attr(switch_xml.getCPtr(xml), attr);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_fd_read_line")]
+  public static extern IntPtr switch_fd_read_line(int jarg1, string jarg2, HandleRef jarg3);
 
-  public static string switch_xml_attr_soft(switch_xml xml, string attr) {
-    string ret = freeswitchPINVOKE.switch_xml_attr_soft(switch_xml.getCPtr(xml), attr);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_find_local_ip")]
+  public static extern int switch_find_local_ip(string jarg1, int jarg2, int jarg3);
 
-  public static switch_xml switch_xml_get(switch_xml xml) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_get(switch_xml.getCPtr(xml));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_get_addr")]
+  public static extern string get_addr(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static string switch_xml_toxml(switch_xml xml, switch_bool_t prn_header) {
-    string ret = freeswitchPINVOKE.switch_xml_toxml(switch_xml.getCPtr(xml), (int)prn_header);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_get_port")]
+  public static extern ushort get_port(HandleRef jarg1);
 
-  public static string switch_xml_toxml_buf(switch_xml xml, string buf, SWIGTYPE_p_switch_size_t buflen, SWIGTYPE_p_switch_size_t offset, switch_bool_t prn_header) {
-    string ret = freeswitchPINVOKE.switch_xml_toxml_buf(switch_xml.getCPtr(xml), buf, SWIGTYPE_p_switch_size_t.getCPtr(buflen), SWIGTYPE_p_switch_size_t.getCPtr(offset), (int)prn_header);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_build_uri")]
+  public static extern int switch_build_uri(string jarg1, HandleRef jarg2, string jarg3, string jarg4, HandleRef jarg5, int jarg6);
 
-  public static void switch_xml_free(switch_xml xml) {
-    freeswitchPINVOKE.switch_xml_free(switch_xml.getCPtr(xml));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_priority_name")]
+  public static extern string switch_priority_name(int jarg1);
 
-  public static void switch_xml_free_in_thread(switch_xml xml, int stacksize) {
-    freeswitchPINVOKE.switch_xml_free_in_thread(switch_xml.getCPtr(xml), stacksize);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rfc2833_to_char")]
+  public static extern char switch_rfc2833_to_char(int jarg1);
 
-  public static string switch_xml_error(switch_xml xml) {
-    string ret = freeswitchPINVOKE.switch_xml_error(switch_xml.getCPtr(xml));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_char_to_rfc2833")]
+  public static extern byte switch_char_to_rfc2833(char jarg1);
 
-  public static switch_xml switch_xml_new(string name) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_new(name);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_clean_string")]
+  public static extern string switch_clean_string(string jarg1);
 
-  public static switch_xml switch_xml_add_child(switch_xml xml, string name, SWIGTYPE_p_switch_size_t off) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_add_child(switch_xml.getCPtr(xml), name, SWIGTYPE_p_switch_size_t.getCPtr(off));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_safe_strdup")]
+  public static extern string switch_safe_strdup(string jarg1);
 
-  public static switch_xml switch_xml_set_txt(switch_xml xml, string txt) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_txt(switch_xml.getCPtr(xml), txt);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_strstr")]
+  public static extern int switch_strstr(string jarg1, string jarg2);
 
-  public static switch_xml switch_xml_set_attr(switch_xml xml, string name, string value) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_attr(switch_xml.getCPtr(xml), name, value);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_str_time")]
+  public static extern IntPtr switch_str_time(string jarg1);
 
-  public static switch_xml switch_xml_set_flag(switch_xml xml, switch_xml_flag_t flag) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_flag(switch_xml.getCPtr(xml), (int)flag);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_separate_string")]
+  public static extern uint switch_separate_string(string jarg1, char jarg2, ref string jarg3, uint jarg4);
 
-  public static switch_xml switch_xml_cut(switch_xml xml) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_cut(switch_xml.getCPtr(xml));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_number")]
+  public static extern int switch_is_number(string jarg1);
 
-  public static switch_xml switch_xml_insert(switch_xml xml, switch_xml dest, SWIGTYPE_p_switch_size_t off) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_insert(switch_xml.getCPtr(xml), switch_xml.getCPtr(dest), SWIGTYPE_p_switch_size_t.getCPtr(off));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_strip_spaces")]
+  public static extern string switch_strip_spaces(string jarg1);
 
-  public static switch_xml switch_xml_open_root(byte reload, ref string err) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_open_root(reload, ref err);
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_separate_paren_args")]
+  public static extern string switch_separate_paren_args(string jarg1);
 
-  public static switch_status_t switch_xml_init(SWIGTYPE_p_apr_pool_t pool, ref string err) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool), ref err);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stristr")]
+  public static extern string switch_stristr(string jarg1, string jarg2);
 
-  public static switch_status_t switch_xml_destroy() {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_destroy();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_lan_addr")]
+  public static extern int switch_is_lan_addr(string jarg1);
 
-  public static switch_xml switch_xml_root() {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_root();
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_replace_char")]
+  public static extern string switch_replace_char(string jarg1, char jarg2, char jarg3, int jarg4);
 
-  public static switch_status_t switch_xml_locate(string section, string tag_name, string key_name, string key_value, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml node, switch_event arg6) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate(section, tag_name, key_name, key_value, SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(node), switch_event.getCPtr(arg6));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ast2regex")]
+  public static extern int switch_ast2regex(string jarg1, string jarg2, uint jarg3);
 
-  public static switch_status_t switch_xml_locate_domain(string domain_name, switch_event arg1, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml domain) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate_domain(domain_name, switch_event.getCPtr(arg1), SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(domain));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_escape_char")]
+  public static extern string switch_escape_char(HandleRef jarg1, string jarg2, string jarg3, char jarg4);
 
-  public static switch_status_t switch_xml_locate_user(string key, string user_name, string domain_name, string ip, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml domain, SWIGTYPE_p_p_switch_xml user, switch_event arg7) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate_user(key, user_name, domain_name, ip, SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(domain), SWIGTYPE_p_p_switch_xml.getCPtr(user), switch_event.getCPtr(arg7));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_socket_waitfor")]
+  public static extern int switch_socket_waitfor(HandleRef jarg1, int jarg2);
 
-  public static switch_xml switch_xml_open_cfg(string file_path, SWIGTYPE_p_p_switch_xml node, switch_event arg2) {
-    IntPtr cPtr = freeswitchPINVOKE.switch_xml_open_cfg(file_path, SWIGTYPE_p_p_switch_xml.getCPtr(node), switch_event.getCPtr(arg2));
-    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_cut_path")]
+  public static extern string switch_cut_path(string jarg1);
 
-  public static switch_status_t switch_xml_bind_search_function(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml function, uint sections, SWIGTYPE_p_void user_data) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_bind_search_function(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml.getCPtr(function), sections, SWIGTYPE_p_void.getCPtr(user_data));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_string_replace")]
+  public static extern string switch_string_replace(string jarg1, string jarg2, string jarg3);
 
-  public static switch_status_t switch_xml_unbind_search_function(SWIGTYPE_p_p_switch_xml_binding binding) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_unbind_search_function(SWIGTYPE_p_p_switch_xml_binding.getCPtr(binding));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_string_match")]
+  public static extern int switch_string_match(string jarg1, uint jarg2, string jarg3, uint jarg4);
 
-  public static switch_status_t switch_xml_unbind_search_function_ptr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml function) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_unbind_search_function_ptr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml.getCPtr(function));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_url_encode")]
+  public static extern uint switch_url_encode(string jarg1, string jarg2, uint jarg3);
 
-  public static uint switch_xml_parse_section_string(string str) {
-    uint ret = freeswitchPINVOKE.switch_xml_parse_section_string(str);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_url_decode")]
+  public static extern string switch_url_decode(string jarg1);
 
-  public static switch_status_t switch_core_event_hook_add_outgoing_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(outgoing_channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_simple_email")]
+  public static extern int switch_simple_email(string jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
 
-  public static switch_status_t switch_core_event_hook_add_receive_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(receive_message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_find_end_paren")]
+  public static extern string switch_find_end_paren(string jarg1, char jarg2, char jarg3);
 
-  public static switch_status_t switch_core_event_hook_add_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(receive_event));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_parse_cidr")]
+  public static extern int switch_parse_cidr(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  public static switch_status_t switch_core_event_hook_add_state_change(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(state_change));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_create")]
+  public static extern int switch_network_list_create(HandleRef jarg1, int jarg2, HandleRef jarg3);
 
-  public static switch_status_t switch_core_event_hook_add_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(read_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_add_cidr_token")]
+  public static extern int switch_network_list_add_cidr_token(HandleRef jarg1, string jarg2, int jarg3, string jarg4);
 
-  public static switch_status_t switch_core_event_hook_add_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(write_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_add_host_mask")]
+  public static extern int switch_network_list_add_host_mask(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  public static switch_status_t switch_core_event_hook_add_video_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_video_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_read_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_validate_ip_token")]
+  public static extern int switch_network_list_validate_ip_token(HandleRef jarg1, uint jarg2, ref string jarg3);
 
-  public static switch_status_t switch_core_event_hook_add_video_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_video_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_write_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_username_set")]
+  public static extern void switch_caller_profile_username_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_add_kill_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(kill_channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_username_get")]
+  public static extern string switch_caller_profile_username_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_add_send_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(send_dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dialplan_set")]
+  public static extern void switch_caller_profile_dialplan_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_add_recv_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(recv_dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dialplan_get")]
+  public static extern string switch_caller_profile_dialplan_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_add_resurrect_session(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_resurrect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(resurrect_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_name_set")]
+  public static extern void switch_caller_profile_caller_id_name_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_outgoing_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(outgoing_channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_name_get")]
+  public static extern string switch_caller_profile_caller_id_name_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_receive_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(receive_message));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_number_set")]
+  public static extern void switch_caller_profile_caller_id_number_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(receive_event));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_number_get")]
+  public static extern string switch_caller_profile_caller_id_number_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_state_change(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(state_change));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_ton_set")]
+  public static extern void switch_caller_profile_caller_ton_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(read_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_ton_get")]
+  public static extern byte switch_caller_profile_caller_ton_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(write_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_numplan_set")]
+  public static extern void switch_caller_profile_caller_numplan_set(HandleRef jarg1, byte jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_video_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_video_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_read_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_numplan_get")]
+  public static extern byte switch_caller_profile_caller_numplan_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_video_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_video_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_write_frame));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_network_addr_set")]
+  public static extern void switch_caller_profile_network_addr_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_kill_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(kill_channel));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_network_addr_get")]
+  public static extern string switch_caller_profile_network_addr_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_send_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(send_dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_set")]
+  public static extern void switch_caller_profile_ani_set(HandleRef jarg1, string jarg2);
 
-  public static switch_status_t switch_core_event_hook_remove_recv_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(recv_dtmf));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_get")]
+  public static extern string switch_caller_profile_ani_get(HandleRef jarg1);
 
-  public static switch_status_t switch_core_event_hook_remove_resurrect_session(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_resurrect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(resurrect_session));
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_ton_set")]
+  public static extern void switch_caller_profile_ani_ton_set(HandleRef jarg1, byte jarg2);
 
-  public static uint switch_scheduler_add_task(SWIGTYPE_p_time_t task_runtime, SWIGTYPE_p_f_p_switch_scheduler_task__void func, string desc, string group, uint cmd_id, SWIGTYPE_p_void cmd_arg, uint flags) {
-    uint ret = freeswitchPINVOKE.switch_scheduler_add_task(SWIGTYPE_p_time_t.getCPtr(task_runtime), SWIGTYPE_p_f_p_switch_scheduler_task__void.getCPtr(func), desc, group, cmd_id, SWIGTYPE_p_void.getCPtr(cmd_arg), flags);
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_ton_get")]
+  public static extern byte switch_caller_profile_ani_ton_get(HandleRef jarg1);
 
-  public static uint switch_scheduler_del_task_id(uint task_id) {
-    uint ret = freeswitchPINVOKE.switch_scheduler_del_task_id(task_id);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_numplan_set")]
+  public static extern void switch_caller_profile_ani_numplan_set(HandleRef jarg1, byte jarg2);
 
-  public static uint switch_scheduler_del_task_group(string group) {
-    uint ret = freeswitchPINVOKE.switch_scheduler_del_task_group(group);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_numplan_get")]
+  public static extern byte switch_caller_profile_ani_numplan_get(HandleRef jarg1);
 
-  public static void switch_scheduler_task_thread_start() {
-    freeswitchPINVOKE.switch_scheduler_task_thread_start();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_aniii_set")]
+  public static extern void switch_caller_profile_aniii_set(HandleRef jarg1, string jarg2);
 
-  public static void switch_scheduler_task_thread_stop() {
-    freeswitchPINVOKE.switch_scheduler_task_thread_stop();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_aniii_get")]
+  public static extern string switch_caller_profile_aniii_get(HandleRef jarg1);
 
-  public static int switch_config_open_file(switch_config cfg, string file_path) {
-    int ret = freeswitchPINVOKE.switch_config_open_file(switch_config.getCPtr(cfg), file_path);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_set")]
+  public static extern void switch_caller_profile_rdnis_set(HandleRef jarg1, string jarg2);
 
-  public static void switch_config_close_file(switch_config cfg) {
-    freeswitchPINVOKE.switch_config_close_file(switch_config.getCPtr(cfg));
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_get")]
+  public static extern string switch_caller_profile_rdnis_get(HandleRef jarg1);
 
-  public static int switch_config_next_pair(switch_config cfg, ref string var, ref string val) {
-    int ret = freeswitchPINVOKE.switch_config_next_pair(switch_config.getCPtr(cfg), ref var, ref val);
-    return ret;
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_ton_set")]
+  public static extern void switch_caller_profile_rdnis_ton_set(HandleRef jarg1, byte jarg2);
 
-  public static void consoleLog(string level_str, string msg) {
-    freeswitchPINVOKE.consoleLog(level_str, msg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_ton_get")]
+  public static extern byte switch_caller_profile_rdnis_ton_get(HandleRef jarg1);
 
-  public static void consoleCleanLog(string msg) {
-    freeswitchPINVOKE.consoleCleanLog(msg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_numplan_set")]
+  public static extern void switch_caller_profile_rdnis_numplan_set(HandleRef jarg1, byte jarg2);
 
-  public static void console_log(string level_str, string msg) {
-    freeswitchPINVOKE.console_log(level_str, msg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_numplan_get")]
+  public static extern byte switch_caller_profile_rdnis_numplan_get(HandleRef jarg1);
 
-  public static void console_clean_log(string msg) {
-    freeswitchPINVOKE.console_clean_log(msg);
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_set")]
+  public static extern void switch_caller_profile_destination_number_set(HandleRef jarg1, string jarg2);
 
-  public static void bridge(CoreSession session_a, CoreSession session_b) {
-    freeswitchPINVOKE.bridge(CoreSession.getCPtr(session_a), CoreSession.getCPtr(session_b));
-    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-  }
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_get")]
+  public static extern string switch_caller_profile_destination_number_get(HandleRef jarg1);
 
-  public static switch_status_t hanguphook(SWIGTYPE_p_switch_core_session session) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.hanguphook(SWIGTYPE_p_switch_core_session.getCPtr(session));
-    return ret;
-  }
-
-  public static switch_status_t dtmf_callback(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void input, switch_input_type_t itype, SWIGTYPE_p_void buf, uint buflen) {
-    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.dtmf_callback(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(input), (int)itype, SWIGTYPE_p_void.getCPtr(buf), buflen);
-    return ret;
-  }
-
-  public static readonly string FREESWITCH_PEN = freeswitchPINVOKE.FREESWITCH_PEN_get();
-  public static readonly string FREESWITCH_OID_PREFIX = freeswitchPINVOKE.FREESWITCH_OID_PREFIX_get();
-  public static readonly string FREESWITCH_ITAD = freeswitchPINVOKE.FREESWITCH_ITAD_get();
-  public static readonly int __EXTENSIONS__ = freeswitchPINVOKE.__EXTENSIONS___get();
-  public static readonly int __BSD_VISIBLE = freeswitchPINVOKE.__BSD_VISIBLE_get();
-  public static readonly string SWITCH_BLANK_STRING = freeswitchPINVOKE.SWITCH_BLANK_STRING_get();
-  public static readonly string SWITCH_SEQ_ESC = freeswitchPINVOKE.SWITCH_SEQ_ESC_get();
-  public static readonly char SWITCH_SEQ_HOME_CHAR = freeswitchPINVOKE.SWITCH_SEQ_HOME_CHAR_get();
-  public static readonly string SWITCH_SEQ_HOME_CHAR_STR = freeswitchPINVOKE.SWITCH_SEQ_HOME_CHAR_STR_get();
-  public static readonly char SWITCH_SEQ_CLEARLINE_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_CHAR_get();
-  public static readonly string SWITCH_SEQ_CLEARLINE_CHAR_STR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_CHAR_STR_get();
-  public static readonly string SWITCH_SEQ_CLEARLINEEND_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINEEND_CHAR_get();
-  public static readonly char SWITCH_SEQ_CLEARSCR_CHAR0 = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR0_get();
-  public static readonly char SWITCH_SEQ_CLEARSCR_CHAR1 = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR1_get();
-  public static readonly string SWITCH_SEQ_CLEARSCR_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR_get();
-  public static readonly string SWITCH_SEQ_AND_COLOR = freeswitchPINVOKE.SWITCH_SEQ_AND_COLOR_get();
-  public static readonly string SWITCH_SEQ_END_COLOR = freeswitchPINVOKE.SWITCH_SEQ_END_COLOR_get();
-  public static readonly string SWITCH_SEQ_F_BLACK = freeswitchPINVOKE.SWITCH_SEQ_F_BLACK_get();
-  public static readonly string SWITCH_SEQ_F_RED = freeswitchPINVOKE.SWITCH_SEQ_F_RED_get();
-  public static readonly string SWITCH_SEQ_F_GREEN = freeswitchPINVOKE.SWITCH_SEQ_F_GREEN_get();
-  public static readonly string SWITCH_SEQ_F_YELLOW = freeswitchPINVOKE.SWITCH_SEQ_F_YELLOW_get();
-  public static readonly string SWITCH_SEQ_F_BLUE = freeswitchPINVOKE.SWITCH_SEQ_F_BLUE_get();
-  public static readonly string SWITCH_SEQ_F_MAGEN = freeswitchPINVOKE.SWITCH_SEQ_F_MAGEN_get();
-  public static readonly string SWITCH_SEQ_F_CYAN = freeswitchPINVOKE.SWITCH_SEQ_F_CYAN_get();
-  public static readonly string SWITCH_SEQ_F_WHITE = freeswitchPINVOKE.SWITCH_SEQ_F_WHITE_get();
-  public static readonly string SWITCH_SEQ_B_BLACK = freeswitchPINVOKE.SWITCH_SEQ_B_BLACK_get();
-  public static readonly string SWITCH_SEQ_B_RED = freeswitchPINVOKE.SWITCH_SEQ_B_RED_get();
-  public static readonly string SWITCH_SEQ_B_GREEN = freeswitchPINVOKE.SWITCH_SEQ_B_GREEN_get();
-  public static readonly string SWITCH_SEQ_B_YELLOW = freeswitchPINVOKE.SWITCH_SEQ_B_YELLOW_get();
-  public static readonly string SWITCH_SEQ_B_BLUE = freeswitchPINVOKE.SWITCH_SEQ_B_BLUE_get();
-  public static readonly string SWITCH_SEQ_B_MAGEN = freeswitchPINVOKE.SWITCH_SEQ_B_MAGEN_get();
-  public static readonly string SWITCH_SEQ_B_CYAN = freeswitchPINVOKE.SWITCH_SEQ_B_CYAN_get();
-  public static readonly string SWITCH_SEQ_B_WHITE = freeswitchPINVOKE.SWITCH_SEQ_B_WHITE_get();
-  public static readonly string SWITCH_SEQ_FBLACK = freeswitchPINVOKE.SWITCH_SEQ_FBLACK_get();
-  public static readonly string SWITCH_SEQ_FRED = freeswitchPINVOKE.SWITCH_SEQ_FRED_get();
-  public static readonly string SWITCH_SEQ_FGREEN = freeswitchPINVOKE.SWITCH_SEQ_FGREEN_get();
-  public static readonly string SWITCH_SEQ_FYELLOW = freeswitchPINVOKE.SWITCH_SEQ_FYELLOW_get();
-  public static readonly string SWITCH_SEQ_FBLUE = freeswitchPINVOKE.SWITCH_SEQ_FBLUE_get();
-  public static readonly string SWITCH_SEQ_FMAGEN = freeswitchPINVOKE.SWITCH_SEQ_FMAGEN_get();
-  public static readonly string SWITCH_SEQ_FCYAN = freeswitchPINVOKE.SWITCH_SEQ_FCYAN_get();
-  public static readonly string SWITCH_SEQ_FWHITE = freeswitchPINVOKE.SWITCH_SEQ_FWHITE_get();
-  public static readonly string SWITCH_SEQ_BBLACK = freeswitchPINVOKE.SWITCH_SEQ_BBLACK_get();
-  public static readonly string SWITCH_SEQ_BRED = freeswitchPINVOKE.SWITCH_SEQ_BRED_get();
-  public static readonly string SWITCH_SEQ_BGREEN = freeswitchPINVOKE.SWITCH_SEQ_BGREEN_get();
-  public static readonly string SWITCH_SEQ_BYELLOW = freeswitchPINVOKE.SWITCH_SEQ_BYELLOW_get();
-  public static readonly string SWITCH_SEQ_BBLUE = freeswitchPINVOKE.SWITCH_SEQ_BBLUE_get();
-  public static readonly string SWITCH_SEQ_BMAGEN = freeswitchPINVOKE.SWITCH_SEQ_BMAGEN_get();
-  public static readonly string SWITCH_SEQ_BCYAN = freeswitchPINVOKE.SWITCH_SEQ_BCYAN_get();
-  public static readonly string SWITCH_SEQ_BWHITE = freeswitchPINVOKE.SWITCH_SEQ_BWHITE_get();
-  public static readonly string SWITCH_SEQ_HOME = freeswitchPINVOKE.SWITCH_SEQ_HOME_get();
-  public static readonly string SWITCH_SEQ_CLEARLINE = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_get();
-  public static readonly string SWITCH_SEQ_CLEARLINEEND = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINEEND_get();
-  public static readonly string SWITCH_SEQ_CLEARSCR = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_get();
-  public static readonly int SWITCH_DEFAULT_DTMF_DURATION = freeswitchPINVOKE.SWITCH_DEFAULT_DTMF_DURATION_get();
-  public static readonly int SWITCH_MAX_DTMF_DURATION = freeswitchPINVOKE.SWITCH_MAX_DTMF_DURATION_get();
-  public static readonly string SWITCH_PATH_SEPARATOR = freeswitchPINVOKE.SWITCH_PATH_SEPARATOR_get();
-  public static readonly string SWITCH_URL_SEPARATOR = freeswitchPINVOKE.SWITCH_URL_SEPARATOR_get();
-  public static readonly string SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get();
-  public static readonly string SWITCH_READ_RESULT_VARIABLE = freeswitchPINVOKE.SWITCH_READ_RESULT_VARIABLE_get();
-  public static readonly string SWITCH_COPY_XML_CDR_VARIABLE = freeswitchPINVOKE.SWITCH_COPY_XML_CDR_VARIABLE_get();
-  public static readonly string SWITCH_CURRENT_APPLICATION_VARIABLE = freeswitchPINVOKE.SWITCH_CURRENT_APPLICATION_VARIABLE_get();
-  public static readonly string SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE = freeswitchPINVOKE.SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get();
-  public static readonly string SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get();
-  public static readonly string SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get();
-  public static readonly string SWITCH_CALL_TIMEOUT_VARIABLE = freeswitchPINVOKE.SWITCH_CALL_TIMEOUT_VARIABLE_get();
-  public static readonly string SWITCH_HOLDING_UUID_VARIABLE = freeswitchPINVOKE.SWITCH_HOLDING_UUID_VARIABLE_get();
-  public static readonly string SWITCH_API_BRIDGE_END_VARIABLE = freeswitchPINVOKE.SWITCH_API_BRIDGE_END_VARIABLE_get();
-  public static readonly string SWITCH_API_HANGUP_HOOK_VARIABLE = freeswitchPINVOKE.SWITCH_API_HANGUP_HOOK_VARIABLE_get();
-  public static readonly string SWITCH_PROCESS_CDR_VARIABLE = freeswitchPINVOKE.SWITCH_PROCESS_CDR_VARIABLE_get();
-  public static readonly string SWITCH_BRIDGE_CHANNEL_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_CHANNEL_VARIABLE_get();
-  public static readonly string SWITCH_CHANNEL_NAME_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_NAME_VARIABLE_get();
-  public static readonly string SWITCH_BRIDGE_UUID_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_UUID_VARIABLE_get();
-  public static readonly string SWITCH_CONTINUE_ON_FAILURE_VARIABLE = freeswitchPINVOKE.SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get();
-  public static readonly string SWITCH_PLAYBACK_TERMINATORS_VARIABLE = freeswitchPINVOKE.SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get();
-  public static readonly string SWITCH_CACHE_SPEECH_HANDLES_VARIABLE = freeswitchPINVOKE.SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get();
-  public static readonly string SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME = freeswitchPINVOKE.SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get();
-  public static readonly string SWITCH_BYPASS_MEDIA_VARIABLE = freeswitchPINVOKE.SWITCH_BYPASS_MEDIA_VARIABLE_get();
-  public static readonly string SWITCH_PROXY_MEDIA_VARIABLE = freeswitchPINVOKE.SWITCH_PROXY_MEDIA_VARIABLE_get();
-  public static readonly string SWITCH_ENDPOINT_DISPOSITION_VARIABLE = freeswitchPINVOKE.SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get();
-  public static readonly string SWITCH_HOLD_MUSIC_VARIABLE = freeswitchPINVOKE.SWITCH_HOLD_MUSIC_VARIABLE_get();
-  public static readonly string SWITCH_EXPORT_VARS_VARIABLE = freeswitchPINVOKE.SWITCH_EXPORT_VARS_VARIABLE_get();
-  public static readonly string SWITCH_R_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_R_SDP_VARIABLE_get();
-  public static readonly string SWITCH_L_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_L_SDP_VARIABLE_get();
-  public static readonly string SWITCH_B_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_B_SDP_VARIABLE_get();
-  public static readonly string SWITCH_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_VARIABLE_get();
-  public static readonly string SWITCH_SIGNAL_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_SIGNAL_BRIDGE_VARIABLE_get();
-  public static readonly string SWITCH_SIGNAL_BOND_VARIABLE = freeswitchPINVOKE.SWITCH_SIGNAL_BOND_VARIABLE_get();
-  public static readonly string SWITCH_ORIGINATOR_VARIABLE = freeswitchPINVOKE.SWITCH_ORIGINATOR_VARIABLE_get();
-  public static readonly string SWITCH_ORIGINATOR_CODEC_VARIABLE = freeswitchPINVOKE.SWITCH_ORIGINATOR_CODEC_VARIABLE_get();
-  public static readonly string SWITCH_LOCAL_MEDIA_IP_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_MEDIA_IP_VARIABLE_get();
-  public static readonly string SWITCH_LOCAL_MEDIA_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get();
-  public static readonly string SWITCH_REMOTE_MEDIA_IP_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_MEDIA_IP_VARIABLE_get();
-  public static readonly string SWITCH_REMOTE_MEDIA_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get();
-  public static readonly string SWITCH_REMOTE_VIDEO_IP_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_VIDEO_IP_VARIABLE_get();
-  public static readonly string SWITCH_REMOTE_VIDEO_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get();
-  public static readonly string SWITCH_LOCAL_VIDEO_IP_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_VIDEO_IP_VARIABLE_get();
-  public static readonly string SWITCH_LOCAL_VIDEO_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get();
-  public static readonly string SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get();
-  public static readonly string SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE = freeswitchPINVOKE.SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get();
-  public static readonly string SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE = freeswitchPINVOKE.SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get();
-  public static readonly string SWITCH_MAX_FORWARDS_VARIABLE = freeswitchPINVOKE.SWITCH_MAX_FORWARDS_VARIABLE_get();
-  public static readonly string SWITCH_DISABLE_APP_LOG_VARIABLE = freeswitchPINVOKE.SWITCH_DISABLE_APP_LOG_VARIABLE_get();
-  public static readonly string SWITCH_SPEECH_KEY = freeswitchPINVOKE.SWITCH_SPEECH_KEY_get();
-  public static readonly string SWITCH_UUID_BRIDGE = freeswitchPINVOKE.SWITCH_UUID_BRIDGE_get();
-  public static readonly int SWITCH_BITS_PER_BYTE = freeswitchPINVOKE.SWITCH_BITS_PER_BYTE_get();
-  public static readonly int SWITCH_MAX_STACKS = freeswitchPINVOKE.SWITCH_MAX_STACKS_get();
-  public static readonly int SWITCH_THREAD_STACKSIZE = freeswitchPINVOKE.SWITCH_THREAD_STACKSIZE_get();
-  public static readonly int SWITCH_MAX_INTERVAL = freeswitchPINVOKE.SWITCH_MAX_INTERVAL_get();
-  public static readonly int SWITCH_INTERVAL_PAD = freeswitchPINVOKE.SWITCH_INTERVAL_PAD_get();
-  public static readonly int SWITCH_MAX_SAMPLE_LEN = freeswitchPINVOKE.SWITCH_MAX_SAMPLE_LEN_get();
-  public static readonly int SWITCH_BYTES_PER_SAMPLE = freeswitchPINVOKE.SWITCH_BYTES_PER_SAMPLE_get();
-  public static readonly int SWITCH_RECOMMENDED_BUFFER_SIZE = freeswitchPINVOKE.SWITCH_RECOMMENDED_BUFFER_SIZE_get();
-  public static readonly int SWITCH_MAX_CODECS = freeswitchPINVOKE.SWITCH_MAX_CODECS_get();
-  public static readonly int SWITCH_MAX_STATE_HANDLERS = freeswitchPINVOKE.SWITCH_MAX_STATE_HANDLERS_get();
-  public static readonly int SWITCH_CORE_QUEUE_LEN = freeswitchPINVOKE.SWITCH_CORE_QUEUE_LEN_get();
-  public static readonly int SWITCH_MAX_MANAGEMENT_BUFFER_LEN = freeswitchPINVOKE.SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get();
-  public static readonly int SWITCH_RTP_CNG_PAYLOAD = freeswitchPINVOKE.SWITCH_RTP_CNG_PAYLOAD_get();
-  public static readonly int SWITCH_API_VERSION = freeswitchPINVOKE.SWITCH_API_VERSION_get();
-  public static readonly int SWITCH_CORE_DB_OK = freeswitchPINVOKE.SWITCH_CORE_DB_OK_get();
-  public static readonly int SWITCH_CORE_DB_ERROR = freeswitchPINVOKE.SWITCH_CORE_DB_ERROR_get();
-  public static readonly int SWITCH_CORE_DB_INTERNAL = freeswitchPINVOKE.SWITCH_CORE_DB_INTERNAL_get();
-  public static readonly int SWITCH_CORE_DB_PERM = freeswitchPINVOKE.SWITCH_CORE_DB_PERM_get();
-  public static readonly int SWITCH_CORE_DB_ABORT = freeswitchPINVOKE.SWITCH_CORE_DB_ABORT_get();
-  public static readonly int SWITCH_CORE_DB_BUSY = freeswitchPINVOKE.SWITCH_CORE_DB_BUSY_get();
-  public static readonly int SWITCH_CORE_DB_LOCKED = freeswitchPINVOKE.SWITCH_CORE_DB_LOCKED_get();
-  public static readonly int SWITCH_CORE_DB_NOMEM = freeswitchPINVOKE.SWITCH_CORE_DB_NOMEM_get();
-  public static readonly int SWITCH_CORE_DB_READONLY = freeswitchPINVOKE.SWITCH_CORE_DB_READONLY_get();
-  public static readonly int SWITCH_CORE_DB_INTERRUPT = freeswitchPINVOKE.SWITCH_CORE_DB_INTERRUPT_get();
-  public static readonly int SWITCH_CORE_DB_IOERR = freeswitchPINVOKE.SWITCH_CORE_DB_IOERR_get();
-  public static readonly int SWITCH_CORE_DB_CORRUPT = freeswitchPINVOKE.SWITCH_CORE_DB_CORRUPT_get();
-  public static readonly int SWITCH_CORE_DB_NOTFOUND = freeswitchPINVOKE.SWITCH_CORE_DB_NOTFOUND_get();
-  public static readonly int SWITCH_CORE_DB_FULL = freeswitchPINVOKE.SWITCH_CORE_DB_FULL_get();
-  public static readonly int SWITCH_CORE_DB_CANTOPEN = freeswitchPINVOKE.SWITCH_CORE_DB_CANTOPEN_get();
-  public static readonly int SWITCH_CORE_DB_PROTOCOL = freeswitchPINVOKE.SWITCH_CORE_DB_PROTOCOL_get();
-  public static readonly int SWITCH_CORE_DB_EMPTY = freeswitchPINVOKE.SWITCH_CORE_DB_EMPTY_get();
-  public static readonly int SWITCH_CORE_DB_SCHEMA = freeswitchPINVOKE.SWITCH_CORE_DB_SCHEMA_get();
-  public static readonly int SWITCH_CORE_DB_TOOBIG = freeswitchPINVOKE.SWITCH_CORE_DB_TOOBIG_get();
-  public static readonly int SWITCH_CORE_DB_CONSTRAINT = freeswitchPINVOKE.SWITCH_CORE_DB_CONSTRAINT_get();
-  public static readonly int SWITCH_CORE_DB_MISMATCH = freeswitchPINVOKE.SWITCH_CORE_DB_MISMATCH_get();
-  public static readonly int SWITCH_CORE_DB_MISUSE = freeswitchPINVOKE.SWITCH_CORE_DB_MISUSE_get();
-  public static readonly int SWITCH_CORE_DB_NOLFS = freeswitchPINVOKE.SWITCH_CORE_DB_NOLFS_get();
-  public static readonly int SWITCH_CORE_DB_AUTH = freeswitchPINVOKE.SWITCH_CORE_DB_AUTH_get();
-  public static readonly int SWITCH_CORE_DB_FORMAT = freeswitchPINVOKE.SWITCH_CORE_DB_FORMAT_get();
-  public static readonly int SWITCH_CORE_DB_RANGE = freeswitchPINVOKE.SWITCH_CORE_DB_RANGE_get();
-  public static readonly int SWITCH_CORE_DB_NOTADB = freeswitchPINVOKE.SWITCH_CORE_DB_NOTADB_get();
-  public static readonly int SWITCH_CORE_DB_ROW = freeswitchPINVOKE.SWITCH_CORE_DB_ROW_get();
-  public static readonly int SWITCH_CORE_DB_DONE = freeswitchPINVOKE.SWITCH_CORE_DB_DONE_get();
-  public static readonly int SWITCH_MAX_CORE_THREAD_SESSION_OBJS = freeswitchPINVOKE.SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get();
-  public static readonly int SWITCH_MAX_STREAMS = freeswitchPINVOKE.SWITCH_MAX_STREAMS_get();
-  public static readonly string SWITCH_CORE_DB = freeswitchPINVOKE.SWITCH_CORE_DB_get();
-  public static readonly int SWITCH_CMD_CHUNK_LEN = freeswitchPINVOKE.SWITCH_CMD_CHUNK_LEN_get();
-  public static readonly int SWITCH_SMAX = freeswitchPINVOKE.SWITCH_SMAX_get();
-  public static readonly int SWITCH_SMIN = freeswitchPINVOKE.SWITCH_SMIN_get();
-  public static readonly int SWITCH_RTP_MAX_BUF_LEN = freeswitchPINVOKE.SWITCH_RTP_MAX_BUF_LEN_get();
-  public static readonly int SWITCH_RTP_MAX_CRYPTO_LEN = freeswitchPINVOKE.SWITCH_RTP_MAX_CRYPTO_LEN_get();
-  public static readonly int SWITCH_RTP_KEY_LEN = freeswitchPINVOKE.SWITCH_RTP_KEY_LEN_get();
-  public static readonly string SWITCH_RTP_CRYPTO_KEY_32 = freeswitchPINVOKE.SWITCH_RTP_CRYPTO_KEY_32_get();
-  public static readonly string SWITCH_RTP_CRYPTO_KEY_80 = freeswitchPINVOKE.SWITCH_RTP_CRYPTO_KEY_80_get();
-  public static readonly int SWITCH_XML_BUFSIZE = freeswitchPINVOKE.SWITCH_XML_BUFSIZE_get();
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-class freeswitchPINVOKE {
-
-  protected class SWIGExceptionHelper {
-
-    public delegate void ExceptionDelegate(string message);
-    public delegate void ExceptionArgumentDelegate(string message, string paramName);
-
-    static ExceptionDelegate applicationDelegate = new ExceptionDelegate(SetPendingApplicationException);
-    static ExceptionDelegate arithmeticDelegate = new ExceptionDelegate(SetPendingArithmeticException);
-    static ExceptionDelegate divideByZeroDelegate = new ExceptionDelegate(SetPendingDivideByZeroException);
-    static ExceptionDelegate indexOutOfRangeDelegate = new ExceptionDelegate(SetPendingIndexOutOfRangeException);
-    static ExceptionDelegate invalidCastDelegate = new ExceptionDelegate(SetPendingInvalidCastException);
-    static ExceptionDelegate invalidOperationDelegate = new ExceptionDelegate(SetPendingInvalidOperationException);
-    static ExceptionDelegate ioDelegate = new ExceptionDelegate(SetPendingIOException);
-    static ExceptionDelegate nullReferenceDelegate = new ExceptionDelegate(SetPendingNullReferenceException);
-    static ExceptionDelegate outOfMemoryDelegate = new ExceptionDelegate(SetPendingOutOfMemoryException);
-    static ExceptionDelegate overflowDelegate = new ExceptionDelegate(SetPendingOverflowException);
-    static ExceptionDelegate systemDelegate = new ExceptionDelegate(SetPendingSystemException);
-
-    static ExceptionArgumentDelegate argumentDelegate = new ExceptionArgumentDelegate(SetPendingArgumentException);
-    static ExceptionArgumentDelegate argumentNullDelegate = new ExceptionArgumentDelegate(SetPendingArgumentNullException);
-    static ExceptionArgumentDelegate argumentOutOfRangeDelegate = new ExceptionArgumentDelegate(SetPendingArgumentOutOfRangeException);
-
-    [DllImport("mod_managed", EntryPoint="SWIGRegisterExceptionCallbacks_freeswitch")]
-    public static extern void SWIGRegisterExceptionCallbacks_freeswitch(
-                                ExceptionDelegate applicationDelegate,
-                                ExceptionDelegate arithmeticDelegate,
-                                ExceptionDelegate divideByZeroDelegate, 
-                                ExceptionDelegate indexOutOfRangeDelegate, 
-                                ExceptionDelegate invalidCastDelegate,
-                                ExceptionDelegate invalidOperationDelegate,
-                                ExceptionDelegate ioDelegate,
-                                ExceptionDelegate nullReferenceDelegate,
-                                ExceptionDelegate outOfMemoryDelegate, 
-                                ExceptionDelegate overflowDelegate, 
-                                ExceptionDelegate systemExceptionDelegate);
-
-    [DllImport("mod_managed", EntryPoint="SWIGRegisterExceptionArgumentCallbacks_freeswitch")]
-    public static extern void SWIGRegisterExceptionCallbacksArgument_freeswitch(
-                                ExceptionArgumentDelegate argumentDelegate,
-                                ExceptionArgumentDelegate argumentNullDelegate,
-                                ExceptionArgumentDelegate argumentOutOfRangeDelegate);
-
-    static void SetPendingApplicationException(string message) {
-      SWIGPendingException.Set(new System.ApplicationException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingArithmeticException(string message) {
-      SWIGPendingException.Set(new System.ArithmeticException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingDivideByZeroException(string message) {
-      SWIGPendingException.Set(new System.DivideByZeroException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingIndexOutOfRangeException(string message) {
-      SWIGPendingException.Set(new System.IndexOutOfRangeException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingInvalidCastException(string message) {
-      SWIGPendingException.Set(new System.InvalidCastException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingInvalidOperationException(string message) {
-      SWIGPendingException.Set(new System.InvalidOperationException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingIOException(string message) {
-      SWIGPendingException.Set(new System.IO.IOException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingNullReferenceException(string message) {
-      SWIGPendingException.Set(new System.NullReferenceException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingOutOfMemoryException(string message) {
-      SWIGPendingException.Set(new System.OutOfMemoryException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingOverflowException(string message) {
-      SWIGPendingException.Set(new System.OverflowException(message, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingSystemException(string message) {
-      SWIGPendingException.Set(new System.SystemException(message, SWIGPendingException.Retrieve()));
-    }
-
-    static void SetPendingArgumentException(string message, string paramName) {
-      SWIGPendingException.Set(new System.ArgumentException(message, paramName, SWIGPendingException.Retrieve()));
-    }
-    static void SetPendingArgumentNullException(string message, string paramName) {
-      Exception e = SWIGPendingException.Retrieve();
-      if (e != null) message = message + " Inner Exception: " + e.Message;
-      SWIGPendingException.Set(new System.ArgumentNullException(paramName, message));
-    }
-    static void SetPendingArgumentOutOfRangeException(string message, string paramName) {
-      Exception e = SWIGPendingException.Retrieve();
-      if (e != null) message = message + " Inner Exception: " + e.Message;
-      SWIGPendingException.Set(new System.ArgumentOutOfRangeException(paramName, message));
-    }
-
-    static SWIGExceptionHelper() {
-      SWIGRegisterExceptionCallbacks_freeswitch(
-                                applicationDelegate,
-                                arithmeticDelegate,
-                                divideByZeroDelegate,
-                                indexOutOfRangeDelegate,
-                                invalidCastDelegate,
-                                invalidOperationDelegate,
-                                ioDelegate,
-                                nullReferenceDelegate,
-                                outOfMemoryDelegate,
-                                overflowDelegate,
-                                systemDelegate);
-
-      SWIGRegisterExceptionCallbacksArgument_freeswitch(
-                                argumentDelegate,
-                                argumentNullDelegate,
-                                argumentOutOfRangeDelegate);
-    }
-  }
-
-  protected static SWIGExceptionHelper swigExceptionHelper = new SWIGExceptionHelper();
-
-  public class SWIGPendingException {
-    [ThreadStatic]
-    private static Exception pendingException = null;
-    private static int numExceptionsPending = 0;
-
-    public static bool Pending {
-      get {
-        bool pending = false;
-        if (numExceptionsPending > 0)
-          if (pendingException != null)
-            pending = true;
-        return pending;
-      } 
-    }
-
-    public static void Set(Exception e) {
-      if (pendingException != null)
-        throw new ApplicationException("FATAL: An earlier pending exception from unmanaged code was missed and thus not thrown (" + pendingException.ToString() + ")", e);
-      pendingException = e;
-      lock(typeof(freeswitchPINVOKE)) {
-        numExceptionsPending++;
-      }
-    }
-
-    public static Exception Retrieve() {
-      Exception e = null;
-      if (numExceptionsPending > 0) {
-        if (pendingException != null) {
-          e = pendingException;
-          pendingException = null;
-          lock(typeof(freeswitchPINVOKE)) {
-            numExceptionsPending--;
-          }
-        }
-      }
-      return e;
-    }
-  }
-
-
-  protected class SWIGStringHelper {
-
-    public delegate string SWIGStringDelegate(string message);
-    static SWIGStringDelegate stringDelegate = new SWIGStringDelegate(CreateString);
-
-    [DllImport("mod_managed", EntryPoint="SWIGRegisterStringCallback_freeswitch")]
-    public static extern void SWIGRegisterStringCallback_freeswitch(SWIGStringDelegate stringDelegate);
-
-    static string CreateString(string cString) {
-      return cString;
-    }
-
-    static SWIGStringHelper() {
-      SWIGRegisterStringCallback_freeswitch(stringDelegate);
-    }
-  }
-
-  static protected SWIGStringHelper swigStringHelper = new SWIGStringHelper();
-
-
-  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_PEN_get")]
-  public static extern string FREESWITCH_PEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_OID_PREFIX_get")]
-  public static extern string FREESWITCH_OID_PREFIX_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_FREESWITCH_ITAD_get")]
-  public static extern string FREESWITCH_ITAD_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp___EXTENSIONS___get")]
-  public static extern int __EXTENSIONS___get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp___BSD_VISIBLE_get")]
-  public static extern int __BSD_VISIBLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BLANK_STRING_get")]
-  public static extern string SWITCH_BLANK_STRING_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_ESC_get")]
-  public static extern string SWITCH_SEQ_ESC_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_CHAR_get")]
-  public static extern char SWITCH_SEQ_HOME_CHAR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_CHAR_STR_get")]
-  public static extern string SWITCH_SEQ_HOME_CHAR_STR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_CHAR_get")]
-  public static extern char SWITCH_SEQ_CLEARLINE_CHAR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_CHAR_STR_get")]
-  public static extern string SWITCH_SEQ_CLEARLINE_CHAR_STR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINEEND_CHAR_get")]
-  public static extern string SWITCH_SEQ_CLEARLINEEND_CHAR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR0_get")]
-  public static extern char SWITCH_SEQ_CLEARSCR_CHAR0_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR1_get")]
-  public static extern char SWITCH_SEQ_CLEARSCR_CHAR1_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_CHAR_get")]
-  public static extern string SWITCH_SEQ_CLEARSCR_CHAR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_AND_COLOR_get")]
-  public static extern string SWITCH_SEQ_AND_COLOR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_END_COLOR_get")]
-  public static extern string SWITCH_SEQ_END_COLOR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_BLACK_get")]
-  public static extern string SWITCH_SEQ_F_BLACK_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_RED_get")]
-  public static extern string SWITCH_SEQ_F_RED_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_GREEN_get")]
-  public static extern string SWITCH_SEQ_F_GREEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_YELLOW_get")]
-  public static extern string SWITCH_SEQ_F_YELLOW_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_BLUE_get")]
-  public static extern string SWITCH_SEQ_F_BLUE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_MAGEN_get")]
-  public static extern string SWITCH_SEQ_F_MAGEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_CYAN_get")]
-  public static extern string SWITCH_SEQ_F_CYAN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_F_WHITE_get")]
-  public static extern string SWITCH_SEQ_F_WHITE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_BLACK_get")]
-  public static extern string SWITCH_SEQ_B_BLACK_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_RED_get")]
-  public static extern string SWITCH_SEQ_B_RED_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_GREEN_get")]
-  public static extern string SWITCH_SEQ_B_GREEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_YELLOW_get")]
-  public static extern string SWITCH_SEQ_B_YELLOW_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_BLUE_get")]
-  public static extern string SWITCH_SEQ_B_BLUE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_MAGEN_get")]
-  public static extern string SWITCH_SEQ_B_MAGEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_CYAN_get")]
-  public static extern string SWITCH_SEQ_B_CYAN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_B_WHITE_get")]
-  public static extern string SWITCH_SEQ_B_WHITE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FBLACK_get")]
-  public static extern string SWITCH_SEQ_FBLACK_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FRED_get")]
-  public static extern string SWITCH_SEQ_FRED_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FGREEN_get")]
-  public static extern string SWITCH_SEQ_FGREEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FYELLOW_get")]
-  public static extern string SWITCH_SEQ_FYELLOW_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FBLUE_get")]
-  public static extern string SWITCH_SEQ_FBLUE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FMAGEN_get")]
-  public static extern string SWITCH_SEQ_FMAGEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FCYAN_get")]
-  public static extern string SWITCH_SEQ_FCYAN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_FWHITE_get")]
-  public static extern string SWITCH_SEQ_FWHITE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BBLACK_get")]
-  public static extern string SWITCH_SEQ_BBLACK_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BRED_get")]
-  public static extern string SWITCH_SEQ_BRED_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BGREEN_get")]
-  public static extern string SWITCH_SEQ_BGREEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BYELLOW_get")]
-  public static extern string SWITCH_SEQ_BYELLOW_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BBLUE_get")]
-  public static extern string SWITCH_SEQ_BBLUE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BMAGEN_get")]
-  public static extern string SWITCH_SEQ_BMAGEN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BCYAN_get")]
-  public static extern string SWITCH_SEQ_BCYAN_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_BWHITE_get")]
-  public static extern string SWITCH_SEQ_BWHITE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_HOME_get")]
-  public static extern string SWITCH_SEQ_HOME_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINE_get")]
-  public static extern string SWITCH_SEQ_CLEARLINE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARLINEEND_get")]
-  public static extern string SWITCH_SEQ_CLEARLINEEND_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SEQ_CLEARSCR_get")]
-  public static extern string SWITCH_SEQ_CLEARSCR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_DEFAULT_DTMF_DURATION_get")]
-  public static extern int SWITCH_DEFAULT_DTMF_DURATION_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_DTMF_DURATION_get")]
-  public static extern int SWITCH_MAX_DTMF_DURATION_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PATH_SEPARATOR_get")]
-  public static extern string SWITCH_PATH_SEPARATOR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_URL_SEPARATOR_get")]
-  public static extern string SWITCH_URL_SEPARATOR_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get")]
-  public static extern string SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_READ_RESULT_VARIABLE_get")]
-  public static extern string SWITCH_READ_RESULT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_COPY_XML_CDR_VARIABLE_get")]
-  public static extern string SWITCH_COPY_XML_CDR_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CURRENT_APPLICATION_VARIABLE_get")]
-  public static extern string SWITCH_CURRENT_APPLICATION_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get")]
-  public static extern string SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get")]
-  public static extern string SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get")]
-  public static extern string SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CALL_TIMEOUT_VARIABLE_get")]
-  public static extern string SWITCH_CALL_TIMEOUT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HOLDING_UUID_VARIABLE_get")]
-  public static extern string SWITCH_HOLDING_UUID_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_BRIDGE_END_VARIABLE_get")]
-  public static extern string SWITCH_API_BRIDGE_END_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_HANGUP_HOOK_VARIABLE_get")]
-  public static extern string SWITCH_API_HANGUP_HOOK_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROCESS_CDR_VARIABLE_get")]
-  public static extern string SWITCH_PROCESS_CDR_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_CHANNEL_VARIABLE_get")]
-  public static extern string SWITCH_BRIDGE_CHANNEL_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CHANNEL_NAME_VARIABLE_get")]
-  public static extern string SWITCH_CHANNEL_NAME_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_UUID_VARIABLE_get")]
-  public static extern string SWITCH_BRIDGE_UUID_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get")]
-  public static extern string SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get")]
-  public static extern string SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get")]
-  public static extern string SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get")]
-  public static extern string SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYPASS_MEDIA_VARIABLE_get")]
-  public static extern string SWITCH_BYPASS_MEDIA_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_PROXY_MEDIA_VARIABLE_get")]
-  public static extern string SWITCH_PROXY_MEDIA_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get")]
-  public static extern string SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HOLD_MUSIC_VARIABLE_get")]
-  public static extern string SWITCH_HOLD_MUSIC_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXPORT_VARS_VARIABLE_get")]
-  public static extern string SWITCH_EXPORT_VARS_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_R_SDP_VARIABLE_get")]
-  public static extern string SWITCH_R_SDP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_L_SDP_VARIABLE_get")]
-  public static extern string SWITCH_L_SDP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_B_SDP_VARIABLE_get")]
-  public static extern string SWITCH_B_SDP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BRIDGE_VARIABLE_get")]
-  public static extern string SWITCH_BRIDGE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SIGNAL_BRIDGE_VARIABLE_get")]
-  public static extern string SWITCH_SIGNAL_BRIDGE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SIGNAL_BOND_VARIABLE_get")]
-  public static extern string SWITCH_SIGNAL_BOND_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ORIGINATOR_VARIABLE_get")]
-  public static extern string SWITCH_ORIGINATOR_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_ORIGINATOR_CODEC_VARIABLE_get")]
-  public static extern string SWITCH_ORIGINATOR_CODEC_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_MEDIA_IP_VARIABLE_get")]
-  public static extern string SWITCH_LOCAL_MEDIA_IP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get")]
-  public static extern string SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_MEDIA_IP_VARIABLE_get")]
-  public static extern string SWITCH_REMOTE_MEDIA_IP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get")]
-  public static extern string SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_VIDEO_IP_VARIABLE_get")]
-  public static extern string SWITCH_REMOTE_VIDEO_IP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get")]
-  public static extern string SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_VIDEO_IP_VARIABLE_get")]
-  public static extern string SWITCH_LOCAL_VIDEO_IP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get")]
-  public static extern string SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get")]
-  public static extern string SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get")]
-  public static extern string SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get")]
-  public static extern string SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_FORWARDS_VARIABLE_get")]
-  public static extern string SWITCH_MAX_FORWARDS_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_DISABLE_APP_LOG_VARIABLE_get")]
-  public static extern string SWITCH_DISABLE_APP_LOG_VARIABLE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SPEECH_KEY_get")]
-  public static extern string SWITCH_SPEECH_KEY_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_UUID_BRIDGE_get")]
-  public static extern string SWITCH_UUID_BRIDGE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BITS_PER_BYTE_get")]
-  public static extern int SWITCH_BITS_PER_BYTE_get();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_digit_set")]
-  public static extern void switch_dtmf_t_digit_set(HandleRef jarg1, char jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_digit_get")]
-  public static extern char switch_dtmf_t_digit_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_duration_set")]
-  public static extern void switch_dtmf_t_duration_set(HandleRef jarg1, uint jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dtmf_t_duration_get")]
-  public static extern uint switch_dtmf_t_duration_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_dtmf_t")]
-  public static extern IntPtr new_switch_dtmf_t();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_dtmf_t")]
-  public static extern void delete_switch_dtmf_t(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buf_set")]
-  public static extern void switch_bitpack_t_buf_set(HandleRef jarg1, HandleRef jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buf_get")]
-  public static extern IntPtr switch_bitpack_t_buf_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buflen_set")]
-  public static extern void switch_bitpack_t_buflen_set(HandleRef jarg1, uint jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_buflen_get")]
-  public static extern uint switch_bitpack_t_buflen_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_cur_set")]
-  public static extern void switch_bitpack_t_cur_set(HandleRef jarg1, HandleRef jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_cur_get")]
-  public static extern IntPtr switch_bitpack_t_cur_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bytes_set")]
-  public static extern void switch_bitpack_t_bytes_set(HandleRef jarg1, uint jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bytes_get")]
-  public static extern uint switch_bitpack_t_bytes_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_tot_set")]
-  public static extern void switch_bitpack_t_bits_tot_set(HandleRef jarg1, uint jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_tot_get")]
-  public static extern uint switch_bitpack_t_bits_tot_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_cur_set")]
-  public static extern void switch_bitpack_t_bits_cur_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_cur_get")]
-  public static extern byte switch_bitpack_t_bits_cur_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_rem_set")]
-  public static extern void switch_bitpack_t_bits_rem_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_bits_rem_get")]
-  public static extern byte switch_bitpack_t_bits_rem_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_frame_bits_set")]
-  public static extern void switch_bitpack_t_frame_bits_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_frame_bits_get")]
-  public static extern byte switch_bitpack_t_frame_bits_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_shiftby_set")]
-  public static extern void switch_bitpack_t_shiftby_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_shiftby_get")]
-  public static extern byte switch_bitpack_t_shiftby_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_this_byte_set")]
-  public static extern void switch_bitpack_t_this_byte_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_this_byte_get")]
-  public static extern byte switch_bitpack_t_this_byte_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_under_set")]
-  public static extern void switch_bitpack_t_under_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_under_get")]
-  public static extern byte switch_bitpack_t_under_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_over_set")]
-  public static extern void switch_bitpack_t_over_set(HandleRef jarg1, byte jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_over_get")]
-  public static extern byte switch_bitpack_t_over_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_mode_set")]
-  public static extern void switch_bitpack_t_mode_set(HandleRef jarg1, int jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_bitpack_t_mode_get")]
-  public static extern int switch_bitpack_t_mode_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_bitpack_t")]
-  public static extern IntPtr new_switch_bitpack_t();
-
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_bitpack_t")]
-  public static extern void delete_switch_bitpack_t(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_base_dir_set")]
-  public static extern void switch_directories_base_dir_set(HandleRef jarg1, string jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_base_dir_get")]
-  public static extern string switch_directories_base_dir_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_mod_dir_set")]
-  public static extern void switch_directories_mod_dir_set(HandleRef jarg1, string jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_mod_dir_get")]
-  public static extern string switch_directories_mod_dir_get(HandleRef jarg1);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_conf_dir_set")]
-  public static extern void switch_directories_conf_dir_set(HandleRef jarg1, string jarg2);
-
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_conf_dir_get")]
-  public static extern string switch_directories_conf_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_ton_set")]
+  public static extern void switch_caller_profile_destination_number_ton_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_log_dir_set")]
-  public static extern void switch_directories_log_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_ton_get")]
+  public static extern byte switch_caller_profile_destination_number_ton_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_log_dir_get")]
-  public static extern string switch_directories_log_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_numplan_set")]
+  public static extern void switch_caller_profile_destination_number_numplan_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_db_dir_set")]
-  public static extern void switch_directories_db_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_numplan_get")]
+  public static extern byte switch_caller_profile_destination_number_numplan_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_db_dir_get")]
-  public static extern string switch_directories_db_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_source_set")]
+  public static extern void switch_caller_profile_source_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_script_dir_set")]
-  public static extern void switch_directories_script_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_source_get")]
+  public static extern string switch_caller_profile_source_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_script_dir_get")]
-  public static extern string switch_directories_script_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_chan_name_set")]
+  public static extern void switch_caller_profile_chan_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_temp_dir_set")]
-  public static extern void switch_directories_temp_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_chan_name_get")]
+  public static extern string switch_caller_profile_chan_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_temp_dir_get")]
-  public static extern string switch_directories_temp_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_uuid_set")]
+  public static extern void switch_caller_profile_uuid_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_htdocs_dir_set")]
-  public static extern void switch_directories_htdocs_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_uuid_get")]
+  public static extern string switch_caller_profile_uuid_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_htdocs_dir_get")]
-  public static extern string switch_directories_htdocs_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_context_set")]
+  public static extern void switch_caller_profile_context_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_grammar_dir_set")]
-  public static extern void switch_directories_grammar_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_context_get")]
+  public static extern string switch_caller_profile_context_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_grammar_dir_get")]
-  public static extern string switch_directories_grammar_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_profile_index_set")]
+  public static extern void switch_caller_profile_profile_index_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_storage_dir_set")]
-  public static extern void switch_directories_storage_dir_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_profile_index_get")]
+  public static extern string switch_caller_profile_profile_index_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directories_storage_dir_get")]
-  public static extern string switch_directories_storage_dir_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_flags_set")]
+  public static extern void switch_caller_profile_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directories")]
-  public static extern IntPtr new_switch_directories();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_flags_get")]
+  public static extern uint switch_caller_profile_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directories")]
-  public static extern void delete_switch_directories(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originator_caller_profile_set")]
+  public static extern void switch_caller_profile_originator_caller_profile_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_GLOBAL_dirs_set")]
-  public static extern void SWITCH_GLOBAL_dirs_set(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originator_caller_profile_get")]
+  public static extern IntPtr switch_caller_profile_originator_caller_profile_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_GLOBAL_dirs_get")]
-  public static extern IntPtr SWITCH_GLOBAL_dirs_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originatee_caller_profile_set")]
+  public static extern void switch_caller_profile_originatee_caller_profile_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STACKS_get")]
-  public static extern int SWITCH_MAX_STACKS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originatee_caller_profile_get")]
+  public static extern IntPtr switch_caller_profile_originatee_caller_profile_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_THREAD_STACKSIZE_get")]
-  public static extern int SWITCH_THREAD_STACKSIZE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_times_set")]
+  public static extern void switch_caller_profile_times_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_INTERVAL_get")]
-  public static extern int SWITCH_MAX_INTERVAL_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_times_get")]
+  public static extern IntPtr switch_caller_profile_times_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_INTERVAL_PAD_get")]
-  public static extern int SWITCH_INTERVAL_PAD_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_extension_set")]
+  public static extern void switch_caller_profile_caller_extension_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_SAMPLE_LEN_get")]
-  public static extern int SWITCH_MAX_SAMPLE_LEN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_extension_get")]
+  public static extern IntPtr switch_caller_profile_caller_extension_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_BYTES_PER_SAMPLE_get")]
-  public static extern int SWITCH_BYTES_PER_SAMPLE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_pool_set")]
+  public static extern void switch_caller_profile_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RECOMMENDED_BUFFER_SIZE_get")]
-  public static extern int SWITCH_RECOMMENDED_BUFFER_SIZE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_pool_get")]
+  public static extern IntPtr switch_caller_profile_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_CODECS_get")]
-  public static extern int SWITCH_MAX_CODECS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_next_set")]
+  public static extern void switch_caller_profile_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STATE_HANDLERS_get")]
-  public static extern int SWITCH_MAX_STATE_HANDLERS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_next_get")]
+  public static extern IntPtr switch_caller_profile_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_QUEUE_LEN_get")]
-  public static extern int SWITCH_CORE_QUEUE_LEN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_profile")]
+  public static extern IntPtr new_switch_caller_profile();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get")]
-  public static extern int SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_profile")]
+  public static extern void delete_switch_caller_profile(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CNG_PAYLOAD_get")]
-  public static extern int SWITCH_RTP_CNG_PAYLOAD_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_name_set")]
+  public static extern void switch_caller_application_application_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_version_set")]
-  public static extern void switch_rtp_hdr_t_version_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_name_get")]
+  public static extern string switch_caller_application_application_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_version_get")]
-  public static extern uint switch_rtp_hdr_t_version_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_data_set")]
+  public static extern void switch_caller_application_application_data_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_p_set")]
-  public static extern void switch_rtp_hdr_t_p_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_data_get")]
+  public static extern string switch_caller_application_application_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_p_get")]
-  public static extern uint switch_rtp_hdr_t_p_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_function_set")]
+  public static extern void switch_caller_application_application_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_x_set")]
-  public static extern void switch_rtp_hdr_t_x_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_function_get")]
+  public static extern IntPtr switch_caller_application_application_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_x_get")]
-  public static extern uint switch_rtp_hdr_t_x_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_next_set")]
+  public static extern void switch_caller_application_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_cc_set")]
-  public static extern void switch_rtp_hdr_t_cc_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_next_get")]
+  public static extern IntPtr switch_caller_application_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_cc_get")]
-  public static extern uint switch_rtp_hdr_t_cc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_application")]
+  public static extern IntPtr new_switch_caller_application();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_m_set")]
-  public static extern void switch_rtp_hdr_t_m_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_application")]
+  public static extern void delete_switch_caller_application(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_m_get")]
-  public static extern uint switch_rtp_hdr_t_m_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_name_set")]
+  public static extern void switch_caller_extension_extension_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_pt_set")]
-  public static extern void switch_rtp_hdr_t_pt_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_name_get")]
+  public static extern string switch_caller_extension_extension_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_pt_get")]
-  public static extern uint switch_rtp_hdr_t_pt_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_number_set")]
+  public static extern void switch_caller_extension_extension_number_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_seq_set")]
-  public static extern void switch_rtp_hdr_t_seq_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_number_get")]
+  public static extern string switch_caller_extension_extension_number_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_seq_get")]
-  public static extern uint switch_rtp_hdr_t_seq_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_current_application_set")]
+  public static extern void switch_caller_extension_current_application_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ts_set")]
-  public static extern void switch_rtp_hdr_t_ts_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_current_application_get")]
+  public static extern IntPtr switch_caller_extension_current_application_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ts_get")]
-  public static extern uint switch_rtp_hdr_t_ts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_last_application_set")]
+  public static extern void switch_caller_extension_last_application_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ssrc_set")]
-  public static extern void switch_rtp_hdr_t_ssrc_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_last_application_get")]
+  public static extern IntPtr switch_caller_extension_last_application_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_hdr_t_ssrc_get")]
-  public static extern uint switch_rtp_hdr_t_ssrc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_applications_set")]
+  public static extern void switch_caller_extension_applications_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_rtp_hdr_t")]
-  public static extern IntPtr new_switch_rtp_hdr_t();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_applications_get")]
+  public static extern IntPtr switch_caller_extension_applications_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_rtp_hdr_t")]
-  public static extern void delete_switch_rtp_hdr_t(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_children_set")]
+  public static extern void switch_caller_extension_children_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_input_callback_set")]
-  public static extern void switch_input_args_t_input_callback_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_children_get")]
+  public static extern IntPtr switch_caller_extension_children_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_input_callback_get")]
-  public static extern IntPtr switch_input_args_t_input_callback_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_next_set")]
+  public static extern void switch_caller_extension_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buf_set")]
-  public static extern void switch_input_args_t_buf_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_next_get")]
+  public static extern IntPtr switch_caller_extension_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buf_get")]
-  public static extern IntPtr switch_input_args_t_buf_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_extension")]
+  public static extern IntPtr new_switch_caller_extension();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buflen_set")]
-  public static extern void switch_input_args_t_buflen_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_extension")]
+  public static extern void delete_switch_caller_extension(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_buflen_get")]
-  public static extern uint switch_input_args_t_buflen_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_new")]
+  public static extern IntPtr switch_caller_extension_new(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_read_frame_callback_set")]
-  public static extern void switch_input_args_t_read_frame_callback_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_clone")]
+  public static extern int switch_caller_extension_clone(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_read_frame_callback_get")]
-  public static extern IntPtr switch_input_args_t_read_frame_callback_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_add_application")]
+  public static extern void switch_caller_extension_add_application(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_user_data_set")]
-  public static extern void switch_input_args_t_user_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_get_field_by_name")]
+  public static extern string switch_caller_get_field_by_name(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_input_args_t_user_data_get")]
-  public static extern IntPtr switch_input_args_t_user_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_new")]
+  public static extern IntPtr switch_caller_profile_new(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, string jarg10, string jarg11, string jarg12);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_input_args_t")]
-  public static extern IntPtr new_switch_input_args_t();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_clone")]
+  public static extern IntPtr switch_caller_profile_clone(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_input_args_t")]
-  public static extern void delete_switch_input_args_t(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dup")]
+  public static extern IntPtr switch_caller_profile_dup(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_API_VERSION_get")]
-  public static extern int SWITCH_API_VERSION_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_event_set_data")]
+  public static extern void switch_caller_profile_event_set_data(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_switch_api_version_set")]
-  public static extern void switch_loadable_module_function_table_t_switch_api_version_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_codec_set")]
+  public static extern void switch_frame_codec_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_switch_api_version_get")]
-  public static extern int switch_loadable_module_function_table_t_switch_api_version_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_codec_get")]
+  public static extern IntPtr switch_frame_codec_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_load_set")]
-  public static extern void switch_loadable_module_function_table_t_load_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_source_set")]
+  public static extern void switch_frame_source_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_load_get")]
-  public static extern IntPtr switch_loadable_module_function_table_t_load_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_source_get")]
+  public static extern string switch_frame_source_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_shutdown_set")]
-  public static extern void switch_loadable_module_function_table_t_shutdown_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packet_set")]
+  public static extern void switch_frame_packet_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_shutdown_get")]
-  public static extern IntPtr switch_loadable_module_function_table_t_shutdown_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packet_get")]
+  public static extern IntPtr switch_frame_packet_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_runtime_set")]
-  public static extern void switch_loadable_module_function_table_t_runtime_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packetlen_set")]
+  public static extern void switch_frame_packetlen_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_function_table_t_runtime_get")]
-  public static extern IntPtr switch_loadable_module_function_table_t_runtime_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packetlen_get")]
+  public static extern uint switch_frame_packetlen_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_loadable_module_function_table_t")]
-  public static extern IntPtr new_switch_loadable_module_function_table_t();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_data_set")]
+  public static extern void switch_frame_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_loadable_module_function_table_t")]
-  public static extern void delete_switch_loadable_module_function_table_t(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_data_get")]
+  public static extern IntPtr switch_frame_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_close")]
-  public static extern int switch_core_db_close(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_datalen_set")]
+  public static extern void switch_frame_datalen_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_open")]
-  public static extern int switch_core_db_open(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_datalen_get")]
+  public static extern uint switch_frame_datalen_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_text")]
-  public static extern IntPtr switch_core_db_column_text(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_buflen_set")]
+  public static extern void switch_frame_buflen_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_name")]
-  public static extern string switch_core_db_column_name(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_buflen_get")]
+  public static extern uint switch_frame_buflen_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_column_count")]
-  public static extern int switch_core_db_column_count(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_samples_set")]
+  public static extern void switch_frame_samples_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_errmsg")]
-  public static extern string switch_core_db_errmsg(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_samples_get")]
+  public static extern uint switch_frame_samples_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_exec")]
-  public static extern int switch_core_db_exec(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, ref string jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_rate_set")]
+  public static extern void switch_frame_rate_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_finalize")]
-  public static extern int switch_core_db_finalize(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_rate_get")]
+  public static extern uint switch_frame_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_prepare")]
-  public static extern int switch_core_db_prepare(HandleRef jarg1, string jarg2, int jarg3, HandleRef jarg4, ref string jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_payload_set")]
+  public static extern void switch_frame_payload_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_step")]
-  public static extern int switch_core_db_step(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_payload_get")]
+  public static extern byte switch_frame_payload_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_reset")]
-  public static extern int switch_core_db_reset(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_timestamp_set")]
+  public static extern void switch_frame_timestamp_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_int")]
-  public static extern int switch_core_db_bind_int(HandleRef jarg1, int jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_timestamp_get")]
+  public static extern IntPtr switch_frame_timestamp_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_int64")]
-  public static extern int switch_core_db_bind_int64(HandleRef jarg1, int jarg2, long jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_seq_set")]
+  public static extern void switch_frame_seq_set(HandleRef jarg1, ushort jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_text")]
-  public static extern int switch_core_db_bind_text(HandleRef jarg1, int jarg2, string jarg3, int jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_seq_get")]
+  public static extern ushort switch_frame_seq_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_bind_double")]
-  public static extern int switch_core_db_bind_double(HandleRef jarg1, int jarg2, double jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_ssrc_set")]
+  public static extern void switch_frame_ssrc_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_last_insert_rowid")]
-  public static extern long switch_core_db_last_insert_rowid(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_ssrc_get")]
+  public static extern uint switch_frame_ssrc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_get_table")]
-  public static extern int switch_core_db_get_table(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, ref string jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_m_set")]
+  public static extern void switch_frame_m_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_free_table")]
-  public static extern void switch_core_db_free_table(ref string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_m_get")]
+  public static extern int switch_frame_m_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_free")]
-  public static extern void switch_core_db_free(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_flags_set")]
+  public static extern void switch_frame_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_changes")]
-  public static extern int switch_core_db_changes(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_flags_get")]
+  public static extern uint switch_frame_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_OK_get")]
-  public static extern int SWITCH_CORE_DB_OK_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_frame")]
+  public static extern IntPtr new_switch_frame();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ERROR_get")]
-  public static extern int SWITCH_CORE_DB_ERROR_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_frame")]
+  public static extern void delete_switch_frame(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_INTERNAL_get")]
-  public static extern int SWITCH_CORE_DB_INTERNAL_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_init_set")]
+  public static extern void switch_state_handler_table_on_init_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_PERM_get")]
-  public static extern int SWITCH_CORE_DB_PERM_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_init_get")]
+  public static extern IntPtr switch_state_handler_table_on_init_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ABORT_get")]
-  public static extern int SWITCH_CORE_DB_ABORT_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_routing_set")]
+  public static extern void switch_state_handler_table_on_routing_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_BUSY_get")]
-  public static extern int SWITCH_CORE_DB_BUSY_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_routing_get")]
+  public static extern IntPtr switch_state_handler_table_on_routing_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_LOCKED_get")]
-  public static extern int SWITCH_CORE_DB_LOCKED_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_execute_set")]
+  public static extern void switch_state_handler_table_on_execute_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOMEM_get")]
-  public static extern int SWITCH_CORE_DB_NOMEM_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_execute_get")]
+  public static extern IntPtr switch_state_handler_table_on_execute_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_READONLY_get")]
-  public static extern int SWITCH_CORE_DB_READONLY_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hangup_set")]
+  public static extern void switch_state_handler_table_on_hangup_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_INTERRUPT_get")]
-  public static extern int SWITCH_CORE_DB_INTERRUPT_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hangup_get")]
+  public static extern IntPtr switch_state_handler_table_on_hangup_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_IOERR_get")]
-  public static extern int SWITCH_CORE_DB_IOERR_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_exchange_media_set")]
+  public static extern void switch_state_handler_table_on_exchange_media_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CORRUPT_get")]
-  public static extern int SWITCH_CORE_DB_CORRUPT_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_exchange_media_get")]
+  public static extern IntPtr switch_state_handler_table_on_exchange_media_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOTFOUND_get")]
-  public static extern int SWITCH_CORE_DB_NOTFOUND_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_soft_execute_set")]
+  public static extern void switch_state_handler_table_on_soft_execute_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_FULL_get")]
-  public static extern int SWITCH_CORE_DB_FULL_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_soft_execute_get")]
+  public static extern IntPtr switch_state_handler_table_on_soft_execute_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CANTOPEN_get")]
-  public static extern int SWITCH_CORE_DB_CANTOPEN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_consume_media_set")]
+  public static extern void switch_state_handler_table_on_consume_media_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_PROTOCOL_get")]
-  public static extern int SWITCH_CORE_DB_PROTOCOL_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_consume_media_get")]
+  public static extern IntPtr switch_state_handler_table_on_consume_media_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_EMPTY_get")]
-  public static extern int SWITCH_CORE_DB_EMPTY_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hibernate_set")]
+  public static extern void switch_state_handler_table_on_hibernate_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_SCHEMA_get")]
-  public static extern int SWITCH_CORE_DB_SCHEMA_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hibernate_get")]
+  public static extern IntPtr switch_state_handler_table_on_hibernate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_TOOBIG_get")]
-  public static extern int SWITCH_CORE_DB_TOOBIG_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_reset_set")]
+  public static extern void switch_state_handler_table_on_reset_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_CONSTRAINT_get")]
-  public static extern int SWITCH_CORE_DB_CONSTRAINT_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_reset_get")]
+  public static extern IntPtr switch_state_handler_table_on_reset_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_MISMATCH_get")]
-  public static extern int SWITCH_CORE_DB_MISMATCH_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_park_set")]
+  public static extern void switch_state_handler_table_on_park_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_MISUSE_get")]
-  public static extern int SWITCH_CORE_DB_MISUSE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_park_get")]
+  public static extern IntPtr switch_state_handler_table_on_park_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOLFS_get")]
-  public static extern int SWITCH_CORE_DB_NOLFS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_padding_set")]
+  public static extern void switch_state_handler_table_padding_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_AUTH_get")]
-  public static extern int SWITCH_CORE_DB_AUTH_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_padding_get")]
+  public static extern IntPtr switch_state_handler_table_padding_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_FORMAT_get")]
-  public static extern int SWITCH_CORE_DB_FORMAT_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_state_handler_table")]
+  public static extern IntPtr new_switch_state_handler_table();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_RANGE_get")]
-  public static extern int SWITCH_CORE_DB_RANGE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_state_handler_table")]
+  public static extern void delete_switch_state_handler_table(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_NOTADB_get")]
-  public static extern int SWITCH_CORE_DB_NOTADB_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_write_function_set")]
+  public static extern void switch_stream_handle_write_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_ROW_get")]
-  public static extern int SWITCH_CORE_DB_ROW_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_write_function_get")]
+  public static extern IntPtr switch_stream_handle_write_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_DONE_get")]
-  public static extern int SWITCH_CORE_DB_DONE_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_raw_write_function_set")]
+  public static extern void switch_stream_handle_raw_write_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_mprintf")]
-  public static extern string switch_mprintf(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_raw_write_function_get")]
+  public static extern IntPtr switch_stream_handle_raw_write_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_compile")]
-  public static extern IntPtr switch_regex_compile(string jarg1, int jarg2, ref string jarg3, HandleRef jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_set")]
+  public static extern void switch_stream_handle_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_copy_substring")]
-  public static extern int switch_regex_copy_substring(string jarg1, HandleRef jarg2, int jarg3, int jarg4, string jarg5, int jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_get")]
+  public static extern IntPtr switch_stream_handle_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_free")]
-  public static extern void switch_regex_free(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_end_set")]
+  public static extern void switch_stream_handle_end_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_perform")]
-  public static extern int switch_regex_perform(string jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, uint jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_end_get")]
+  public static extern IntPtr switch_stream_handle_end_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_perform_substitution")]
-  public static extern void switch_perform_substitution(HandleRef jarg1, int jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6, HandleRef jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_size_set")]
+  public static extern void switch_stream_handle_data_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_match")]
-  public static extern int switch_regex_match(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_size_get")]
+  public static extern IntPtr switch_stream_handle_data_size_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_regex_match_partial")]
-  public static extern int switch_regex_match_partial(string jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_len_set")]
+  public static extern void switch_stream_handle_data_len_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get")]
-  public static extern int SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_len_get")]
+  public static extern IntPtr switch_stream_handle_data_len_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_MAX_STREAMS_get")]
-  public static extern int SWITCH_MAX_STREAMS_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_len_set")]
+  public static extern void switch_stream_handle_alloc_len_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_mms_set")]
-  public static extern void switch_core_time_duration_mms_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_len_get")]
+  public static extern IntPtr switch_stream_handle_alloc_len_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_mms_get")]
-  public static extern uint switch_core_time_duration_mms_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_chunk_set")]
+  public static extern void switch_stream_handle_alloc_chunk_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_ms_set")]
-  public static extern void switch_core_time_duration_ms_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_chunk_get")]
+  public static extern IntPtr switch_stream_handle_alloc_chunk_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_ms_get")]
-  public static extern uint switch_core_time_duration_ms_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_param_event_set")]
+  public static extern void switch_stream_handle_param_event_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_sec_set")]
-  public static extern void switch_core_time_duration_sec_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_param_event_get")]
+  public static extern IntPtr switch_stream_handle_param_event_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_sec_get")]
-  public static extern uint switch_core_time_duration_sec_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_stream_handle")]
+  public static extern IntPtr new_switch_stream_handle();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_min_set")]
-  public static extern void switch_core_time_duration_min_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_stream_handle")]
+  public static extern void delete_switch_stream_handle(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_min_get")]
-  public static extern uint switch_core_time_duration_min_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_outgoing_channel_set")]
+  public static extern void switch_io_routines_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_hr_set")]
-  public static extern void switch_core_time_duration_hr_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_outgoing_channel_get")]
+  public static extern IntPtr switch_io_routines_outgoing_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_hr_get")]
-  public static extern uint switch_core_time_duration_hr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_frame_set")]
+  public static extern void switch_io_routines_read_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_day_set")]
-  public static extern void switch_core_time_duration_day_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_frame_get")]
+  public static extern IntPtr switch_io_routines_read_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_day_get")]
-  public static extern uint switch_core_time_duration_day_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_frame_set")]
+  public static extern void switch_io_routines_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_yr_set")]
-  public static extern void switch_core_time_duration_yr_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_frame_get")]
+  public static extern IntPtr switch_io_routines_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_time_duration_yr_get")]
-  public static extern uint switch_core_time_duration_yr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_kill_channel_set")]
+  public static extern void switch_io_routines_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_time_duration")]
-  public static extern IntPtr new_switch_core_time_duration();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_kill_channel_get")]
+  public static extern IntPtr switch_io_routines_kill_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_time_duration")]
-  public static extern void delete_switch_core_time_duration(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_send_dtmf_set")]
+  public static extern void switch_io_routines_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_app_set")]
-  public static extern void switch_app_log_app_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_send_dtmf_get")]
+  public static extern IntPtr switch_io_routines_send_dtmf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_app_get")]
-  public static extern string switch_app_log_app_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_message_set")]
+  public static extern void switch_io_routines_receive_message_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_arg_set")]
-  public static extern void switch_app_log_arg_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_message_get")]
+  public static extern IntPtr switch_io_routines_receive_message_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_arg_get")]
-  public static extern string switch_app_log_arg_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_event_set")]
+  public static extern void switch_io_routines_receive_event_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_next_set")]
-  public static extern void switch_app_log_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_event_get")]
+  public static extern IntPtr switch_io_routines_receive_event_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_app_log_next_get")]
-  public static extern IntPtr switch_app_log_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_state_change_set")]
+  public static extern void switch_io_routines_state_change_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_app_log")]
-  public static extern IntPtr new_switch_app_log();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_state_change_get")]
+  public static extern IntPtr switch_io_routines_state_change_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_app_log")]
-  public static extern void delete_switch_app_log(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_video_frame_set")]
+  public static extern void switch_io_routines_read_video_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_from_set")]
-  public static extern void switch_core_session_message_from_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_video_frame_get")]
+  public static extern IntPtr switch_io_routines_read_video_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_from_get")]
-  public static extern string switch_core_session_message_from_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_video_frame_set")]
+  public static extern void switch_io_routines_write_video_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_message_id_set")]
-  public static extern void switch_core_session_message_message_id_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_video_frame_get")]
+  public static extern IntPtr switch_io_routines_write_video_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_message_id_get")]
-  public static extern int switch_core_session_message_message_id_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_resurrect_session_set")]
+  public static extern void switch_io_routines_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_arg_set")]
-  public static extern void switch_core_session_message_numeric_arg_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_resurrect_session_get")]
+  public static extern IntPtr switch_io_routines_resurrect_session_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_arg_get")]
-  public static extern int switch_core_session_message_numeric_arg_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_padding_set")]
+  public static extern void switch_io_routines_padding_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_set")]
-  public static extern void switch_core_session_message_string_arg_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_padding_get")]
+  public static extern IntPtr switch_io_routines_padding_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_get")]
-  public static extern string switch_core_session_message_string_arg_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_routines")]
+  public static extern IntPtr new_switch_io_routines();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_size_set")]
-  public static extern void switch_core_session_message_string_arg_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_routines")]
+  public static extern void delete_switch_io_routines(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_arg_size_get")]
-  public static extern IntPtr switch_core_session_message_string_arg_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_interface_name_set")]
+  public static extern void switch_endpoint_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_set")]
-  public static extern void switch_core_session_message_pointer_arg_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_interface_name_get")]
+  public static extern string switch_endpoint_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_get")]
-  public static extern IntPtr switch_core_session_message_pointer_arg_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_io_routines_set")]
+  public static extern void switch_endpoint_interface_io_routines_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_size_set")]
-  public static extern void switch_core_session_message_pointer_arg_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_io_routines_get")]
+  public static extern IntPtr switch_endpoint_interface_io_routines_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_arg_size_get")]
-  public static extern IntPtr switch_core_session_message_pointer_arg_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_state_handler_set")]
+  public static extern void switch_endpoint_interface_state_handler_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_reply_set")]
-  public static extern void switch_core_session_message_numeric_reply_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_state_handler_get")]
+  public static extern IntPtr switch_endpoint_interface_state_handler_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_numeric_reply_get")]
-  public static extern int switch_core_session_message_numeric_reply_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_private_info_set")]
+  public static extern void switch_endpoint_interface_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_set")]
-  public static extern void switch_core_session_message_string_reply_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_private_info_get")]
+  public static extern IntPtr switch_endpoint_interface_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_get")]
-  public static extern string switch_core_session_message_string_reply_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_rwlock_set")]
+  public static extern void switch_endpoint_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_size_set")]
-  public static extern void switch_core_session_message_string_reply_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_rwlock_get")]
+  public static extern IntPtr switch_endpoint_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_string_reply_size_get")]
-  public static extern IntPtr switch_core_session_message_string_reply_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_next_set")]
+  public static extern void switch_endpoint_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_set")]
-  public static extern void switch_core_session_message_pointer_reply_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_next_get")]
+  public static extern IntPtr switch_endpoint_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_get")]
-  public static extern IntPtr switch_core_session_message_pointer_reply_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_endpoint_interface")]
+  public static extern IntPtr new_switch_endpoint_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_size_set")]
-  public static extern void switch_core_session_message_pointer_reply_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_endpoint_interface")]
+  public static extern void delete_switch_endpoint_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_pointer_reply_size_get")]
-  public static extern IntPtr switch_core_session_message_pointer_reply_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interval_set")]
+  public static extern void switch_timer_interval_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_flags_set")]
-  public static extern void switch_core_session_message_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interval_get")]
+  public static extern int switch_timer_interval_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_flags_get")]
-  public static extern uint switch_core_session_message_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_flags_set")]
+  public static extern void switch_timer_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_session_message")]
-  public static extern IntPtr new_switch_core_session_message();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_flags_get")]
+  public static extern uint switch_timer_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_session_message")]
-  public static extern void delete_switch_core_session_message(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samples_set")]
+  public static extern void switch_timer_samples_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_running_set")]
-  public static extern void switch_core_thread_session_running_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samples_get")]
+  public static extern uint switch_timer_samples_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_running_get")]
-  public static extern int switch_core_thread_session_running_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samplecount_set")]
+  public static extern void switch_timer_samplecount_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_mutex_set")]
-  public static extern void switch_core_thread_session_mutex_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samplecount_get")]
+  public static extern uint switch_timer_samplecount_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_mutex_get")]
-  public static extern IntPtr switch_core_thread_session_mutex_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_timer_interface_set")]
+  public static extern void switch_timer_timer_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_objs_set")]
-  public static extern void switch_core_thread_session_objs_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_timer_interface_get")]
+  public static extern IntPtr switch_timer_timer_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_objs_get")]
-  public static extern IntPtr switch_core_thread_session_objs_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_memory_pool_set")]
+  public static extern void switch_timer_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_input_callback_set")]
-  public static extern void switch_core_thread_session_input_callback_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_memory_pool_get")]
+  public static extern IntPtr switch_timer_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_input_callback_get")]
-  public static extern IntPtr switch_core_thread_session_input_callback_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_private_info_set")]
+  public static extern void switch_timer_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_pool_set")]
-  public static extern void switch_core_thread_session_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_private_info_get")]
+  public static extern IntPtr switch_timer_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_pool_get")]
-  public static extern IntPtr switch_core_thread_session_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_diff_set")]
+  public static extern void switch_timer_diff_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_core_thread_session")]
-  public static extern IntPtr new_switch_core_thread_session();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_diff_get")]
+  public static extern IntPtr switch_timer_diff_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_core_thread_session")]
-  public static extern void delete_switch_core_thread_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_tick_set")]
+  public static extern void switch_timer_tick_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_add")]
-  public static extern int switch_core_media_bug_add(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, uint jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_tick_get")]
+  public static extern IntPtr switch_timer_tick_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_user_data")]
-  public static extern IntPtr switch_core_media_bug_get_user_data(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_timer")]
+  public static extern IntPtr new_switch_timer();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_write_replace_frame")]
-  public static extern IntPtr switch_core_media_bug_get_write_replace_frame(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_timer")]
+  public static extern void delete_switch_timer(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_set_write_replace_frame")]
-  public static extern void switch_core_media_bug_set_write_replace_frame(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_interface_name_set")]
+  public static extern void switch_timer_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_read_replace_frame")]
-  public static extern IntPtr switch_core_media_bug_get_read_replace_frame(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_interface_name_get")]
+  public static extern string switch_timer_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_get_session")]
-  public static extern IntPtr switch_core_media_bug_get_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_init_set")]
+  public static extern void switch_timer_interface_timer_init_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_test_flag")]
-  public static extern uint switch_core_media_bug_test_flag(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_init_get")]
+  public static extern IntPtr switch_timer_interface_timer_init_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_set_read_replace_frame")]
-  public static extern void switch_core_media_bug_set_read_replace_frame(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_next_set")]
+  public static extern void switch_timer_interface_timer_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_remove")]
-  public static extern int switch_core_media_bug_remove(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_next_get")]
+  public static extern IntPtr switch_timer_interface_timer_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_close")]
-  public static extern int switch_core_media_bug_close(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_step_set")]
+  public static extern void switch_timer_interface_timer_step_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_remove_all")]
-  public static extern int switch_core_media_bug_remove_all(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_step_get")]
+  public static extern IntPtr switch_timer_interface_timer_step_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_media_bug_read")]
-  public static extern int switch_core_media_bug_read(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_sync_set")]
+  public static extern void switch_timer_interface_timer_sync_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_new")]
-  public static extern int switch_core_port_allocator_new(ushort jarg1, ushort jarg2, uint jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_sync_get")]
+  public static extern IntPtr switch_timer_interface_timer_sync_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_request_port")]
-  public static extern int switch_core_port_allocator_request_port(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_check_set")]
+  public static extern void switch_timer_interface_timer_check_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_free_port")]
-  public static extern int switch_core_port_allocator_free_port(HandleRef jarg1, ushort jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_check_get")]
+  public static extern IntPtr switch_timer_interface_timer_check_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_port_allocator_destroy")]
-  public static extern void switch_core_port_allocator_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_destroy_set")]
+  public static extern void switch_timer_interface_timer_destroy_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_init")]
-  public static extern int switch_core_init(uint jarg1, int jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_destroy_get")]
+  public static extern IntPtr switch_timer_interface_timer_destroy_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_init_and_modload")]
-  public static extern int switch_core_init_and_modload(uint jarg1, int jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_rwlock_set")]
+  public static extern void switch_timer_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_limit")]
-  public static extern uint switch_core_session_limit(uint jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_rwlock_get")]
+  public static extern IntPtr switch_timer_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_sessions_per_second")]
-  public static extern uint switch_core_sessions_per_second(uint jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_next_set")]
+  public static extern void switch_timer_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_destroy")]
-  public static extern int switch_core_destroy();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_next_get")]
+  public static extern IntPtr switch_timer_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_lock")]
-  public static extern int switch_core_session_signal_lock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_timer_interface")]
+  public static extern IntPtr new_switch_timer_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_unlock")]
-  public static extern int switch_core_session_signal_unlock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_timer_interface")]
+  public static extern void delete_switch_timer_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_lock")]
-  public static extern int switch_core_session_read_lock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_interface_name_set")]
+  public static extern void switch_dialplan_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_lock")]
-  public static extern void switch_core_session_write_lock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_interface_name_get")]
+  public static extern string switch_dialplan_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_rwunlock")]
-  public static extern void switch_core_session_rwunlock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_hunt_function_set")]
+  public static extern void switch_dialplan_interface_hunt_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_add_state_handler")]
-  public static extern int switch_core_add_state_handler(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_hunt_function_get")]
+  public static extern IntPtr switch_dialplan_interface_hunt_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_remove_state_handler")]
-  public static extern void switch_core_remove_state_handler(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_rwlock_set")]
+  public static extern void switch_dialplan_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_state_handler")]
-  public static extern IntPtr switch_core_get_state_handler(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_rwlock_get")]
+  public static extern IntPtr switch_dialplan_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_pool_tag")]
-  public static extern void switch_core_memory_pool_tag(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_next_set")]
+  public static extern void switch_dialplan_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_new_memory_pool")]
-  public static extern int switch_core_perform_new_memory_pool(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_next_get")]
+  public static extern IntPtr switch_dialplan_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_destroy_memory_pool")]
-  public static extern int switch_core_perform_destroy_memory_pool(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_dialplan_interface")]
+  public static extern IntPtr new_switch_dialplan_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_run")]
-  public static extern void switch_core_session_run(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_dialplan_interface")]
+  public static extern void delete_switch_dialplan_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_running")]
-  public static extern uint switch_core_session_running(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_interface_name_set")]
+  public static extern void switch_file_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_permanent_alloc")]
-  public static extern IntPtr switch_core_perform_permanent_alloc(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_interface_name_get")]
+  public static extern string switch_file_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_alloc")]
-  public static extern IntPtr switch_core_perform_alloc(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_open_set")]
+  public static extern void switch_file_interface_file_open_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_session_alloc")]
-  public static extern IntPtr switch_core_perform_session_alloc(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_open_get")]
+  public static extern IntPtr switch_file_interface_file_open_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_permanent_strdup")]
-  public static extern string switch_core_perform_permanent_strdup(string jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_close_set")]
+  public static extern void switch_file_interface_file_close_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_session_strdup")]
-  public static extern string switch_core_perform_session_strdup(HandleRef jarg1, string jarg2, string jarg3, string jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_close_get")]
+  public static extern IntPtr switch_file_interface_file_close_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_strdup")]
-  public static extern string switch_core_perform_strdup(HandleRef jarg1, string jarg2, string jarg3, string jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_read_set")]
+  public static extern void switch_file_interface_file_read_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_sprintf")]
-  public static extern string switch_core_session_sprintf(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_read_get")]
+  public static extern IntPtr switch_file_interface_file_read_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_sprintf")]
-  public static extern string switch_core_sprintf(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_write_set")]
+  public static extern void switch_file_interface_file_write_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_pool")]
-  public static extern IntPtr switch_core_session_get_pool(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_write_get")]
+  public static extern IntPtr switch_file_interface_file_write_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_request")]
-  public static extern IntPtr switch_core_session_request(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_seek_set")]
+  public static extern void switch_file_interface_file_seek_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_perform_destroy")]
-  public static extern void switch_core_session_perform_destroy(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_seek_get")]
+  public static extern IntPtr switch_file_interface_file_seek_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_count")]
-  public static extern uint switch_core_session_count();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_set_string_set")]
+  public static extern void switch_file_interface_file_set_string_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_id")]
-  public static extern IntPtr switch_core_session_id();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_set_string_get")]
+  public static extern IntPtr switch_file_interface_file_set_string_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_request_by_name")]
-  public static extern IntPtr switch_core_session_request_by_name(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_get_string_set")]
+  public static extern void switch_file_interface_file_get_string_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_thread_launch")]
-  public static extern int switch_core_session_thread_launch(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_get_string_get")]
+  public static extern IntPtr switch_file_interface_file_get_string_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_channel")]
-  public static extern IntPtr switch_core_session_get_channel(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_extens_set")]
+  public static extern void switch_file_interface_extens_set(HandleRef jarg1, ref string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_signal_state_change")]
-  public static extern void switch_core_session_signal_state_change(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_extens_get")]
+  public static extern string switch_file_interface_extens_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_uuid")]
-  public static extern string switch_core_session_get_uuid(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_rwlock_set")]
+  public static extern void switch_file_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_uuid")]
-  public static extern string switch_core_get_uuid();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_rwlock_get")]
+  public static extern IntPtr switch_file_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_locate")]
-  public static extern IntPtr switch_core_session_locate(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_next_set")]
+  public static extern void switch_file_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_variable")]
-  public static extern string switch_core_get_variable(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_next_get")]
+  public static extern IntPtr switch_file_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_variable")]
-  public static extern void switch_core_set_variable(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_file_interface")]
+  public static extern IntPtr new_switch_file_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_dump_variables")]
-  public static extern void switch_core_dump_variables(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_file_interface")]
+  public static extern void delete_switch_file_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall")]
-  public static extern void switch_core_session_hupall(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_interface_set")]
+  public static extern void switch_file_handle_file_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall_matching_var")]
-  public static extern void switch_core_session_hupall_matching_var(string jarg1, string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_interface_get")]
+  public static extern IntPtr switch_file_handle_file_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_hupall_endpoint")]
-  public static extern void switch_core_session_hupall_endpoint(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_flags_set")]
+  public static extern void switch_file_handle_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_message_send")]
-  public static extern int switch_core_session_message_send(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_flags_get")]
+  public static extern uint switch_file_handle_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_message")]
-  public static extern int switch_core_session_queue_message(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_fd_set")]
+  public static extern void switch_file_handle_fd_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_pass_indication")]
-  public static extern int switch_core_session_pass_indication(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_fd_get")]
+  public static extern IntPtr switch_file_handle_fd_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_indication")]
-  public static extern int switch_core_session_queue_indication(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samples_set")]
+  public static extern void switch_file_handle_samples_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_message")]
-  public static extern int switch_core_session_dequeue_message(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samples_get")]
+  public static extern uint switch_file_handle_samples_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_flush_message")]
-  public static extern int switch_core_session_flush_message(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samplerate_set")]
+  public static extern void switch_file_handle_samplerate_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_event_send")]
-  public static extern int switch_core_session_event_send(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samplerate_get")]
+  public static extern uint switch_file_handle_samplerate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_app_log")]
-  public static extern IntPtr switch_core_session_get_app_log(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_native_rate_set")]
+  public static extern void switch_file_handle_native_rate_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_exec")]
-  public static extern int switch_core_session_exec(HandleRef jarg1, HandleRef jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_native_rate_get")]
+  public static extern uint switch_file_handle_native_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_execute_application")]
-  public static extern int switch_core_session_execute_application(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_channels_set")]
+  public static extern void switch_file_handle_channels_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_execute_exten")]
-  public static extern int switch_core_session_execute_exten(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_channels_get")]
+  public static extern byte switch_file_handle_channels_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_receive_event")]
-  public static extern int switch_core_session_receive_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_format_set")]
+  public static extern void switch_file_handle_format_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_private")]
-  public static extern IntPtr switch_core_session_get_private(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_format_get")]
+  public static extern uint switch_file_handle_format_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_private")]
-  public static extern int switch_core_session_set_private(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sections_set")]
+  public static extern void switch_file_handle_sections_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_add_stream")]
-  public static extern int switch_core_session_add_stream(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sections_get")]
+  public static extern uint switch_file_handle_sections_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_stream")]
-  public static extern IntPtr switch_core_session_get_stream(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_seekable_set")]
+  public static extern void switch_file_handle_seekable_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_stream_count")]
-  public static extern int switch_core_session_get_stream_count(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_seekable_get")]
+  public static extern int switch_file_handle_seekable_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_launch_thread")]
-  public static extern void switch_core_session_launch_thread(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sample_count_set")]
+  public static extern void switch_file_handle_sample_count_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_thread_session_end")]
-  public static extern void switch_core_thread_session_end(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sample_count_get")]
+  public static extern IntPtr switch_file_handle_sample_count_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_service_session")]
-  public static extern void switch_core_service_session(HandleRef jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_speed_set")]
+  public static extern void switch_file_handle_speed_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_outgoing_channel")]
-  public static extern int switch_core_session_outgoing_channel(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5, HandleRef jarg6, uint jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_speed_get")]
+  public static extern int switch_file_handle_speed_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_resurrect_channel")]
-  public static extern int switch_core_session_resurrect_channel(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_memory_pool_set")]
+  public static extern void switch_file_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_receive_message")]
-  public static extern int switch_core_session_receive_message(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_memory_pool_get")]
+  public static extern IntPtr switch_file_handle_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_event")]
-  public static extern int switch_core_session_queue_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_prebuf_set")]
+  public static extern void switch_file_handle_prebuf_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_event_count")]
-  public static extern uint switch_core_session_event_count(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_prebuf_get")]
+  public static extern uint switch_file_handle_prebuf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_event")]
-  public static extern int switch_core_session_dequeue_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_interval_set")]
+  public static extern void switch_file_handle_interval_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_queue_private_event")]
-  public static extern int switch_core_session_queue_private_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_interval_get")]
+  public static extern uint switch_file_handle_interval_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_private_event_count")]
-  public static extern uint switch_core_session_private_event_count(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_private_info_set")]
+  public static extern void switch_file_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_dequeue_private_event")]
-  public static extern int switch_core_session_dequeue_private_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_private_info_get")]
+  public static extern IntPtr switch_file_handle_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_flush_private_events")]
-  public static extern uint switch_core_session_flush_private_events(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_handler_set")]
+  public static extern void switch_file_handle_handler_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_frame")]
-  public static extern int switch_core_session_read_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_handler_get")]
+  public static extern string switch_file_handle_handler_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_read_video_frame")]
-  public static extern int switch_core_session_read_video_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_pos_set")]
+  public static extern void switch_file_handle_pos_set(HandleRef jarg1, long jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_video_frame")]
-  public static extern int switch_core_session_write_video_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_pos_get")]
+  public static extern long switch_file_handle_pos_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_reset")]
-  public static extern void switch_core_session_reset(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_audio_buffer_set")]
+  public static extern void switch_file_handle_audio_buffer_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_write_frame")]
-  public static extern int switch_core_session_write_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_audio_buffer_get")]
+  public static extern IntPtr switch_file_handle_audio_buffer_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_perform_kill_channel")]
-  public static extern int switch_core_session_perform_kill_channel(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sp_audio_buffer_set")]
+  public static extern void switch_file_handle_sp_audio_buffer_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_send_dtmf")]
-  public static extern int switch_core_session_send_dtmf(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sp_audio_buffer_get")]
+  public static extern IntPtr switch_file_handle_sp_audio_buffer_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_send_dtmf_string")]
-  public static extern int switch_core_session_send_dtmf_string(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_thresh_set")]
+  public static extern void switch_file_handle_thresh_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_recv_dtmf")]
-  public static extern int switch_core_session_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_thresh_get")]
+  public static extern uint switch_file_handle_thresh_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_init")]
-  public static extern int switch_core_hash_init(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_silence_hits_set")]
+  public static extern void switch_file_handle_silence_hits_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_destroy")]
-  public static extern int switch_core_hash_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_silence_hits_get")]
+  public static extern uint switch_file_handle_silence_hits_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_insert")]
-  public static extern int switch_core_hash_insert(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_offset_pos_set")]
+  public static extern void switch_file_handle_offset_pos_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_insert_locked")]
-  public static extern int switch_core_hash_insert_locked(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_offset_pos_get")]
+  public static extern uint switch_file_handle_offset_pos_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_delete")]
-  public static extern int switch_core_hash_delete(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_last_pos_set")]
+  public static extern void switch_file_handle_last_pos_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_delete_locked")]
-  public static extern int switch_core_hash_delete_locked(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_last_pos_get")]
+  public static extern uint switch_file_handle_last_pos_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_find")]
-  public static extern IntPtr switch_core_hash_find(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_vol_set")]
+  public static extern void switch_file_handle_vol_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_hash_find_locked")]
-  public static extern IntPtr switch_core_hash_find_locked(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_vol_get")]
+  public static extern int switch_file_handle_vol_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_first")]
-  public static extern IntPtr switch_hash_first(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_resampler_set")]
+  public static extern void switch_file_handle_resampler_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_next")]
-  public static extern IntPtr switch_hash_next(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_resampler_get")]
+  public static extern IntPtr switch_file_handle_resampler_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_hash_this")]
-  public static extern void switch_hash_this(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_buffer_set")]
+  public static extern void switch_file_handle_buffer_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_init")]
-  public static extern int switch_core_timer_init(HandleRef jarg1, string jarg2, int jarg3, int jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_buffer_get")]
+  public static extern IntPtr switch_file_handle_buffer_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_next")]
-  public static extern int switch_core_timer_next(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuf_set")]
+  public static extern void switch_file_handle_dbuf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_step")]
-  public static extern int switch_core_timer_step(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuf_get")]
+  public static extern IntPtr switch_file_handle_dbuf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_sync")]
-  public static extern int switch_core_timer_sync(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuflen_set")]
+  public static extern void switch_file_handle_dbuflen_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_check")]
-  public static extern int switch_core_timer_check(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuflen_get")]
+  public static extern IntPtr switch_file_handle_dbuflen_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_timer_destroy")]
-  public static extern int switch_core_timer_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_set")]
+  public static extern void switch_file_handle_file_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_init")]
-  public static extern int switch_core_codec_init(HandleRef jarg1, string jarg2, string jarg3, uint jarg4, int jarg5, int jarg6, uint jarg7, HandleRef jarg8, HandleRef jarg9);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_get")]
+  public static extern string switch_file_handle_file_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_copy")]
-  public static extern int switch_core_codec_copy(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_func_set")]
+  public static extern void switch_file_handle_func_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_encode")]
-  public static extern int switch_core_codec_encode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8, HandleRef jarg9);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_func_get")]
+  public static extern string switch_file_handle_func_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_decode")]
-  public static extern int switch_core_codec_decode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8, HandleRef jarg9);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_line_set")]
+  public static extern void switch_file_handle_line_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_codec_destroy")]
-  public static extern int switch_core_codec_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_line_get")]
+  public static extern int switch_file_handle_line_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_read_codec")]
-  public static extern int switch_core_session_set_read_codec(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_file_handle")]
+  public static extern IntPtr new_switch_file_handle();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_unset_read_codec")]
-  public static extern void switch_core_session_unset_read_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_file_handle")]
+  public static extern void delete_switch_file_handle(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_read_codec")]
-  public static extern IntPtr switch_core_session_get_read_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_interface_name_set")]
+  public static extern void switch_asr_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_effective_read_codec")]
-  public static extern IntPtr switch_core_session_get_effective_read_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_interface_name_get")]
+  public static extern string switch_asr_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_write_codec")]
-  public static extern int switch_core_session_set_write_codec(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_open_set")]
+  public static extern void switch_asr_interface_asr_open_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_write_codec")]
-  public static extern IntPtr switch_core_session_get_write_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_open_get")]
+  public static extern IntPtr switch_asr_interface_asr_open_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_effective_write_codec")]
-  public static extern IntPtr switch_core_session_get_effective_write_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_load_grammar_set")]
+  public static extern void switch_asr_interface_asr_load_grammar_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_video_read_codec")]
-  public static extern int switch_core_session_set_video_read_codec(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_load_grammar_get")]
+  public static extern IntPtr switch_asr_interface_asr_load_grammar_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_video_read_codec")]
-  public static extern IntPtr switch_core_session_get_video_read_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_unload_grammar_set")]
+  public static extern void switch_asr_interface_asr_unload_grammar_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_set_video_write_codec")]
-  public static extern int switch_core_session_set_video_write_codec(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_unload_grammar_get")]
+  public static extern IntPtr switch_asr_interface_asr_unload_grammar_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_get_video_write_codec")]
-  public static extern IntPtr switch_core_session_get_video_write_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_close_set")]
+  public static extern void switch_asr_interface_asr_close_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_open_file")]
-  public static extern IntPtr switch_core_db_open_file(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_close_get")]
+  public static extern IntPtr switch_asr_interface_asr_close_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_persistant_execute")]
-  public static extern int switch_core_db_persistant_execute(HandleRef jarg1, string jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_feed_set")]
+  public static extern void switch_asr_interface_asr_feed_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_db_test_reactive")]
-  public static extern void switch_core_db_test_reactive(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_feed_get")]
+  public static extern IntPtr switch_asr_interface_asr_feed_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CORE_DB_get")]
-  public static extern string SWITCH_CORE_DB_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_resume_set")]
+  public static extern void switch_asr_interface_asr_resume_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_perform_file_open")]
-  public static extern int switch_core_perform_file_open(string jarg1, string jarg2, int jarg3, HandleRef jarg4, string jarg5, byte jarg6, uint jarg7, uint jarg8, HandleRef jarg9);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_resume_get")]
+  public static extern IntPtr switch_asr_interface_asr_resume_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_read")]
-  public static extern int switch_core_file_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_pause_set")]
+  public static extern void switch_asr_interface_asr_pause_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_write")]
-  public static extern int switch_core_file_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_pause_get")]
+  public static extern IntPtr switch_asr_interface_asr_pause_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_seek")]
-  public static extern int switch_core_file_seek(HandleRef jarg1, HandleRef jarg2, long jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_check_results_set")]
+  public static extern void switch_asr_interface_asr_check_results_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_set_string")]
-  public static extern int switch_core_file_set_string(HandleRef jarg1, int jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_check_results_get")]
+  public static extern IntPtr switch_asr_interface_asr_check_results_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_get_string")]
-  public static extern int switch_core_file_get_string(HandleRef jarg1, int jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_get_results_set")]
+  public static extern void switch_asr_interface_asr_get_results_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_file_close")]
-  public static extern int switch_core_file_close(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_get_results_get")]
+  public static extern IntPtr switch_asr_interface_asr_get_results_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_open")]
-  public static extern int switch_core_speech_open(HandleRef jarg1, string jarg2, string jarg3, uint jarg4, uint jarg5, HandleRef jarg6, HandleRef jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_rwlock_set")]
+  public static extern void switch_asr_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_feed_tts")]
-  public static extern int switch_core_speech_feed_tts(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_rwlock_get")]
+  public static extern IntPtr switch_asr_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_flush_tts")]
-  public static extern void switch_core_speech_flush_tts(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_next_set")]
+  public static extern void switch_asr_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_text_param_tts")]
-  public static extern void switch_core_speech_text_param_tts(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_next_get")]
+  public static extern IntPtr switch_asr_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_numeric_param_tts")]
-  public static extern void switch_core_speech_numeric_param_tts(HandleRef jarg1, string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_asr_interface")]
+  public static extern IntPtr new_switch_asr_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_float_param_tts")]
-  public static extern void switch_core_speech_float_param_tts(HandleRef jarg1, string jarg2, double jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_asr_interface")]
+  public static extern void delete_switch_asr_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_read_tts")]
-  public static extern int switch_core_speech_read_tts(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_asr_interface_set")]
+  public static extern void switch_asr_handle_asr_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_speech_close")]
-  public static extern int switch_core_speech_close(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_asr_interface_get")]
+  public static extern IntPtr switch_asr_handle_asr_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_open")]
-  public static extern int switch_core_asr_open(HandleRef jarg1, string jarg2, string jarg3, int jarg4, string jarg5, HandleRef jarg6, HandleRef jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_flags_set")]
+  public static extern void switch_asr_handle_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_close")]
-  public static extern int switch_core_asr_close(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_flags_get")]
+  public static extern uint switch_asr_handle_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_feed")]
-  public static extern int switch_core_asr_feed(HandleRef jarg1, HandleRef jarg2, uint jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_name_set")]
+  public static extern void switch_asr_handle_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_check_results")]
-  public static extern int switch_core_asr_check_results(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_name_get")]
+  public static extern string switch_asr_handle_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_get_results")]
-  public static extern int switch_core_asr_get_results(HandleRef jarg1, ref string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_codec_set")]
+  public static extern void switch_asr_handle_codec_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_load_grammar")]
-  public static extern int switch_core_asr_load_grammar(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_codec_get")]
+  public static extern string switch_asr_handle_codec_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_unload_grammar")]
-  public static extern int switch_core_asr_unload_grammar(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_rate_set")]
+  public static extern void switch_asr_handle_rate_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_pause")]
-  public static extern int switch_core_asr_pause(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_rate_get")]
+  public static extern uint switch_asr_handle_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_asr_resume")]
-  public static extern int switch_core_asr_resume(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_grammar_set")]
+  public static extern void switch_asr_handle_grammar_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_open")]
-  public static extern int switch_core_directory_open(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_grammar_get")]
+  public static extern string switch_asr_handle_grammar_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_query")]
-  public static extern int switch_core_directory_query(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_param_set")]
+  public static extern void switch_asr_handle_param_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_next")]
-  public static extern int switch_core_directory_next(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_param_get")]
+  public static extern string switch_asr_handle_param_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_next_pair")]
-  public static extern int switch_core_directory_next_pair(HandleRef jarg1, ref string jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_memory_pool_set")]
+  public static extern void switch_asr_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_directory_close")]
-  public static extern int switch_core_directory_close(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_memory_pool_get")]
+  public static extern IntPtr switch_asr_handle_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_data_channel")]
-  public static extern IntPtr switch_core_data_channel(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_private_info_set")]
+  public static extern void switch_asr_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_ready")]
-  public static extern int switch_core_ready();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_private_info_get")]
+  public static extern IntPtr switch_asr_handle_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_flags")]
-  public static extern uint switch_core_flags();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_asr_handle")]
+  public static extern IntPtr new_switch_asr_handle();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_management_exec")]
-  public static extern int switch_core_management_exec(string jarg1, int jarg2, string jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_asr_handle")]
+  public static extern void delete_switch_asr_handle(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_set_high_priority")]
-  public static extern int set_high_priority();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_interface_name_set")]
+  public static extern void switch_speech_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_change_user_group")]
-  public static extern int change_user_group(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_interface_name_get")]
+  public static extern string switch_speech_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_runtime_loop")]
-  public static extern void switch_core_runtime_loop(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_open_set")]
+  public static extern void switch_speech_interface_speech_open_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_console")]
-  public static extern int switch_core_set_console(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_open_get")]
+  public static extern IntPtr switch_speech_interface_speech_open_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_measure_time")]
-  public static extern void switch_core_measure_time(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_close_set")]
+  public static extern void switch_speech_interface_speech_close_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_uptime")]
-  public static extern IntPtr switch_core_uptime();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_close_get")]
+  public static extern IntPtr switch_speech_interface_speech_close_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_ctl")]
-  public static extern int switch_core_session_ctl(int jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_feed_tts_set")]
+  public static extern void switch_speech_interface_speech_feed_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_get_console")]
-  public static extern IntPtr switch_core_get_console();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_feed_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_feed_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_launch_thread")]
-  public static extern void switch_core_launch_thread(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_read_tts_set")]
+  public static extern void switch_speech_interface_speech_read_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_set_globals")]
-  public static extern void switch_core_set_globals();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_read_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_read_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_compare")]
-  public static extern byte switch_core_session_compare(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_flush_tts_set")]
+  public static extern void switch_speech_interface_speech_flush_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_session_check_interface")]
-  public static extern byte switch_core_session_check_interface(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_flush_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_flush_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_index")]
-  public static extern IntPtr switch_core_mime_index();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_text_param_tts_set")]
+  public static extern void switch_speech_interface_speech_text_param_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_ext2type")]
-  public static extern string switch_core_mime_ext2type(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_text_param_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_text_param_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_mime_add_type")]
-  public static extern int switch_core_mime_add_type(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_numeric_param_tts_set")]
+  public static extern void switch_speech_interface_speech_numeric_param_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_create_module_interface")]
-  public static extern IntPtr switch_loadable_module_create_module_interface(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_numeric_param_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_numeric_param_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_loadable_module_create_interface")]
-  public static extern IntPtr switch_loadable_module_create_interface(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_float_param_tts_set")]
+  public static extern void switch_speech_interface_speech_float_param_tts_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timestamp_now")]
-  public static extern IntPtr switch_timestamp_now();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_float_param_tts_get")]
+  public static extern IntPtr switch_speech_interface_speech_float_param_tts_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim")]
-  public static extern void switch_core_memory_reclaim();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_rwlock_set")]
+  public static extern void switch_speech_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_events")]
-  public static extern void switch_core_memory_reclaim_events();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_rwlock_get")]
+  public static extern IntPtr switch_speech_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_logger")]
-  public static extern void switch_core_memory_reclaim_logger();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_next_set")]
+  public static extern void switch_speech_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_memory_reclaim_all")]
-  public static extern void switch_core_memory_reclaim_all();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_next_get")]
+  public static extern IntPtr switch_speech_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_setrlimits")]
-  public static extern void switch_core_setrlimits();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_speech_interface")]
+  public static extern IntPtr new_switch_speech_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_time_sync")]
-  public static extern void switch_time_sync();
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_speech_interface")]
+  public static extern void delete_switch_speech_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timestamp")]
-  public static extern IntPtr switch_timestamp(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speech_interface_set")]
+  public static extern void switch_speech_handle_speech_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_load_network_lists")]
-  public static extern void switch_load_network_lists(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speech_interface_get")]
+  public static extern IntPtr switch_speech_handle_speech_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_check_network_list_ip_token")]
-  public static extern int switch_check_network_list_ip_token(string jarg1, string jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_flags_set")]
+  public static extern void switch_speech_handle_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_time_set_monotonic")]
-  public static extern void switch_time_set_monotonic(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_flags_get")]
+  public static extern uint switch_speech_handle_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_max_dtmf_duration")]
-  public static extern uint switch_core_max_dtmf_duration(uint jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_name_set")]
+  public static extern void switch_speech_handle_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_default_dtmf_duration")]
-  public static extern uint switch_core_default_dtmf_duration(uint jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_name_get")]
+  public static extern string switch_speech_handle_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_set_complete")]
-  public static extern int switch_console_set_complete(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_rate_set")]
+  public static extern void switch_speech_handle_rate_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_set_alias")]
-  public static extern int switch_console_set_alias(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_rate_get")]
+  public static extern uint switch_speech_handle_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_CMD_CHUNK_LEN_get")]
-  public static extern int SWITCH_CMD_CHUNK_LEN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speed_set")]
+  public static extern void switch_speech_handle_speed_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_loop")]
-  public static extern void switch_console_loop();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speed_get")]
+  public static extern uint switch_speech_handle_speed_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_console_stream_raw_write")]
-  public static extern int switch_console_stream_raw_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_samples_set")]
+  public static extern void switch_speech_handle_samples_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SMAX_get")]
-  public static extern int SWITCH_SMAX_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_samples_get")]
+  public static extern uint switch_speech_handle_samples_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_SMIN_get")]
-  public static extern int SWITCH_SMIN_get();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_voice_set")]
+  public static extern void switch_speech_handle_voice_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_moh")]
-  public static extern int switch_is_moh(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_voice_get")]
+  public static extern string switch_speech_handle_voice_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_b64_encode")]
-  public static extern int switch_b64_encode(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_engine_set")]
+  public static extern void switch_speech_handle_engine_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_b64_decode")]
-  public static extern IntPtr switch_b64_decode(string jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_engine_get")]
+  public static extern string switch_speech_handle_engine_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_amp_encode")]
-  public static extern string switch_amp_encode(string jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_param_set")]
+  public static extern void switch_speech_handle_param_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_digit_string")]
-  public static extern int switch_is_digit_string(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_param_get")]
+  public static extern string switch_speech_handle_param_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_fd_read_line")]
-  public static extern IntPtr switch_fd_read_line(int jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_memory_pool_set")]
+  public static extern void switch_speech_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_find_local_ip")]
-  public static extern int switch_find_local_ip(string jarg1, int jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_memory_pool_get")]
+  public static extern IntPtr switch_speech_handle_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_get_addr")]
-  public static extern string get_addr(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_private_info_set")]
+  public static extern void switch_speech_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_get_port")]
-  public static extern ushort get_port(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_private_info_get")]
+  public static extern IntPtr switch_speech_handle_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_build_uri")]
-  public static extern int switch_build_uri(string jarg1, HandleRef jarg2, string jarg3, string jarg4, HandleRef jarg5, int jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_speech_handle")]
+  public static extern IntPtr new_switch_speech_handle();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_priority_name")]
-  public static extern string switch_priority_name(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_speech_handle")]
+  public static extern void delete_switch_speech_handle(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rfc2833_to_char")]
-  public static extern char switch_rfc2833_to_char(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_interface_name_set")]
+  public static extern void switch_say_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_char_to_rfc2833")]
-  public static extern byte switch_char_to_rfc2833(char jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_interface_name_get")]
+  public static extern string switch_say_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_clean_string")]
-  public static extern string switch_clean_string(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_say_function_set")]
+  public static extern void switch_say_interface_say_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_safe_strdup")]
-  public static extern string switch_safe_strdup(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_say_function_get")]
+  public static extern IntPtr switch_say_interface_say_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_strstr")]
-  public static extern int switch_strstr(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_rwlock_set")]
+  public static extern void switch_say_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_str_time")]
-  public static extern IntPtr switch_str_time(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_rwlock_get")]
+  public static extern IntPtr switch_say_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_separate_string")]
-  public static extern uint switch_separate_string(string jarg1, char jarg2, ref string jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_next_set")]
+  public static extern void switch_say_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_number")]
-  public static extern int switch_is_number(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_next_get")]
+  public static extern IntPtr switch_say_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_strip_spaces")]
-  public static extern string switch_strip_spaces(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_say_interface")]
+  public static extern IntPtr new_switch_say_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_separate_paren_args")]
-  public static extern string switch_separate_paren_args(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_say_interface")]
+  public static extern void delete_switch_say_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stristr")]
-  public static extern string switch_stristr(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_interface_name_set")]
+  public static extern void switch_chat_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_is_lan_addr")]
-  public static extern int switch_is_lan_addr(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_interface_name_get")]
+  public static extern string switch_chat_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_replace_char")]
-  public static extern string switch_replace_char(string jarg1, char jarg2, char jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_chat_send_set")]
+  public static extern void switch_chat_interface_chat_send_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ast2regex")]
-  public static extern int switch_ast2regex(string jarg1, string jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_chat_send_get")]
+  public static extern IntPtr switch_chat_interface_chat_send_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_escape_char")]
-  public static extern string switch_escape_char(HandleRef jarg1, string jarg2, string jarg3, char jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_rwlock_set")]
+  public static extern void switch_chat_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_socket_waitfor")]
-  public static extern int switch_socket_waitfor(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_rwlock_get")]
+  public static extern IntPtr switch_chat_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_cut_path")]
-  public static extern string switch_cut_path(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_next_set")]
+  public static extern void switch_chat_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_string_replace")]
-  public static extern string switch_string_replace(string jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_next_get")]
+  public static extern IntPtr switch_chat_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_string_match")]
-  public static extern int switch_string_match(string jarg1, uint jarg2, string jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_chat_interface")]
+  public static extern IntPtr new_switch_chat_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_url_encode")]
-  public static extern uint switch_url_encode(string jarg1, string jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_chat_interface")]
+  public static extern void delete_switch_chat_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_url_decode")]
-  public static extern string switch_url_decode(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_relative_oid_set")]
+  public static extern void switch_management_interface_relative_oid_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_simple_email")]
-  public static extern int switch_simple_email(string jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_relative_oid_get")]
+  public static extern string switch_management_interface_relative_oid_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_find_end_paren")]
-  public static extern string switch_find_end_paren(string jarg1, char jarg2, char jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_management_function_set")]
+  public static extern void switch_management_interface_management_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_parse_cidr")]
-  public static extern int switch_parse_cidr(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_management_function_get")]
+  public static extern IntPtr switch_management_interface_management_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_create")]
-  public static extern int switch_network_list_create(HandleRef jarg1, int jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_rwlock_set")]
+  public static extern void switch_management_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_add_cidr_token")]
-  public static extern int switch_network_list_add_cidr_token(HandleRef jarg1, string jarg2, int jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_rwlock_get")]
+  public static extern IntPtr switch_management_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_add_host_mask")]
-  public static extern int switch_network_list_add_host_mask(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_next_set")]
+  public static extern void switch_management_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_network_list_validate_ip_token")]
-  public static extern int switch_network_list_validate_ip_token(HandleRef jarg1, uint jarg2, ref string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_next_get")]
+  public static extern IntPtr switch_management_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_username_set")]
-  public static extern void switch_caller_profile_username_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_management_interface")]
+  public static extern IntPtr new_switch_management_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_username_get")]
-  public static extern string switch_caller_profile_username_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_management_interface")]
+  public static extern void delete_switch_management_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dialplan_set")]
-  public static extern void switch_caller_profile_dialplan_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_interface_name_set")]
+  public static extern void switch_directory_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dialplan_get")]
-  public static extern string switch_caller_profile_dialplan_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_interface_name_get")]
+  public static extern string switch_directory_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_name_set")]
-  public static extern void switch_caller_profile_caller_id_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_open_set")]
+  public static extern void switch_directory_interface_directory_open_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_name_get")]
-  public static extern string switch_caller_profile_caller_id_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_open_get")]
+  public static extern IntPtr switch_directory_interface_directory_open_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_number_set")]
-  public static extern void switch_caller_profile_caller_id_number_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_close_set")]
+  public static extern void switch_directory_interface_directory_close_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_id_number_get")]
-  public static extern string switch_caller_profile_caller_id_number_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_close_get")]
+  public static extern IntPtr switch_directory_interface_directory_close_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_ton_set")]
-  public static extern void switch_caller_profile_caller_ton_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_query_set")]
+  public static extern void switch_directory_interface_directory_query_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_ton_get")]
-  public static extern byte switch_caller_profile_caller_ton_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_query_get")]
+  public static extern IntPtr switch_directory_interface_directory_query_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_numplan_set")]
-  public static extern void switch_caller_profile_caller_numplan_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_set")]
+  public static extern void switch_directory_interface_directory_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_numplan_get")]
-  public static extern byte switch_caller_profile_caller_numplan_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_get")]
+  public static extern IntPtr switch_directory_interface_directory_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_network_addr_set")]
-  public static extern void switch_caller_profile_network_addr_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_pair_set")]
+  public static extern void switch_directory_interface_directory_next_pair_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_network_addr_get")]
-  public static extern string switch_caller_profile_network_addr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_pair_get")]
+  public static extern IntPtr switch_directory_interface_directory_next_pair_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_set")]
-  public static extern void switch_caller_profile_ani_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_rwlock_set")]
+  public static extern void switch_directory_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_get")]
-  public static extern string switch_caller_profile_ani_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_rwlock_get")]
+  public static extern IntPtr switch_directory_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_ton_set")]
-  public static extern void switch_caller_profile_ani_ton_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_next_set")]
+  public static extern void switch_directory_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_ton_get")]
-  public static extern byte switch_caller_profile_ani_ton_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_next_get")]
+  public static extern IntPtr switch_directory_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_numplan_set")]
-  public static extern void switch_caller_profile_ani_numplan_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directory_interface")]
+  public static extern IntPtr new_switch_directory_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_ani_numplan_get")]
-  public static extern byte switch_caller_profile_ani_numplan_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directory_interface")]
+  public static extern void delete_switch_directory_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_aniii_set")]
-  public static extern void switch_caller_profile_aniii_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_directory_interface_set")]
+  public static extern void switch_directory_handle_directory_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_aniii_get")]
-  public static extern string switch_caller_profile_aniii_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_directory_interface_get")]
+  public static extern IntPtr switch_directory_handle_directory_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_set")]
-  public static extern void switch_caller_profile_rdnis_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_flags_set")]
+  public static extern void switch_directory_handle_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_get")]
-  public static extern string switch_caller_profile_rdnis_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_flags_get")]
+  public static extern uint switch_directory_handle_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_ton_set")]
-  public static extern void switch_caller_profile_rdnis_ton_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_memory_pool_set")]
+  public static extern void switch_directory_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_ton_get")]
-  public static extern byte switch_caller_profile_rdnis_ton_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_memory_pool_get")]
+  public static extern IntPtr switch_directory_handle_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_numplan_set")]
-  public static extern void switch_caller_profile_rdnis_numplan_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_private_info_set")]
+  public static extern void switch_directory_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_rdnis_numplan_get")]
-  public static extern byte switch_caller_profile_rdnis_numplan_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_private_info_get")]
+  public static extern IntPtr switch_directory_handle_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_set")]
-  public static extern void switch_caller_profile_destination_number_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directory_handle")]
+  public static extern IntPtr new_switch_directory_handle();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_get")]
-  public static extern string switch_caller_profile_destination_number_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directory_handle")]
+  public static extern void delete_switch_directory_handle(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_ton_set")]
-  public static extern void switch_caller_profile_destination_number_ton_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_quality_set")]
+  public static extern void switch_codec_settings_quality_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_ton_get")]
-  public static extern byte switch_caller_profile_destination_number_ton_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_quality_get")]
+  public static extern int switch_codec_settings_quality_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_numplan_set")]
-  public static extern void switch_caller_profile_destination_number_numplan_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_complexity_set")]
+  public static extern void switch_codec_settings_complexity_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_destination_number_numplan_get")]
-  public static extern byte switch_caller_profile_destination_number_numplan_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_complexity_get")]
+  public static extern int switch_codec_settings_complexity_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_source_set")]
-  public static extern void switch_caller_profile_source_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_enhancement_set")]
+  public static extern void switch_codec_settings_enhancement_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_source_get")]
-  public static extern string switch_caller_profile_source_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_enhancement_get")]
+  public static extern int switch_codec_settings_enhancement_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_chan_name_set")]
-  public static extern void switch_caller_profile_chan_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vad_set")]
+  public static extern void switch_codec_settings_vad_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_chan_name_get")]
-  public static extern string switch_caller_profile_chan_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vad_get")]
+  public static extern int switch_codec_settings_vad_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_uuid_set")]
-  public static extern void switch_caller_profile_uuid_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_set")]
+  public static extern void switch_codec_settings_vbr_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_uuid_get")]
-  public static extern string switch_caller_profile_uuid_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_get")]
+  public static extern int switch_codec_settings_vbr_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_context_set")]
-  public static extern void switch_caller_profile_context_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_quality_set")]
+  public static extern void switch_codec_settings_vbr_quality_set(HandleRef jarg1, float jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_context_get")]
-  public static extern string switch_caller_profile_context_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_quality_get")]
+  public static extern float switch_codec_settings_vbr_quality_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_profile_index_set")]
-  public static extern void switch_caller_profile_profile_index_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_abr_set")]
+  public static extern void switch_codec_settings_abr_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_profile_index_get")]
-  public static extern string switch_caller_profile_profile_index_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_abr_get")]
+  public static extern int switch_codec_settings_abr_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_flags_set")]
-  public static extern void switch_caller_profile_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_dtx_set")]
+  public static extern void switch_codec_settings_dtx_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_flags_get")]
-  public static extern uint switch_caller_profile_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_dtx_get")]
+  public static extern int switch_codec_settings_dtx_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originator_caller_profile_set")]
-  public static extern void switch_caller_profile_originator_caller_profile_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_preproc_set")]
+  public static extern void switch_codec_settings_preproc_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originator_caller_profile_get")]
-  public static extern IntPtr switch_caller_profile_originator_caller_profile_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_preproc_get")]
+  public static extern int switch_codec_settings_preproc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originatee_caller_profile_set")]
-  public static extern void switch_caller_profile_originatee_caller_profile_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_vad_set")]
+  public static extern void switch_codec_settings_pp_vad_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_originatee_caller_profile_get")]
-  public static extern IntPtr switch_caller_profile_originatee_caller_profile_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_vad_get")]
+  public static extern int switch_codec_settings_pp_vad_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_times_set")]
-  public static extern void switch_caller_profile_times_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_set")]
+  public static extern void switch_codec_settings_pp_agc_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_times_get")]
-  public static extern IntPtr switch_caller_profile_times_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_get")]
+  public static extern int switch_codec_settings_pp_agc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_extension_set")]
-  public static extern void switch_caller_profile_caller_extension_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_level_set")]
+  public static extern void switch_codec_settings_pp_agc_level_set(HandleRef jarg1, float jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_caller_extension_get")]
-  public static extern IntPtr switch_caller_profile_caller_extension_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_level_get")]
+  public static extern float switch_codec_settings_pp_agc_level_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_pool_set")]
-  public static extern void switch_caller_profile_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_denoise_set")]
+  public static extern void switch_codec_settings_pp_denoise_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_pool_get")]
-  public static extern IntPtr switch_caller_profile_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_denoise_get")]
+  public static extern int switch_codec_settings_pp_denoise_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_next_set")]
-  public static extern void switch_caller_profile_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_set")]
+  public static extern void switch_codec_settings_pp_dereverb_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_next_get")]
-  public static extern IntPtr switch_caller_profile_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_get")]
+  public static extern int switch_codec_settings_pp_dereverb_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_profile")]
-  public static extern IntPtr new_switch_caller_profile();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_decay_set")]
+  public static extern void switch_codec_settings_pp_dereverb_decay_set(HandleRef jarg1, float jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_profile")]
-  public static extern void delete_switch_caller_profile(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_decay_get")]
+  public static extern float switch_codec_settings_pp_dereverb_decay_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_name_set")]
-  public static extern void switch_caller_application_application_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_level_set")]
+  public static extern void switch_codec_settings_pp_dereverb_level_set(HandleRef jarg1, float jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_name_get")]
-  public static extern string switch_caller_application_application_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_level_get")]
+  public static extern float switch_codec_settings_pp_dereverb_level_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_data_set")]
-  public static extern void switch_caller_application_application_data_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_settings")]
+  public static extern IntPtr new_switch_codec_settings();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_data_get")]
-  public static extern string switch_caller_application_application_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_settings")]
+  public static extern void delete_switch_codec_settings(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_function_set")]
-  public static extern void switch_caller_application_application_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_interface_set")]
+  public static extern void switch_codec_codec_interface_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_application_function_get")]
-  public static extern IntPtr switch_caller_application_application_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_interface_get")]
+  public static extern IntPtr switch_codec_codec_interface_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_next_set")]
-  public static extern void switch_caller_application_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_set")]
+  public static extern void switch_codec_implementation_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_application_next_get")]
-  public static extern IntPtr switch_caller_application_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_get")]
+  public static extern IntPtr switch_codec_implementation_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_application")]
-  public static extern IntPtr new_switch_caller_application();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_in_set")]
+  public static extern void switch_codec_fmtp_in_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_application")]
-  public static extern void delete_switch_caller_application(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_in_get")]
+  public static extern string switch_codec_fmtp_in_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_name_set")]
-  public static extern void switch_caller_extension_extension_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_out_set")]
+  public static extern void switch_codec_fmtp_out_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_name_get")]
-  public static extern string switch_caller_extension_extension_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_out_get")]
+  public static extern string switch_codec_fmtp_out_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_number_set")]
-  public static extern void switch_caller_extension_extension_number_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_settings_set")]
+  public static extern void switch_codec_codec_settings_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_extension_number_get")]
-  public static extern string switch_caller_extension_extension_number_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_settings_get")]
+  public static extern IntPtr switch_codec_codec_settings_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_current_application_set")]
-  public static extern void switch_caller_extension_current_application_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_flags_set")]
+  public static extern void switch_codec_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_current_application_get")]
-  public static extern IntPtr switch_caller_extension_current_application_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_flags_get")]
+  public static extern uint switch_codec_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_last_application_set")]
-  public static extern void switch_caller_extension_last_application_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_memory_pool_set")]
+  public static extern void switch_codec_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_last_application_get")]
-  public static extern IntPtr switch_caller_extension_last_application_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_memory_pool_get")]
+  public static extern IntPtr switch_codec_memory_pool_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_applications_set")]
-  public static extern void switch_caller_extension_applications_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_private_info_set")]
+  public static extern void switch_codec_private_info_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_applications_get")]
-  public static extern IntPtr switch_caller_extension_applications_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_private_info_get")]
+  public static extern IntPtr switch_codec_private_info_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_children_set")]
-  public static extern void switch_caller_extension_children_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_agreed_pt_set")]
+  public static extern void switch_codec_agreed_pt_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_children_get")]
-  public static extern IntPtr switch_caller_extension_children_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_agreed_pt_get")]
+  public static extern byte switch_codec_agreed_pt_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_next_set")]
-  public static extern void switch_caller_extension_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec")]
+  public static extern IntPtr new_switch_codec();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_next_get")]
-  public static extern IntPtr switch_caller_extension_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec")]
+  public static extern void delete_switch_codec(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_caller_extension")]
-  public static extern IntPtr new_switch_caller_extension();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_type_set")]
+  public static extern void switch_codec_implementation_codec_type_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_caller_extension")]
-  public static extern void delete_switch_caller_extension(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_type_get")]
+  public static extern int switch_codec_implementation_codec_type_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_new")]
-  public static extern IntPtr switch_caller_extension_new(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_ianacode_set")]
+  public static extern void switch_codec_implementation_ianacode_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_clone")]
-  public static extern int switch_caller_extension_clone(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_ianacode_get")]
+  public static extern byte switch_codec_implementation_ianacode_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_extension_add_application")]
-  public static extern void switch_caller_extension_add_application(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_iananame_set")]
+  public static extern void switch_codec_implementation_iananame_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_get_field_by_name")]
-  public static extern string switch_caller_get_field_by_name(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_iananame_get")]
+  public static extern string switch_codec_implementation_iananame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_new")]
-  public static extern IntPtr switch_caller_profile_new(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, string jarg10, string jarg11, string jarg12);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_fmtp_set")]
+  public static extern void switch_codec_implementation_fmtp_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_clone")]
-  public static extern IntPtr switch_caller_profile_clone(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_fmtp_get")]
+  public static extern string switch_codec_implementation_fmtp_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_dup")]
-  public static extern IntPtr switch_caller_profile_dup(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_second_set")]
+  public static extern void switch_codec_implementation_samples_per_second_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_caller_profile_event_set_data")]
-  public static extern void switch_caller_profile_event_set_data(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_second_get")]
+  public static extern uint switch_codec_implementation_samples_per_second_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_codec_set")]
-  public static extern void switch_frame_codec_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_actual_samples_per_second_set")]
+  public static extern void switch_codec_implementation_actual_samples_per_second_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_codec_get")]
-  public static extern IntPtr switch_frame_codec_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_actual_samples_per_second_get")]
+  public static extern uint switch_codec_implementation_actual_samples_per_second_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_source_set")]
-  public static extern void switch_frame_source_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bits_per_second_set")]
+  public static extern void switch_codec_implementation_bits_per_second_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_source_get")]
-  public static extern string switch_frame_source_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bits_per_second_get")]
+  public static extern int switch_codec_implementation_bits_per_second_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packet_set")]
-  public static extern void switch_frame_packet_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_microseconds_per_frame_set")]
+  public static extern void switch_codec_implementation_microseconds_per_frame_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packet_get")]
-  public static extern IntPtr switch_frame_packet_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_microseconds_per_frame_get")]
+  public static extern int switch_codec_implementation_microseconds_per_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packetlen_set")]
-  public static extern void switch_frame_packetlen_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_frame_set")]
+  public static extern void switch_codec_implementation_samples_per_frame_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_packetlen_get")]
-  public static extern uint switch_frame_packetlen_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_frame_get")]
+  public static extern uint switch_codec_implementation_samples_per_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_data_set")]
-  public static extern void switch_frame_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bytes_per_frame_set")]
+  public static extern void switch_codec_implementation_bytes_per_frame_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_data_get")]
-  public static extern IntPtr switch_frame_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bytes_per_frame_get")]
+  public static extern uint switch_codec_implementation_bytes_per_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_datalen_set")]
-  public static extern void switch_frame_datalen_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encoded_bytes_per_frame_set")]
+  public static extern void switch_codec_implementation_encoded_bytes_per_frame_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_datalen_get")]
-  public static extern uint switch_frame_datalen_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encoded_bytes_per_frame_get")]
+  public static extern uint switch_codec_implementation_encoded_bytes_per_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_buflen_set")]
-  public static extern void switch_frame_buflen_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_number_of_channels_set")]
+  public static extern void switch_codec_implementation_number_of_channels_set(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_buflen_get")]
-  public static extern uint switch_frame_buflen_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_number_of_channels_get")]
+  public static extern byte switch_codec_implementation_number_of_channels_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_samples_set")]
-  public static extern void switch_frame_samples_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_pref_frames_per_packet_set")]
+  public static extern void switch_codec_implementation_pref_frames_per_packet_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_samples_get")]
-  public static extern uint switch_frame_samples_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_pref_frames_per_packet_get")]
+  public static extern int switch_codec_implementation_pref_frames_per_packet_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_rate_set")]
-  public static extern void switch_frame_rate_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_max_frames_per_packet_set")]
+  public static extern void switch_codec_implementation_max_frames_per_packet_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_rate_get")]
-  public static extern uint switch_frame_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_max_frames_per_packet_get")]
+  public static extern int switch_codec_implementation_max_frames_per_packet_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_payload_set")]
-  public static extern void switch_frame_payload_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_init_set")]
+  public static extern void switch_codec_implementation_init_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_payload_get")]
-  public static extern byte switch_frame_payload_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_init_get")]
+  public static extern IntPtr switch_codec_implementation_init_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_timestamp_set")]
-  public static extern void switch_frame_timestamp_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encode_set")]
+  public static extern void switch_codec_implementation_encode_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_timestamp_get")]
-  public static extern IntPtr switch_frame_timestamp_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encode_get")]
+  public static extern IntPtr switch_codec_implementation_encode_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_seq_set")]
-  public static extern void switch_frame_seq_set(HandleRef jarg1, ushort jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_decode_set")]
+  public static extern void switch_codec_implementation_decode_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_seq_get")]
-  public static extern ushort switch_frame_seq_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_decode_get")]
+  public static extern IntPtr switch_codec_implementation_decode_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_ssrc_set")]
-  public static extern void switch_frame_ssrc_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_destroy_set")]
+  public static extern void switch_codec_implementation_destroy_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_ssrc_get")]
-  public static extern uint switch_frame_ssrc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_destroy_get")]
+  public static extern IntPtr switch_codec_implementation_destroy_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_m_set")]
-  public static extern void switch_frame_m_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_id_set")]
+  public static extern void switch_codec_implementation_codec_id_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_m_get")]
-  public static extern int switch_frame_m_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_id_get")]
+  public static extern uint switch_codec_implementation_codec_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_flags_set")]
-  public static extern void switch_frame_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_next_set")]
+  public static extern void switch_codec_implementation_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_frame_flags_get")]
-  public static extern uint switch_frame_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_next_get")]
+  public static extern IntPtr switch_codec_implementation_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_frame")]
-  public static extern IntPtr new_switch_frame();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_implementation")]
+  public static extern IntPtr new_switch_codec_implementation();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_frame")]
-  public static extern void delete_switch_frame(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_implementation")]
+  public static extern void delete_switch_codec_implementation(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_init_set")]
-  public static extern void switch_state_handler_table_on_init_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_interface_name_set")]
+  public static extern void switch_codec_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_init_get")]
-  public static extern IntPtr switch_state_handler_table_on_init_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_interface_name_get")]
+  public static extern string switch_codec_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_routing_set")]
-  public static extern void switch_state_handler_table_on_routing_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_implementations_set")]
+  public static extern void switch_codec_interface_implementations_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_routing_get")]
-  public static extern IntPtr switch_state_handler_table_on_routing_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_implementations_get")]
+  public static extern IntPtr switch_codec_interface_implementations_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_execute_set")]
-  public static extern void switch_state_handler_table_on_execute_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_codec_id_set")]
+  public static extern void switch_codec_interface_codec_id_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_execute_get")]
-  public static extern IntPtr switch_state_handler_table_on_execute_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_codec_id_get")]
+  public static extern uint switch_codec_interface_codec_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hangup_set")]
-  public static extern void switch_state_handler_table_on_hangup_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_rwlock_set")]
+  public static extern void switch_codec_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hangup_get")]
-  public static extern IntPtr switch_state_handler_table_on_hangup_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_rwlock_get")]
+  public static extern IntPtr switch_codec_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_exchange_media_set")]
-  public static extern void switch_state_handler_table_on_exchange_media_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_next_set")]
+  public static extern void switch_codec_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_exchange_media_get")]
-  public static extern IntPtr switch_state_handler_table_on_exchange_media_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_next_get")]
+  public static extern IntPtr switch_codec_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_soft_execute_set")]
-  public static extern void switch_state_handler_table_on_soft_execute_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_interface")]
+  public static extern IntPtr new_switch_codec_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_soft_execute_get")]
-  public static extern IntPtr switch_state_handler_table_on_soft_execute_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_interface")]
+  public static extern void delete_switch_codec_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_consume_media_set")]
-  public static extern void switch_state_handler_table_on_consume_media_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_interface_name_set")]
+  public static extern void switch_application_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_consume_media_get")]
-  public static extern IntPtr switch_state_handler_table_on_consume_media_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_interface_name_get")]
+  public static extern string switch_application_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hibernate_set")]
-  public static extern void switch_state_handler_table_on_hibernate_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_application_function_set")]
+  public static extern void switch_application_interface_application_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_hibernate_get")]
-  public static extern IntPtr switch_state_handler_table_on_hibernate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_application_function_get")]
+  public static extern IntPtr switch_application_interface_application_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_reset_set")]
-  public static extern void switch_state_handler_table_on_reset_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_long_desc_set")]
+  public static extern void switch_application_interface_long_desc_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_reset_get")]
-  public static extern IntPtr switch_state_handler_table_on_reset_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_long_desc_get")]
+  public static extern string switch_application_interface_long_desc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_park_set")]
-  public static extern void switch_state_handler_table_on_park_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_short_desc_set")]
+  public static extern void switch_application_interface_short_desc_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_on_park_get")]
-  public static extern IntPtr switch_state_handler_table_on_park_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_short_desc_get")]
+  public static extern string switch_application_interface_short_desc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_padding_set")]
-  public static extern void switch_state_handler_table_padding_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_syntax_set")]
+  public static extern void switch_application_interface_syntax_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_state_handler_table_padding_get")]
-  public static extern IntPtr switch_state_handler_table_padding_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_syntax_get")]
+  public static extern string switch_application_interface_syntax_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_state_handler_table")]
-  public static extern IntPtr new_switch_state_handler_table();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_flags_set")]
+  public static extern void switch_application_interface_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_state_handler_table")]
-  public static extern void delete_switch_state_handler_table(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_flags_get")]
+  public static extern uint switch_application_interface_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_write_function_set")]
-  public static extern void switch_stream_handle_write_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_rwlock_set")]
+  public static extern void switch_application_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_write_function_get")]
-  public static extern IntPtr switch_stream_handle_write_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_rwlock_get")]
+  public static extern IntPtr switch_application_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_raw_write_function_set")]
-  public static extern void switch_stream_handle_raw_write_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_next_set")]
+  public static extern void switch_application_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_raw_write_function_get")]
-  public static extern IntPtr switch_stream_handle_raw_write_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_next_get")]
+  public static extern IntPtr switch_application_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_set")]
-  public static extern void switch_stream_handle_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_application_interface")]
+  public static extern IntPtr new_switch_application_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_get")]
-  public static extern IntPtr switch_stream_handle_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_application_interface")]
+  public static extern void delete_switch_application_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_end_set")]
-  public static extern void switch_stream_handle_end_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_interface_name_set")]
+  public static extern void switch_api_interface_interface_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_end_get")]
-  public static extern IntPtr switch_stream_handle_end_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_interface_name_get")]
+  public static extern string switch_api_interface_interface_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_size_set")]
-  public static extern void switch_stream_handle_data_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_desc_set")]
+  public static extern void switch_api_interface_desc_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_size_get")]
-  public static extern IntPtr switch_stream_handle_data_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_desc_get")]
+  public static extern string switch_api_interface_desc_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_len_set")]
-  public static extern void switch_stream_handle_data_len_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_function_set")]
+  public static extern void switch_api_interface_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_data_len_get")]
-  public static extern IntPtr switch_stream_handle_data_len_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_function_get")]
+  public static extern IntPtr switch_api_interface_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_len_set")]
-  public static extern void switch_stream_handle_alloc_len_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_syntax_set")]
+  public static extern void switch_api_interface_syntax_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_len_get")]
-  public static extern IntPtr switch_stream_handle_alloc_len_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_syntax_get")]
+  public static extern string switch_api_interface_syntax_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_chunk_set")]
-  public static extern void switch_stream_handle_alloc_chunk_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_rwlock_set")]
+  public static extern void switch_api_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_alloc_chunk_get")]
-  public static extern IntPtr switch_stream_handle_alloc_chunk_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_rwlock_get")]
+  public static extern IntPtr switch_api_interface_rwlock_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_param_event_set")]
-  public static extern void switch_stream_handle_param_event_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_next_set")]
+  public static extern void switch_api_interface_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_stream_handle_param_event_get")]
-  public static extern IntPtr switch_stream_handle_param_event_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_next_get")]
+  public static extern IntPtr switch_api_interface_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_stream_handle")]
-  public static extern IntPtr new_switch_stream_handle();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_api_interface")]
+  public static extern IntPtr new_switch_api_interface();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_stream_handle")]
-  public static extern void delete_switch_stream_handle(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_api_interface")]
+  public static extern void delete_switch_api_interface(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_outgoing_channel_set")]
-  public static extern void switch_io_routines_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_profile_created_set")]
+  public static extern void switch_channel_timetable_profile_created_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_outgoing_channel_get")]
-  public static extern IntPtr switch_io_routines_outgoing_channel_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_profile_created_get")]
+  public static extern IntPtr switch_channel_timetable_profile_created_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_frame_set")]
-  public static extern void switch_io_routines_read_frame_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_created_set")]
+  public static extern void switch_channel_timetable_created_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_frame_get")]
-  public static extern IntPtr switch_io_routines_read_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_created_get")]
+  public static extern IntPtr switch_channel_timetable_created_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_frame_set")]
-  public static extern void switch_io_routines_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_answered_set")]
+  public static extern void switch_channel_timetable_answered_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_frame_get")]
-  public static extern IntPtr switch_io_routines_write_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_answered_get")]
+  public static extern IntPtr switch_channel_timetable_answered_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_kill_channel_set")]
-  public static extern void switch_io_routines_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_set")]
+  public static extern void switch_channel_timetable_progress_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_kill_channel_get")]
-  public static extern IntPtr switch_io_routines_kill_channel_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_get")]
+  public static extern IntPtr switch_channel_timetable_progress_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_send_dtmf_set")]
-  public static extern void switch_io_routines_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_media_set")]
+  public static extern void switch_channel_timetable_progress_media_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_send_dtmf_get")]
-  public static extern IntPtr switch_io_routines_send_dtmf_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_media_get")]
+  public static extern IntPtr switch_channel_timetable_progress_media_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_message_set")]
-  public static extern void switch_io_routines_receive_message_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_hungup_set")]
+  public static extern void switch_channel_timetable_hungup_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_message_get")]
-  public static extern IntPtr switch_io_routines_receive_message_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_hungup_get")]
+  public static extern IntPtr switch_channel_timetable_hungup_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_event_set")]
-  public static extern void switch_io_routines_receive_event_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_transferred_set")]
+  public static extern void switch_channel_timetable_transferred_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_receive_event_get")]
-  public static extern IntPtr switch_io_routines_receive_event_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_transferred_get")]
+  public static extern IntPtr switch_channel_timetable_transferred_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_state_change_set")]
-  public static extern void switch_io_routines_state_change_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_next_set")]
+  public static extern void switch_channel_timetable_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_state_change_get")]
-  public static extern IntPtr switch_io_routines_state_change_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_next_get")]
+  public static extern IntPtr switch_channel_timetable_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_video_frame_set")]
-  public static extern void switch_io_routines_read_video_frame_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_channel_timetable")]
+  public static extern IntPtr new_switch_channel_timetable();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_read_video_frame_get")]
-  public static extern IntPtr switch_io_routines_read_video_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_channel_timetable")]
+  public static extern void delete_switch_channel_timetable(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_video_frame_set")]
-  public static extern void switch_io_routines_write_video_frame_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_state")]
+  public static extern int switch_channel_get_state(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_write_video_frame_get")]
-  public static extern IntPtr switch_io_routines_write_video_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_running_state")]
+  public static extern int switch_channel_get_running_state(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_resurrect_session_set")]
-  public static extern void switch_io_routines_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_ready")]
+  public static extern byte switch_channel_ready(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_resurrect_session_get")]
-  public static extern IntPtr switch_io_routines_resurrect_session_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_wait_for_state")]
+  public static extern void switch_channel_wait_for_state(HandleRef jarg1, HandleRef jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_padding_set")]
-  public static extern void switch_io_routines_padding_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_wait_for_flag")]
+  public static extern int switch_channel_wait_for_flag(HandleRef jarg1, uint jarg2, int jarg3, uint jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_routines_padding_get")]
-  public static extern IntPtr switch_io_routines_padding_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_set_state")]
+  public static extern int switch_channel_perform_set_state(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_routines")]
-  public static extern IntPtr new_switch_io_routines();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_set_running_state")]
+  public static extern int switch_channel_perform_set_running_state(HandleRef jarg1, int jarg2, string jarg3, string jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_routines")]
-  public static extern void delete_switch_io_routines(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_str2cause")]
+  public static extern int switch_channel_str2cause(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_interface_name_set")]
-  public static extern void switch_endpoint_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_cause")]
+  public static extern int switch_channel_get_cause(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_interface_name_get")]
-  public static extern string switch_endpoint_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_cause_q850")]
+  public static extern int switch_channel_cause_q850(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_io_routines_set")]
-  public static extern void switch_endpoint_interface_io_routines_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_cause_q850")]
+  public static extern int switch_channel_get_cause_q850(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_io_routines_get")]
-  public static extern IntPtr switch_endpoint_interface_io_routines_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_cause2str")]
+  public static extern string switch_channel_cause2str(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_state_handler_set")]
-  public static extern void switch_endpoint_interface_state_handler_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_timetable")]
+  public static extern IntPtr switch_channel_get_timetable(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_state_handler_get")]
-  public static extern IntPtr switch_endpoint_interface_state_handler_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_alloc")]
+  public static extern int switch_channel_alloc(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_private_info_set")]
-  public static extern void switch_endpoint_interface_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_init")]
+  public static extern int switch_channel_init(HandleRef jarg1, HandleRef jarg2, int jarg3, uint jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_private_info_get")]
-  public static extern IntPtr switch_endpoint_interface_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_presence")]
+  public static extern void switch_channel_presence(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_rwlock_set")]
-  public static extern void switch_endpoint_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_uninit")]
+  public static extern void switch_channel_uninit(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_rwlock_get")]
-  public static extern IntPtr switch_endpoint_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_caller_profile")]
+  public static extern void switch_channel_set_caller_profile(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_next_set")]
-  public static extern void switch_endpoint_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_caller_profile")]
+  public static extern IntPtr switch_channel_get_caller_profile(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_endpoint_interface_next_get")]
-  public static extern IntPtr switch_endpoint_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_originator_caller_profile")]
+  public static extern void switch_channel_set_originator_caller_profile(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_endpoint_interface")]
-  public static extern IntPtr new_switch_endpoint_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_originator_caller_profile")]
+  public static extern IntPtr switch_channel_get_originator_caller_profile(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_endpoint_interface")]
-  public static extern void delete_switch_endpoint_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_originatee_caller_profile")]
+  public static extern void switch_channel_set_originatee_caller_profile(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interval_set")]
-  public static extern void switch_timer_interval_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_originatee_caller_profile")]
+  public static extern IntPtr switch_channel_get_originatee_caller_profile(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interval_get")]
-  public static extern int switch_timer_interval_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_uuid")]
+  public static extern string switch_channel_get_uuid(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_flags_set")]
-  public static extern void switch_timer_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_variable")]
+  public static extern int switch_channel_set_variable(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_flags_get")]
-  public static extern uint switch_timer_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_variable_printf")]
+  public static extern int switch_channel_set_variable_printf(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samples_set")]
-  public static extern void switch_timer_samples_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_variable_partner")]
+  public static extern int switch_channel_set_variable_partner(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samples_get")]
-  public static extern uint switch_timer_samples_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variable_partner")]
+  public static extern string switch_channel_get_variable_partner(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samplecount_set")]
-  public static extern void switch_timer_samplecount_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variable")]
+  public static extern string switch_channel_get_variable(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_samplecount_get")]
-  public static extern uint switch_timer_samplecount_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variables")]
+  public static extern int switch_channel_get_variables(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_timer_interface_set")]
-  public static extern void switch_timer_timer_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_variable_first")]
+  public static extern IntPtr switch_channel_variable_first(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_timer_interface_get")]
-  public static extern IntPtr switch_timer_timer_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_variable_last")]
+  public static extern void switch_channel_variable_last(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_memory_pool_set")]
-  public static extern void switch_timer_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_caller_extension")]
+  public static extern void switch_channel_set_caller_extension(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_memory_pool_get")]
-  public static extern IntPtr switch_timer_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_caller_extension")]
+  public static extern IntPtr switch_channel_get_caller_extension(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_private_info_set")]
-  public static extern void switch_timer_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_test_flag")]
+  public static extern uint switch_channel_test_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_private_info_get")]
-  public static extern IntPtr switch_timer_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_flag")]
+  public static extern void switch_channel_set_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_diff_set")]
-  public static extern void switch_timer_diff_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_flag_partner")]
+  public static extern int switch_channel_set_flag_partner(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_diff_get")]
-  public static extern IntPtr switch_timer_diff_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_flag_partner")]
+  public static extern int switch_channel_clear_flag_partner(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_tick_set")]
-  public static extern void switch_timer_tick_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_state_flag")]
+  public static extern void switch_channel_set_state_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_tick_get")]
-  public static extern IntPtr switch_timer_tick_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_flag")]
+  public static extern void switch_channel_clear_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_timer")]
-  public static extern IntPtr new_switch_timer();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_answer")]
+  public static extern int switch_channel_perform_answer(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_timer")]
-  public static extern void delete_switch_timer(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_answered")]
+  public static extern int switch_channel_perform_mark_answered(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_interface_name_set")]
-  public static extern void switch_timer_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_ring_ready")]
+  public static extern int switch_channel_perform_ring_ready(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_interface_name_get")]
-  public static extern string switch_timer_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_pre_answer")]
+  public static extern int switch_channel_perform_pre_answer(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_init_set")]
-  public static extern void switch_timer_interface_timer_init_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_pre_answered")]
+  public static extern int switch_channel_perform_mark_pre_answered(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_init_get")]
-  public static extern IntPtr switch_timer_interface_timer_init_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_ring_ready")]
+  public static extern int switch_channel_perform_mark_ring_ready(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_next_set")]
-  public static extern void switch_timer_interface_timer_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_add_state_handler")]
+  public static extern int switch_channel_add_state_handler(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_next_get")]
-  public static extern IntPtr switch_timer_interface_timer_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_state_handler")]
+  public static extern void switch_channel_clear_state_handler(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_step_set")]
-  public static extern void switch_timer_interface_timer_step_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_state_handler")]
+  public static extern IntPtr switch_channel_get_state_handler(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_step_get")]
-  public static extern IntPtr switch_timer_interface_timer_step_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_private")]
+  public static extern int switch_channel_set_private(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_sync_set")]
-  public static extern void switch_timer_interface_timer_sync_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_private")]
+  public static extern IntPtr switch_channel_get_private(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_sync_get")]
-  public static extern IntPtr switch_timer_interface_timer_sync_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_name")]
+  public static extern int switch_channel_set_name(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_check_set")]
-  public static extern void switch_timer_interface_timer_check_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_name")]
+  public static extern string switch_channel_get_name(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_check_get")]
-  public static extern IntPtr switch_timer_interface_timer_check_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_hangup")]
+  public static extern int switch_channel_perform_hangup(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_destroy_set")]
-  public static extern void switch_timer_interface_timer_destroy_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_has_dtmf")]
+  public static extern IntPtr switch_channel_has_dtmf(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_timer_destroy_get")]
-  public static extern IntPtr switch_timer_interface_timer_destroy_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_queue_dtmf")]
+  public static extern int switch_channel_queue_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_rwlock_set")]
-  public static extern void switch_timer_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_queue_dtmf_string")]
+  public static extern int switch_channel_queue_dtmf_string(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_rwlock_get")]
-  public static extern IntPtr switch_timer_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_dequeue_dtmf")]
+  public static extern int switch_channel_dequeue_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_next_set")]
-  public static extern void switch_timer_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_flush_dtmf")]
+  public static extern void switch_channel_flush_dtmf(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_timer_interface_next_get")]
-  public static extern IntPtr switch_timer_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_dequeue_dtmf_string")]
+  public static extern IntPtr switch_channel_dequeue_dtmf_string(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_timer_interface")]
-  public static extern IntPtr new_switch_timer_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_state_name")]
+  public static extern string switch_channel_state_name(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_timer_interface")]
-  public static extern void delete_switch_timer_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_name_state")]
+  public static extern int switch_channel_name_state(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_interface_name_set")]
-  public static extern void switch_dialplan_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_event_set_data")]
+  public static extern void switch_channel_event_set_data(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_interface_name_get")]
-  public static extern string switch_dialplan_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_expand_variables")]
+  public static extern string switch_channel_expand_variables(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_hunt_function_set")]
-  public static extern void switch_dialplan_interface_hunt_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_build_param_string")]
+  public static extern string switch_channel_build_param_string(HandleRef jarg1, HandleRef jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_hunt_function_get")]
-  public static extern IntPtr switch_dialplan_interface_hunt_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_timestamps")]
+  public static extern int switch_channel_set_timestamps(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_rwlock_set")]
-  public static extern void switch_dialplan_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_create")]
+  public static extern int switch_buffer_create(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_rwlock_get")]
-  public static extern IntPtr switch_dialplan_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_create_dynamic")]
+  public static extern int switch_buffer_create_dynamic(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_next_set")]
-  public static extern void switch_dialplan_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_add_mutex")]
+  public static extern void switch_buffer_add_mutex(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_dialplan_interface_next_get")]
-  public static extern IntPtr switch_dialplan_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_lock")]
+  public static extern void switch_buffer_lock(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_dialplan_interface")]
-  public static extern IntPtr new_switch_dialplan_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_trylock")]
+  public static extern int switch_buffer_trylock(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_dialplan_interface")]
-  public static extern void delete_switch_dialplan_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_unlock")]
+  public static extern void switch_buffer_unlock(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_interface_name_set")]
-  public static extern void switch_file_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_len")]
+  public static extern IntPtr switch_buffer_len(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_interface_name_get")]
-  public static extern string switch_file_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_freespace")]
+  public static extern IntPtr switch_buffer_freespace(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_open_set")]
-  public static extern void switch_file_interface_file_open_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_inuse")]
+  public static extern IntPtr switch_buffer_inuse(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_open_get")]
-  public static extern IntPtr switch_file_interface_file_open_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_read")]
+  public static extern IntPtr switch_buffer_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_close_set")]
-  public static extern void switch_file_interface_file_close_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_read_loop")]
+  public static extern IntPtr switch_buffer_read_loop(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_close_get")]
-  public static extern IntPtr switch_file_interface_file_close_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_set_loops")]
+  public static extern void switch_buffer_set_loops(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_read_set")]
-  public static extern void switch_file_interface_file_read_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_write")]
+  public static extern IntPtr switch_buffer_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_read_get")]
-  public static extern IntPtr switch_file_interface_file_read_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_toss")]
+  public static extern IntPtr switch_buffer_toss(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_write_set")]
-  public static extern void switch_file_interface_file_write_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_zero")]
+  public static extern void switch_buffer_zero(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_write_get")]
-  public static extern IntPtr switch_file_interface_file_write_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_destroy")]
+  public static extern void switch_buffer_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_seek_set")]
-  public static extern void switch_file_interface_file_seek_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_zwrite")]
+  public static extern IntPtr switch_buffer_zwrite(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_seek_get")]
-  public static extern IntPtr switch_file_interface_file_seek_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_name_set")]
+  public static extern void switch_event_header_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_set_string_set")]
-  public static extern void switch_file_interface_file_set_string_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_name_get")]
+  public static extern string switch_event_header_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_set_string_get")]
-  public static extern IntPtr switch_file_interface_file_set_string_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_value_set")]
+  public static extern void switch_event_header_value_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_get_string_set")]
-  public static extern void switch_file_interface_file_get_string_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_value_get")]
+  public static extern string switch_event_header_value_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_file_get_string_get")]
-  public static extern IntPtr switch_file_interface_file_get_string_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_next_set")]
+  public static extern void switch_event_header_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_extens_set")]
-  public static extern void switch_file_interface_extens_set(HandleRef jarg1, ref string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_next_get")]
+  public static extern IntPtr switch_event_header_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_extens_get")]
-  public static extern string switch_file_interface_extens_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_event_header")]
+  public static extern IntPtr new_switch_event_header();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_rwlock_set")]
-  public static extern void switch_file_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_event_header")]
+  public static extern void delete_switch_event_header(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_rwlock_get")]
-  public static extern IntPtr switch_file_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_id_set")]
+  public static extern void switch_event_event_id_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_next_set")]
-  public static extern void switch_file_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_id_get")]
+  public static extern int switch_event_event_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_interface_next_get")]
-  public static extern IntPtr switch_file_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_priority_set")]
+  public static extern void switch_event_priority_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_file_interface")]
-  public static extern IntPtr new_switch_file_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_priority_get")]
+  public static extern int switch_event_priority_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_file_interface")]
-  public static extern void delete_switch_file_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_owner_set")]
+  public static extern void switch_event_owner_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_interface_set")]
-  public static extern void switch_file_handle_file_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_owner_get")]
+  public static extern string switch_event_owner_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_interface_get")]
-  public static extern IntPtr switch_file_handle_file_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_subclass_name_set")]
+  public static extern void switch_event_subclass_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_flags_set")]
-  public static extern void switch_file_handle_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_subclass_name_get")]
+  public static extern string switch_event_subclass_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_flags_get")]
-  public static extern uint switch_file_handle_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_headers_set")]
+  public static extern void switch_event_headers_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_fd_set")]
-  public static extern void switch_file_handle_fd_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_headers_get")]
+  public static extern IntPtr switch_event_headers_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_fd_get")]
-  public static extern IntPtr switch_file_handle_fd_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_last_header_set")]
+  public static extern void switch_event_last_header_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samples_set")]
-  public static extern void switch_file_handle_samples_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_last_header_get")]
+  public static extern IntPtr switch_event_last_header_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samples_get")]
-  public static extern uint switch_file_handle_samples_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_body_set")]
+  public static extern void switch_event_body_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samplerate_set")]
-  public static extern void switch_file_handle_samplerate_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_body_get")]
+  public static extern string switch_event_body_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_samplerate_get")]
-  public static extern uint switch_file_handle_samplerate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_user_data_set")]
+  public static extern void switch_event_bind_user_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_native_rate_set")]
-  public static extern void switch_file_handle_native_rate_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_user_data_get")]
+  public static extern IntPtr switch_event_bind_user_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_native_rate_get")]
-  public static extern uint switch_file_handle_native_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_user_data_set")]
+  public static extern void switch_event_event_user_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_channels_set")]
-  public static extern void switch_file_handle_channels_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_user_data_get")]
+  public static extern IntPtr switch_event_event_user_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_channels_get")]
-  public static extern byte switch_file_handle_channels_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_key_set")]
+  public static extern void switch_event_key_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_format_set")]
-  public static extern void switch_file_handle_format_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_key_get")]
+  public static extern uint switch_event_key_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_format_get")]
-  public static extern uint switch_file_handle_format_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_next_set")]
+  public static extern void switch_event_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sections_set")]
-  public static extern void switch_file_handle_sections_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_next_get")]
+  public static extern IntPtr switch_event_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sections_get")]
-  public static extern uint switch_file_handle_sections_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_event")]
+  public static extern IntPtr new_switch_event();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_seekable_set")]
-  public static extern void switch_file_handle_seekable_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_event")]
+  public static extern void delete_switch_event(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_seekable_get")]
-  public static extern int switch_file_handle_seekable_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_init")]
+  public static extern int switch_event_init(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sample_count_set")]
-  public static extern void switch_file_handle_sample_count_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_shutdown")]
+  public static extern int switch_event_shutdown();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sample_count_get")]
-  public static extern IntPtr switch_file_handle_sample_count_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_create_subclass")]
+  public static extern int switch_event_create_subclass(HandleRef jarg1, int jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_speed_set")]
-  public static extern void switch_file_handle_speed_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_set_priority")]
+  public static extern int switch_event_set_priority(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_speed_get")]
-  public static extern int switch_file_handle_speed_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_get_header")]
+  public static extern string switch_event_get_header(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_memory_pool_set")]
-  public static extern void switch_file_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_get_body")]
+  public static extern string switch_event_get_body(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_memory_pool_get")]
-  public static extern IntPtr switch_file_handle_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_add_header_string")]
+  public static extern int switch_event_add_header_string(HandleRef jarg1, int jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_prebuf_set")]
-  public static extern void switch_file_handle_prebuf_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_del_header")]
+  public static extern int switch_event_del_header(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_prebuf_get")]
-  public static extern uint switch_file_handle_prebuf_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_destroy")]
+  public static extern void switch_event_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_interval_set")]
-  public static extern void switch_file_handle_interval_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_dup")]
+  public static extern int switch_event_dup(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_interval_get")]
-  public static extern uint switch_file_handle_interval_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_fire_detailed")]
+  public static extern int switch_event_fire_detailed(string jarg1, string jarg2, int jarg3, HandleRef jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_private_info_set")]
-  public static extern void switch_file_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind")]
+  public static extern int switch_event_bind(string jarg1, int jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_private_info_get")]
-  public static extern IntPtr switch_file_handle_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_removable")]
+  public static extern int switch_event_bind_removable(string jarg1, int jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_handler_set")]
-  public static extern void switch_file_handle_handler_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_unbind")]
+  public static extern int switch_event_unbind(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_handler_get")]
-  public static extern string switch_file_handle_handler_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_unbind_callback")]
+  public static extern int switch_event_unbind_callback(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_pos_set")]
-  public static extern void switch_file_handle_pos_set(HandleRef jarg1, long jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_name")]
+  public static extern string switch_event_name(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_pos_get")]
-  public static extern long switch_file_handle_pos_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_name_event")]
+  public static extern int switch_name_event(string jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_audio_buffer_set")]
-  public static extern void switch_file_handle_audio_buffer_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_reserve_subclass_detailed")]
+  public static extern int switch_event_reserve_subclass_detailed(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_audio_buffer_get")]
-  public static extern IntPtr switch_file_handle_audio_buffer_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_free_subclass_detailed")]
+  public static extern int switch_event_free_subclass_detailed(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sp_audio_buffer_set")]
-  public static extern void switch_file_handle_sp_audio_buffer_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_serialize")]
+  public static extern int switch_event_serialize(HandleRef jarg1, ref string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_sp_audio_buffer_get")]
-  public static extern IntPtr switch_file_handle_sp_audio_buffer_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_running")]
+  public static extern int switch_event_running();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_thresh_set")]
-  public static extern void switch_file_handle_thresh_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_expand_headers")]
+  public static extern string switch_event_expand_headers(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_thresh_get")]
-  public static extern uint switch_file_handle_thresh_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_create_pres_in_detailed")]
+  public static extern int switch_event_create_pres_in_detailed(string jarg1, string jarg2, int jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, string jarg10, int jarg11, string jarg12, string jarg13, string jarg14, string jarg15);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_silence_hits_set")]
-  public static extern void switch_file_handle_silence_hits_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_deliver")]
+  public static extern void switch_event_deliver(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_silence_hits_get")]
-  public static extern uint switch_file_handle_silence_hits_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_build_param_string")]
+  public static extern string switch_event_build_param_string(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_offset_pos_set")]
-  public static extern void switch_file_handle_offset_pos_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_resampler_set")]
+  public static extern void switch_audio_resampler_t_resampler_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_offset_pos_get")]
-  public static extern uint switch_file_handle_offset_pos_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_resampler_get")]
+  public static extern IntPtr switch_audio_resampler_t_resampler_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_last_pos_set")]
-  public static extern void switch_file_handle_last_pos_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_rate_set")]
+  public static extern void switch_audio_resampler_t_from_rate_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_last_pos_get")]
-  public static extern uint switch_file_handle_last_pos_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_rate_get")]
+  public static extern int switch_audio_resampler_t_from_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_vol_set")]
-  public static extern void switch_file_handle_vol_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_rate_set")]
+  public static extern void switch_audio_resampler_t_to_rate_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_vol_get")]
-  public static extern int switch_file_handle_vol_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_rate_get")]
+  public static extern int switch_audio_resampler_t_to_rate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_resampler_set")]
-  public static extern void switch_file_handle_resampler_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_factor_set")]
+  public static extern void switch_audio_resampler_t_factor_set(HandleRef jarg1, double jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_resampler_get")]
-  public static extern IntPtr switch_file_handle_resampler_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_factor_get")]
+  public static extern double switch_audio_resampler_t_factor_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_buffer_set")]
-  public static extern void switch_file_handle_buffer_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_rfactor_set")]
+  public static extern void switch_audio_resampler_t_rfactor_set(HandleRef jarg1, double jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_buffer_get")]
-  public static extern IntPtr switch_file_handle_buffer_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_rfactor_get")]
+  public static extern double switch_audio_resampler_t_rfactor_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuf_set")]
-  public static extern void switch_file_handle_dbuf_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_set")]
+  public static extern void switch_audio_resampler_t_from_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuf_get")]
-  public static extern IntPtr switch_file_handle_dbuf_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_get")]
+  public static extern IntPtr switch_audio_resampler_t_from_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuflen_set")]
-  public static extern void switch_file_handle_dbuflen_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_len_set")]
+  public static extern void switch_audio_resampler_t_from_len_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_dbuflen_get")]
-  public static extern IntPtr switch_file_handle_dbuflen_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_len_get")]
+  public static extern int switch_audio_resampler_t_from_len_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_set")]
-  public static extern void switch_file_handle_file_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_size_set")]
+  public static extern void switch_audio_resampler_t_from_size_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_file_get")]
-  public static extern string switch_file_handle_file_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_size_get")]
+  public static extern IntPtr switch_audio_resampler_t_from_size_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_func_set")]
-  public static extern void switch_file_handle_func_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_set")]
+  public static extern void switch_audio_resampler_t_to_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_func_get")]
-  public static extern string switch_file_handle_func_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_get")]
+  public static extern IntPtr switch_audio_resampler_t_to_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_line_set")]
-  public static extern void switch_file_handle_line_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_len_set")]
+  public static extern void switch_audio_resampler_t_to_len_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_file_handle_line_get")]
-  public static extern int switch_file_handle_line_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_len_get")]
+  public static extern uint switch_audio_resampler_t_to_len_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_file_handle")]
-  public static extern IntPtr new_switch_file_handle();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_size_set")]
+  public static extern void switch_audio_resampler_t_to_size_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_file_handle")]
-  public static extern void delete_switch_file_handle(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_size_get")]
+  public static extern uint switch_audio_resampler_t_to_size_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_interface_name_set")]
-  public static extern void switch_asr_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_audio_resampler_t")]
+  public static extern IntPtr new_switch_audio_resampler_t();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_interface_name_get")]
-  public static extern string switch_asr_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_audio_resampler_t")]
+  public static extern void delete_switch_audio_resampler_t(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_open_set")]
-  public static extern void switch_asr_interface_asr_open_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_create")]
+  public static extern int switch_resample_create(HandleRef jarg1, int jarg2, HandleRef jarg3, int jarg4, uint jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_open_get")]
-  public static extern IntPtr switch_asr_interface_asr_open_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_destroy")]
+  public static extern void switch_resample_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_load_grammar_set")]
-  public static extern void switch_asr_interface_asr_load_grammar_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_process")]
+  public static extern uint switch_resample_process(HandleRef jarg1, HandleRef jarg2, int jarg3, HandleRef jarg4, uint jarg5, int jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_load_grammar_get")]
-  public static extern IntPtr switch_asr_interface_asr_load_grammar_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_float_to_short")]
+  public static extern IntPtr switch_float_to_short(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_unload_grammar_set")]
-  public static extern void switch_asr_interface_asr_unload_grammar_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_char_to_float")]
+  public static extern int switch_char_to_float(string jarg1, HandleRef jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_unload_grammar_get")]
-  public static extern IntPtr switch_asr_interface_asr_unload_grammar_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_float_to_char")]
+  public static extern int switch_float_to_char(HandleRef jarg1, string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_close_set")]
-  public static extern void switch_asr_interface_asr_close_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_short_to_float")]
+  public static extern int switch_short_to_float(HandleRef jarg1, HandleRef jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_close_get")]
-  public static extern IntPtr switch_asr_interface_asr_close_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_swap_linear")]
+  public static extern void switch_swap_linear(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_feed_set")]
-  public static extern void switch_asr_interface_asr_feed_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_generate_sln_silence")]
+  public static extern void switch_generate_sln_silence(HandleRef jarg1, uint jarg2, uint jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_feed_get")]
-  public static extern IntPtr switch_asr_interface_asr_feed_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_change_sln_volume")]
+  public static extern void switch_change_sln_volume(HandleRef jarg1, uint jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_resume_set")]
-  public static extern void switch_asr_interface_asr_resume_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_merge_sln")]
+  public static extern uint switch_merge_sln(HandleRef jarg1, uint jarg2, HandleRef jarg3, uint jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_resume_get")]
-  public static extern IntPtr switch_asr_interface_asr_resume_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_session_set")]
+  public static extern void switch_unicast_conninfo_session_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_pause_set")]
-  public static extern void switch_asr_interface_asr_pause_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_session_get")]
+  public static extern IntPtr switch_unicast_conninfo_session_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_pause_get")]
-  public static extern IntPtr switch_asr_interface_asr_pause_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_read_codec_set")]
+  public static extern void switch_unicast_conninfo_read_codec_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_check_results_set")]
-  public static extern void switch_asr_interface_asr_check_results_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_read_codec_get")]
+  public static extern IntPtr switch_unicast_conninfo_read_codec_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_check_results_get")]
-  public static extern IntPtr switch_asr_interface_asr_check_results_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_set")]
+  public static extern void switch_unicast_conninfo_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_get_results_set")]
-  public static extern void switch_asr_interface_asr_get_results_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_get")]
+  public static extern IntPtr switch_unicast_conninfo_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_asr_get_results_get")]
-  public static extern IntPtr switch_asr_interface_asr_get_results_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_data_set")]
+  public static extern void switch_unicast_conninfo_write_frame_data_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_rwlock_set")]
-  public static extern void switch_asr_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_data_get")]
+  public static extern IntPtr switch_unicast_conninfo_write_frame_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_rwlock_get")]
-  public static extern IntPtr switch_asr_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_socket_set")]
+  public static extern void switch_unicast_conninfo_socket_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_next_set")]
-  public static extern void switch_asr_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_socket_get")]
+  public static extern IntPtr switch_unicast_conninfo_socket_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_interface_next_get")]
-  public static extern IntPtr switch_asr_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_ip_set")]
+  public static extern void switch_unicast_conninfo_local_ip_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_asr_interface")]
-  public static extern IntPtr new_switch_asr_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_ip_get")]
+  public static extern string switch_unicast_conninfo_local_ip_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_asr_interface")]
-  public static extern void delete_switch_asr_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_port_set")]
+  public static extern void switch_unicast_conninfo_local_port_set(HandleRef jarg1, ushort jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_asr_interface_set")]
-  public static extern void switch_asr_handle_asr_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_port_get")]
+  public static extern ushort switch_unicast_conninfo_local_port_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_asr_interface_get")]
-  public static extern IntPtr switch_asr_handle_asr_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_ip_set")]
+  public static extern void switch_unicast_conninfo_remote_ip_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_flags_set")]
-  public static extern void switch_asr_handle_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_ip_get")]
+  public static extern string switch_unicast_conninfo_remote_ip_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_flags_get")]
-  public static extern uint switch_asr_handle_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_port_set")]
+  public static extern void switch_unicast_conninfo_remote_port_set(HandleRef jarg1, ushort jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_name_set")]
-  public static extern void switch_asr_handle_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_port_get")]
+  public static extern ushort switch_unicast_conninfo_remote_port_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_name_get")]
-  public static extern string switch_asr_handle_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_addr_set")]
+  public static extern void switch_unicast_conninfo_local_addr_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_codec_set")]
-  public static extern void switch_asr_handle_codec_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_addr_get")]
+  public static extern IntPtr switch_unicast_conninfo_local_addr_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_codec_get")]
-  public static extern string switch_asr_handle_codec_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_addr_set")]
+  public static extern void switch_unicast_conninfo_remote_addr_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_rate_set")]
-  public static extern void switch_asr_handle_rate_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_addr_get")]
+  public static extern IntPtr switch_unicast_conninfo_remote_addr_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_rate_get")]
-  public static extern uint switch_asr_handle_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flag_mutex_set")]
+  public static extern void switch_unicast_conninfo_flag_mutex_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_grammar_set")]
-  public static extern void switch_asr_handle_grammar_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flag_mutex_get")]
+  public static extern IntPtr switch_unicast_conninfo_flag_mutex_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_grammar_get")]
-  public static extern string switch_asr_handle_grammar_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flags_set")]
+  public static extern void switch_unicast_conninfo_flags_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_param_set")]
-  public static extern void switch_asr_handle_param_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flags_get")]
+  public static extern int switch_unicast_conninfo_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_param_get")]
-  public static extern string switch_asr_handle_param_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_type_set")]
+  public static extern void switch_unicast_conninfo_type_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_memory_pool_set")]
-  public static extern void switch_asr_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_type_get")]
+  public static extern int switch_unicast_conninfo_type_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_memory_pool_get")]
-  public static extern IntPtr switch_asr_handle_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_transport_set")]
+  public static extern void switch_unicast_conninfo_transport_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_private_info_set")]
-  public static extern void switch_asr_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_transport_get")]
+  public static extern int switch_unicast_conninfo_transport_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_asr_handle_private_info_get")]
-  public static extern IntPtr switch_asr_handle_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_stream_id_set")]
+  public static extern void switch_unicast_conninfo_stream_id_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_asr_handle")]
-  public static extern IntPtr new_switch_asr_handle();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_stream_id_get")]
+  public static extern int switch_unicast_conninfo_stream_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_asr_handle")]
-  public static extern void delete_switch_asr_handle(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_unicast_conninfo")]
+  public static extern IntPtr new_switch_unicast_conninfo();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_interface_name_set")]
-  public static extern void switch_speech_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_unicast_conninfo")]
+  public static extern void delete_switch_unicast_conninfo(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_interface_name_get")]
-  public static extern string switch_speech_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_deactivate_unicast")]
+  public static extern int switch_ivr_deactivate_unicast(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_open_set")]
-  public static extern void switch_speech_interface_speech_open_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_activate_unicast")]
+  public static extern int switch_ivr_activate_unicast(HandleRef jarg1, string jarg2, ushort jarg3, string jarg4, ushort jarg5, string jarg6, string jarg7);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_open_get")]
-  public static extern IntPtr switch_speech_interface_speech_open_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_generate_xml_cdr")]
+  public static extern int switch_ivr_generate_xml_cdr(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_close_set")]
-  public static extern void switch_speech_interface_speech_close_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_xml_profile_data")]
+  public static extern int switch_ivr_set_xml_profile_data(HandleRef jarg1, HandleRef jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_close_get")]
-  public static extern IntPtr switch_speech_interface_speech_close_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_xml_chan_vars")]
+  public static extern int switch_ivr_set_xml_chan_vars(HandleRef jarg1, HandleRef jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_feed_tts_set")]
-  public static extern void switch_speech_interface_speech_feed_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_event")]
+  public static extern int switch_ivr_parse_event(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_feed_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_feed_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_all_events")]
+  public static extern int switch_ivr_parse_all_events(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_read_tts_set")]
-  public static extern void switch_speech_interface_speech_read_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_next_event")]
+  public static extern int switch_ivr_parse_next_event(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_read_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_read_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_sleep")]
+  public static extern int switch_ivr_sleep(HandleRef jarg1, uint jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_flush_tts_set")]
-  public static extern void switch_speech_interface_speech_flush_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_park")]
+  public static extern int switch_ivr_park(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_flush_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_flush_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_collect_digits_callback")]
+  public static extern int switch_ivr_collect_digits_callback(HandleRef jarg1, HandleRef jarg2, uint jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_text_param_tts_set")]
-  public static extern void switch_speech_interface_speech_text_param_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_collect_digits_count")]
+  public static extern int switch_ivr_collect_digits_count(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, string jarg5, string jarg6, uint jarg7, uint jarg8, uint jarg9);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_text_param_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_text_param_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech")]
+  public static extern int switch_ivr_detect_speech(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_numeric_param_tts_set")]
-  public static extern void switch_speech_interface_speech_numeric_param_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_detect_speech")]
+  public static extern int switch_ivr_stop_detect_speech(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_numeric_param_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_numeric_param_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_pause_detect_speech")]
+  public static extern int switch_ivr_pause_detect_speech(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_float_param_tts_set")]
-  public static extern void switch_speech_interface_speech_float_param_tts_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_resume_detect_speech")]
+  public static extern int switch_ivr_resume_detect_speech(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_speech_float_param_tts_get")]
-  public static extern IntPtr switch_speech_interface_speech_float_param_tts_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech_load_grammar")]
+  public static extern int switch_ivr_detect_speech_load_grammar(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_rwlock_set")]
-  public static extern void switch_speech_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech_unload_grammar")]
+  public static extern int switch_ivr_detect_speech_unload_grammar(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_rwlock_get")]
-  public static extern IntPtr switch_speech_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_record_session")]
+  public static extern int switch_ivr_record_session(HandleRef jarg1, string jarg2, uint jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_next_set")]
-  public static extern void switch_speech_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_eavesdrop_session")]
+  public static extern int switch_ivr_eavesdrop_session(HandleRef jarg1, string jarg2, string jarg3, uint jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_interface_next_get")]
-  public static extern IntPtr switch_speech_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_displace_session")]
+  public static extern int switch_ivr_displace_session(HandleRef jarg1, string jarg2, uint jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_speech_interface")]
-  public static extern IntPtr new_switch_speech_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_displace_session")]
+  public static extern int switch_ivr_stop_displace_session(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_speech_interface")]
-  public static extern void delete_switch_speech_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_record_session")]
+  public static extern int switch_ivr_stop_record_session(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speech_interface_set")]
-  public static extern void switch_speech_handle_speech_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_inband_dtmf_session")]
+  public static extern int switch_ivr_inband_dtmf_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speech_interface_get")]
-  public static extern IntPtr switch_speech_handle_speech_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_inband_dtmf_session")]
+  public static extern int switch_ivr_stop_inband_dtmf_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_flags_set")]
-  public static extern void switch_speech_handle_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_inband_dtmf_generate_session")]
+  public static extern int switch_ivr_inband_dtmf_generate_session(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_flags_get")]
-  public static extern uint switch_speech_handle_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_inband_dtmf_generate_session")]
+  public static extern int switch_ivr_stop_inband_dtmf_generate_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_name_set")]
-  public static extern void switch_speech_handle_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_session_echo")]
+  public static extern void switch_ivr_session_echo(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_name_get")]
-  public static extern string switch_speech_handle_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_tone_detect_session")]
+  public static extern int switch_ivr_stop_tone_detect_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_rate_set")]
-  public static extern void switch_speech_handle_rate_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_tone_detect_session")]
+  public static extern int switch_ivr_tone_detect_session(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, string jarg6, string jarg7);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_rate_get")]
-  public static extern uint switch_speech_handle_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_play_file")]
+  public static extern int switch_ivr_play_file(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speed_set")]
-  public static extern void switch_speech_handle_speed_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_wait_for_silence")]
+  public static extern int switch_ivr_wait_for_silence(HandleRef jarg1, uint jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_speed_get")]
-  public static extern uint switch_speech_handle_speed_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_gentones")]
+  public static extern int switch_ivr_gentones(HandleRef jarg1, string jarg2, int jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_samples_set")]
-  public static extern void switch_speech_handle_samples_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_record_file")]
+  public static extern int switch_ivr_record_file(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4, uint jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_samples_get")]
-  public static extern uint switch_speech_handle_samples_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_play_and_get_digits")]
+  public static extern int switch_play_and_get_digits(HandleRef jarg1, uint jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6, string jarg7, string jarg8, HandleRef jarg9, uint jarg10, string jarg11);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_voice_set")]
-  public static extern void switch_speech_handle_voice_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_speak_text_handle")]
+  public static extern int switch_ivr_speak_text_handle(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, string jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_voice_get")]
-  public static extern string switch_speech_handle_voice_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_clear_speech_cache")]
+  public static extern void switch_ivr_clear_speech_cache(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_engine_set")]
-  public static extern void switch_speech_handle_engine_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_speak_text")]
+  public static extern int switch_ivr_speak_text(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_engine_get")]
-  public static extern string switch_speech_handle_engine_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_originate")]
+  public static extern int switch_ivr_originate(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, string jarg4, uint jarg5, HandleRef jarg6, string jarg7, string jarg8, HandleRef jarg9, uint jarg10);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_param_set")]
-  public static extern void switch_speech_handle_param_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_multi_threaded_bridge")]
+  public static extern int switch_ivr_multi_threaded_bridge(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_param_get")]
-  public static extern string switch_speech_handle_param_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_signal_bridge")]
+  public static extern int switch_ivr_signal_bridge(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_memory_pool_set")]
-  public static extern void switch_speech_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_session_transfer")]
+  public static extern int switch_ivr_session_transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_memory_pool_get")]
-  public static extern IntPtr switch_speech_handle_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_transfer")]
+  public static extern uint switch_ivr_schedule_transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_private_info_set")]
-  public static extern void switch_speech_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_hangup")]
+  public static extern uint switch_ivr_schedule_hangup(HandleRef jarg1, string jarg2, int jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_speech_handle_private_info_get")]
-  public static extern IntPtr switch_speech_handle_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_uuid_bridge")]
+  public static extern int switch_ivr_uuid_bridge(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_speech_handle")]
-  public static extern IntPtr new_switch_speech_handle();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_media")]
+  public static extern int switch_ivr_media(string jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_speech_handle")]
-  public static extern void delete_switch_speech_handle(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_nomedia")]
+  public static extern int switch_ivr_nomedia(string jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_interface_name_set")]
-  public static extern void switch_say_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_hold_uuid")]
+  public static extern int switch_ivr_hold_uuid(string jarg1, string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_interface_name_get")]
-  public static extern string switch_say_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unhold_uuid")]
+  public static extern int switch_ivr_unhold_uuid(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_say_function_set")]
-  public static extern void switch_say_interface_say_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_hold")]
+  public static extern int switch_ivr_hold(HandleRef jarg1, string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_say_function_get")]
-  public static extern IntPtr switch_say_interface_say_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unhold")]
+  public static extern int switch_ivr_unhold(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_rwlock_set")]
-  public static extern void switch_say_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_broadcast")]
+  public static extern uint switch_ivr_schedule_broadcast(HandleRef jarg1, string jarg2, string jarg3, uint jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_rwlock_get")]
-  public static extern IntPtr switch_say_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_broadcast")]
+  public static extern int switch_ivr_broadcast(string jarg1, string jarg2, uint jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_next_set")]
-  public static extern void switch_say_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_transfer_variable")]
+  public static extern int switch_ivr_transfer_variable(HandleRef jarg1, HandleRef jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_say_interface_next_get")]
-  public static extern IntPtr switch_say_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_new")]
+  public static extern int switch_ivr_digit_stream_parser_new(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_say_interface")]
-  public static extern IntPtr new_switch_say_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_destroy")]
+  public static extern int switch_ivr_digit_stream_parser_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_say_interface")]
-  public static extern void delete_switch_say_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_new")]
+  public static extern int switch_ivr_digit_stream_new(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_interface_name_set")]
-  public static extern void switch_chat_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_destroy")]
+  public static extern int switch_ivr_digit_stream_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_interface_name_get")]
-  public static extern string switch_chat_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_set_event")]
+  public static extern int switch_ivr_digit_stream_parser_set_event(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_chat_send_set")]
-  public static extern void switch_chat_interface_chat_send_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_del_event")]
+  public static extern int switch_ivr_digit_stream_parser_del_event(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_chat_send_get")]
-  public static extern IntPtr switch_chat_interface_chat_send_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_feed")]
+  public static extern IntPtr switch_ivr_digit_stream_parser_feed(HandleRef jarg1, HandleRef jarg2, char jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_rwlock_set")]
-  public static extern void switch_chat_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_reset")]
+  public static extern int switch_ivr_digit_stream_reset(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_rwlock_get")]
-  public static extern IntPtr switch_chat_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_set_terminator")]
+  public static extern int switch_ivr_digit_stream_parser_set_terminator(HandleRef jarg1, char jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_next_set")]
-  public static extern void switch_chat_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_init")]
+  public static extern int switch_ivr_menu_init(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14, int jarg15, HandleRef jarg16);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_chat_interface_next_get")]
-  public static extern IntPtr switch_chat_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_bind_action")]
+  public static extern int switch_ivr_menu_bind_action(HandleRef jarg1, int jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_chat_interface")]
-  public static extern IntPtr new_switch_chat_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_bind_function")]
+  public static extern int switch_ivr_menu_bind_function(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_chat_interface")]
-  public static extern void delete_switch_chat_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_execute")]
+  public static extern int switch_ivr_menu_execute(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_relative_oid_set")]
-  public static extern void switch_management_interface_relative_oid_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_free")]
+  public static extern int switch_ivr_menu_stack_free(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_relative_oid_get")]
-  public static extern string switch_management_interface_relative_oid_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_build")]
+  public static extern int switch_ivr_menu_stack_xml_build(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_management_function_set")]
-  public static extern void switch_management_interface_management_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_str2action")]
+  public static extern int switch_ivr_menu_str2action(string jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_management_function_get")]
-  public static extern IntPtr switch_management_interface_management_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_add_custom")]
+  public static extern int switch_ivr_menu_stack_xml_add_custom(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_rwlock_set")]
-  public static extern void switch_management_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_init")]
+  public static extern int switch_ivr_menu_stack_xml_init(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_rwlock_get")]
-  public static extern IntPtr switch_management_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_phrase_macro")]
+  public static extern int switch_ivr_phrase_macro(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_next_set")]
-  public static extern void switch_management_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_delay_echo")]
+  public static extern void switch_ivr_delay_echo(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_management_interface_next_get")]
-  public static extern IntPtr switch_management_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_find_bridged_uuid")]
+  public static extern int switch_ivr_find_bridged_uuid(string jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_management_interface")]
-  public static extern IntPtr new_switch_management_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_intercept_session")]
+  public static extern void switch_ivr_intercept_session(HandleRef jarg1, string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_management_interface")]
-  public static extern void delete_switch_management_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_park_session")]
+  public static extern void switch_ivr_park_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_interface_name_set")]
-  public static extern void switch_directory_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_wait_for_answer")]
+  public static extern int switch_ivr_wait_for_answer(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_interface_name_get")]
-  public static extern string switch_directory_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_read")]
+  public static extern int switch_ivr_read(HandleRef jarg1, uint jarg2, uint jarg3, string jarg4, string jarg5, string jarg6, HandleRef jarg7, uint jarg8, string jarg9);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_open_set")]
-  public static extern void switch_directory_interface_directory_open_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_bind_dtmf_meta_session")]
+  public static extern int switch_ivr_bind_dtmf_meta_session(HandleRef jarg1, uint jarg2, uint jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_open_get")]
-  public static extern IntPtr switch_directory_interface_directory_open_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unbind_dtmf_meta_session")]
+  public static extern int switch_ivr_unbind_dtmf_meta_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_close_set")]
-  public static extern void switch_directory_interface_directory_close_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_soft_hold")]
+  public static extern int switch_ivr_soft_hold(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_close_get")]
-  public static extern IntPtr switch_directory_interface_directory_close_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_say")]
+  public static extern int switch_ivr_say(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_query_set")]
-  public static extern void switch_directory_interface_directory_query_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_get_say_method_by_name")]
+  public static extern int switch_ivr_get_say_method_by_name(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_query_get")]
-  public static extern IntPtr switch_directory_interface_directory_query_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_get_say_type_by_name")]
+  public static extern int switch_ivr_get_say_type_by_name(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_set")]
-  public static extern void switch_directory_interface_directory_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_user")]
+  public static extern int switch_ivr_set_user(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_get")]
-  public static extern IntPtr switch_directory_interface_directory_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_MAX_BUF_LEN_get")]
+  public static extern int SWITCH_RTP_MAX_BUF_LEN_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_pair_set")]
-  public static extern void switch_directory_interface_directory_next_pair_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_MAX_CRYPTO_LEN_get")]
+  public static extern int SWITCH_RTP_MAX_CRYPTO_LEN_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_directory_next_pair_get")]
-  public static extern IntPtr switch_directory_interface_directory_next_pair_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_KEY_LEN_get")]
+  public static extern int SWITCH_RTP_KEY_LEN_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_rwlock_set")]
-  public static extern void switch_directory_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CRYPTO_KEY_32_get")]
+  public static extern string SWITCH_RTP_CRYPTO_KEY_32_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_rwlock_get")]
-  public static extern IntPtr switch_directory_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CRYPTO_KEY_80_get")]
+  public static extern string SWITCH_RTP_CRYPTO_KEY_80_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_next_set")]
-  public static extern void switch_directory_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_index_set")]
+  public static extern void switch_rtp_crypto_key_index_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_interface_next_get")]
-  public static extern IntPtr switch_directory_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_index_get")]
+  public static extern uint switch_rtp_crypto_key_index_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directory_interface")]
-  public static extern IntPtr new_switch_directory_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_type_set")]
+  public static extern void switch_rtp_crypto_key_type_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directory_interface")]
-  public static extern void delete_switch_directory_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_type_get")]
+  public static extern int switch_rtp_crypto_key_type_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_directory_interface_set")]
-  public static extern void switch_directory_handle_directory_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_key_set")]
+  public static extern void switch_rtp_crypto_key_key_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_directory_interface_get")]
-  public static extern IntPtr switch_directory_handle_directory_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_key_get")]
+  public static extern IntPtr switch_rtp_crypto_key_key_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_flags_set")]
-  public static extern void switch_directory_handle_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_keylen_set")]
+  public static extern void switch_rtp_crypto_key_keylen_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_flags_get")]
-  public static extern uint switch_directory_handle_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_keylen_get")]
+  public static extern IntPtr switch_rtp_crypto_key_keylen_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_memory_pool_set")]
-  public static extern void switch_directory_handle_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_next_set")]
+  public static extern void switch_rtp_crypto_key_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_memory_pool_get")]
-  public static extern IntPtr switch_directory_handle_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_next_get")]
+  public static extern IntPtr switch_rtp_crypto_key_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_private_info_set")]
-  public static extern void switch_directory_handle_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_rtp_crypto_key")]
+  public static extern IntPtr new_switch_rtp_crypto_key();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_directory_handle_private_info_get")]
-  public static extern IntPtr switch_directory_handle_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_rtp_crypto_key")]
+  public static extern void delete_switch_rtp_crypto_key(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_directory_handle")]
-  public static extern IntPtr new_switch_directory_handle();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_add_crypto_key")]
+  public static extern int switch_rtp_add_crypto_key(HandleRef jarg1, int jarg2, uint jarg3, int jarg4, HandleRef jarg5, HandleRef jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_directory_handle")]
-  public static extern void delete_switch_directory_handle(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_random")]
+  public static extern void switch_rtp_get_random(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_quality_set")]
-  public static extern void switch_codec_settings_quality_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_init")]
+  public static extern void switch_rtp_init(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_quality_get")]
-  public static extern int switch_codec_settings_quality_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_shutdown")]
+  public static extern void switch_rtp_shutdown();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_complexity_set")]
-  public static extern void switch_codec_settings_complexity_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_start_port")]
+  public static extern ushort switch_rtp_set_start_port(ushort jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_complexity_get")]
-  public static extern int switch_codec_settings_complexity_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_end_port")]
+  public static extern ushort switch_rtp_set_end_port(ushort jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_enhancement_set")]
-  public static extern void switch_codec_settings_enhancement_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_request_port")]
+  public static extern ushort switch_rtp_request_port(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_enhancement_get")]
-  public static extern int switch_codec_settings_enhancement_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_release_port")]
+  public static extern void switch_rtp_release_port(string jarg1, ushort jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vad_set")]
-  public static extern void switch_codec_settings_vad_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_create")]
+  public static extern int switch_rtp_create(HandleRef jarg1, byte jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6, ref string jarg7, HandleRef jarg8);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vad_get")]
-  public static extern int switch_codec_settings_vad_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_new")]
+  public static extern IntPtr switch_rtp_new(string jarg1, ushort jarg2, string jarg3, ushort jarg4, byte jarg5, uint jarg6, uint jarg7, uint jarg8, string jarg9, ref string jarg10, HandleRef jarg11);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_set")]
-  public static extern void switch_codec_settings_vbr_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_remote_address")]
+  public static extern int switch_rtp_set_remote_address(HandleRef jarg1, string jarg2, ushort jarg3, int jarg4, ref string jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_get")]
-  public static extern int switch_codec_settings_vbr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_remote_host")]
+  public static extern string switch_rtp_get_remote_host(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_quality_set")]
-  public static extern void switch_codec_settings_vbr_quality_set(HandleRef jarg1, float jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_remote_port")]
+  public static extern ushort switch_rtp_get_remote_port(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_vbr_quality_get")]
-  public static extern float switch_codec_settings_vbr_quality_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_max_missed_packets")]
+  public static extern void switch_rtp_set_max_missed_packets(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_abr_set")]
-  public static extern void switch_codec_settings_abr_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_local_address")]
+  public static extern int switch_rtp_set_local_address(HandleRef jarg1, string jarg2, ushort jarg3, ref string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_abr_get")]
-  public static extern int switch_codec_settings_abr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_kill_socket")]
+  public static extern void switch_rtp_kill_socket(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_dtx_set")]
-  public static extern void switch_codec_settings_dtx_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_break")]
+  public static extern void switch_rtp_break(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_dtx_get")]
-  public static extern int switch_codec_settings_dtx_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_ready")]
+  public static extern byte switch_rtp_ready(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_preproc_set")]
-  public static extern void switch_codec_settings_preproc_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_destroy")]
+  public static extern void switch_rtp_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_preproc_get")]
-  public static extern int switch_codec_settings_preproc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_ice")]
+  public static extern int switch_rtp_activate_ice(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_vad_set")]
-  public static extern void switch_codec_settings_pp_vad_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_jitter_buffer")]
+  public static extern int switch_rtp_activate_jitter_buffer(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_vad_get")]
-  public static extern int switch_codec_settings_pp_vad_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_flag")]
+  public static extern void switch_rtp_set_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_set")]
-  public static extern void switch_codec_settings_pp_agc_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_test_flag")]
+  public static extern uint switch_rtp_test_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_get")]
-  public static extern int switch_codec_settings_pp_agc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_clear_flag")]
+  public static extern void switch_rtp_clear_flag(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_level_set")]
-  public static extern void switch_codec_settings_pp_agc_level_set(HandleRef jarg1, float jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_rtp_socket")]
+  public static extern IntPtr switch_rtp_get_rtp_socket(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_agc_level_get")]
-  public static extern float switch_codec_settings_pp_agc_level_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_default_samples_per_interval")]
+  public static extern void switch_rtp_set_default_samples_per_interval(HandleRef jarg1, ushort jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_denoise_set")]
-  public static extern void switch_codec_settings_pp_denoise_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_default_samples_per_interval")]
+  public static extern uint switch_rtp_get_default_samples_per_interval(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_denoise_get")]
-  public static extern int switch_codec_settings_pp_denoise_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_default_payload")]
+  public static extern void switch_rtp_set_default_payload(HandleRef jarg1, byte jarg2);
+
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_default_payload")]
+  public static extern uint switch_rtp_get_default_payload(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_set")]
-  public static extern void switch_codec_settings_pp_dereverb_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_invald_handler")]
+  public static extern void switch_rtp_set_invald_handler(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_get")]
-  public static extern int switch_codec_settings_pp_dereverb_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_read")]
+  public static extern int switch_rtp_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, uint jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_decay_set")]
-  public static extern void switch_codec_settings_pp_dereverb_decay_set(HandleRef jarg1, float jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_queue_rfc2833")]
+  public static extern int switch_rtp_queue_rfc2833(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_decay_get")]
-  public static extern float switch_codec_settings_pp_dereverb_decay_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_queue_rfc2833_in")]
+  public static extern int switch_rtp_queue_rfc2833_in(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_level_set")]
-  public static extern void switch_codec_settings_pp_dereverb_level_set(HandleRef jarg1, float jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_has_dtmf")]
+  public static extern IntPtr switch_rtp_has_dtmf(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_settings_pp_dereverb_level_get")]
-  public static extern float switch_codec_settings_pp_dereverb_level_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_dequeue_dtmf")]
+  public static extern IntPtr switch_rtp_dequeue_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_settings")]
-  public static extern IntPtr new_switch_codec_settings();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_zerocopy_read")]
+  public static extern int switch_rtp_zerocopy_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, uint jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_settings")]
-  public static extern void delete_switch_codec_settings(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_zerocopy_read_frame")]
+  public static extern int switch_rtp_zerocopy_read_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_interface_set")]
-  public static extern void switch_codec_codec_interface_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_enable_vad")]
+  public static extern int switch_rtp_enable_vad(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_interface_get")]
-  public static extern IntPtr switch_codec_codec_interface_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_disable_vad")]
+  public static extern int switch_rtp_disable_vad(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_set")]
-  public static extern void switch_codec_implementation_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_write_frame")]
+  public static extern int switch_rtp_write_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_get")]
-  public static extern IntPtr switch_codec_implementation_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_write_manual")]
+  public static extern int switch_rtp_write_manual(HandleRef jarg1, HandleRef jarg2, uint jarg3, byte jarg4, byte jarg5, uint jarg6, HandleRef jarg7);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_in_set")]
-  public static extern void switch_codec_fmtp_in_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_ssrc")]
+  public static extern uint switch_rtp_get_ssrc(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_in_get")]
-  public static extern string switch_codec_fmtp_in_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_private")]
+  public static extern void switch_rtp_set_private(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_out_set")]
-  public static extern void switch_codec_fmtp_out_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_telephony_event")]
+  public static extern void switch_rtp_set_telephony_event(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_fmtp_out_get")]
-  public static extern string switch_codec_fmtp_out_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_cng_pt")]
+  public static extern void switch_rtp_set_cng_pt(HandleRef jarg1, byte jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_settings_set")]
-  public static extern void switch_codec_codec_settings_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_private")]
+  public static extern IntPtr switch_rtp_get_private(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_codec_settings_get")]
-  public static extern IntPtr switch_codec_codec_settings_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_stun_ping")]
+  public static extern int switch_rtp_activate_stun_ping(HandleRef jarg1, string jarg2, ushort jarg3, uint jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_flags_set")]
-  public static extern void switch_codec_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_data_set")]
+  public static extern void switch_log_node_t_data_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_flags_get")]
-  public static extern uint switch_codec_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_data_get")]
+  public static extern string switch_log_node_t_data_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_memory_pool_set")]
-  public static extern void switch_codec_memory_pool_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_file_set")]
+  public static extern void switch_log_node_t_file_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_memory_pool_get")]
-  public static extern IntPtr switch_codec_memory_pool_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_file_get")]
+  public static extern string switch_log_node_t_file_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_private_info_set")]
-  public static extern void switch_codec_private_info_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_line_set")]
+  public static extern void switch_log_node_t_line_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_private_info_get")]
-  public static extern IntPtr switch_codec_private_info_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_line_get")]
+  public static extern uint switch_log_node_t_line_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_agreed_pt_set")]
-  public static extern void switch_codec_agreed_pt_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_func_set")]
+  public static extern void switch_log_node_t_func_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_agreed_pt_get")]
-  public static extern byte switch_codec_agreed_pt_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_func_get")]
+  public static extern string switch_log_node_t_func_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec")]
-  public static extern IntPtr new_switch_codec();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_level_set")]
+  public static extern void switch_log_node_t_level_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec")]
-  public static extern void delete_switch_codec(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_level_get")]
+  public static extern int switch_log_node_t_level_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_type_set")]
-  public static extern void switch_codec_implementation_codec_type_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_timestamp_set")]
+  public static extern void switch_log_node_t_timestamp_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_type_get")]
-  public static extern int switch_codec_implementation_codec_type_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_timestamp_get")]
+  public static extern IntPtr switch_log_node_t_timestamp_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_ianacode_set")]
-  public static extern void switch_codec_implementation_ianacode_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_content_set")]
+  public static extern void switch_log_node_t_content_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_ianacode_get")]
-  public static extern byte switch_codec_implementation_ianacode_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_content_get")]
+  public static extern string switch_log_node_t_content_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_iananame_set")]
-  public static extern void switch_codec_implementation_iananame_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_userdata_set")]
+  public static extern void switch_log_node_t_userdata_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_iananame_get")]
-  public static extern string switch_codec_implementation_iananame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_userdata_get")]
+  public static extern string switch_log_node_t_userdata_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_fmtp_set")]
-  public static extern void switch_codec_implementation_fmtp_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_log_node_t")]
+  public static extern IntPtr new_switch_log_node_t();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_fmtp_get")]
-  public static extern string switch_codec_implementation_fmtp_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_log_node_t")]
+  public static extern void delete_switch_log_node_t(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_second_set")]
-  public static extern void switch_codec_implementation_samples_per_second_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_init")]
+  public static extern int switch_log_init(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_second_get")]
-  public static extern uint switch_codec_implementation_samples_per_second_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_shutdown")]
+  public static extern int switch_log_shutdown();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_actual_samples_per_second_set")]
-  public static extern void switch_codec_implementation_actual_samples_per_second_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_bind_logger")]
+  public static extern int switch_log_bind_logger(HandleRef jarg1, int jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_actual_samples_per_second_get")]
-  public static extern uint switch_codec_implementation_actual_samples_per_second_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_unbind_logger")]
+  public static extern int switch_log_unbind_logger(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bits_per_second_set")]
-  public static extern void switch_codec_implementation_bits_per_second_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_level2str")]
+  public static extern string switch_log_level2str(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bits_per_second_get")]
-  public static extern int switch_codec_implementation_bits_per_second_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_str2level")]
+  public static extern int switch_log_str2level(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_microseconds_per_frame_set")]
-  public static extern void switch_codec_implementation_microseconds_per_frame_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_str2mask")]
+  public static extern uint switch_log_str2mask(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_microseconds_per_frame_get")]
-  public static extern int switch_codec_implementation_microseconds_per_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_XML_BUFSIZE_get")]
+  public static extern int SWITCH_XML_BUFSIZE_get();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_frame_set")]
-  public static extern void switch_codec_implementation_samples_per_frame_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_name_set")]
+  public static extern void switch_xml_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_samples_per_frame_get")]
-  public static extern uint switch_codec_implementation_samples_per_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_name_get")]
+  public static extern string switch_xml_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bytes_per_frame_set")]
-  public static extern void switch_codec_implementation_bytes_per_frame_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_set")]
+  public static extern void switch_xml_attr_set(HandleRef jarg1, ref string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_bytes_per_frame_get")]
-  public static extern uint switch_codec_implementation_bytes_per_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_get")]
+  public static extern string switch_xml_attr_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encoded_bytes_per_frame_set")]
-  public static extern void switch_codec_implementation_encoded_bytes_per_frame_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_txt_set")]
+  public static extern void switch_xml_txt_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encoded_bytes_per_frame_get")]
-  public static extern uint switch_codec_implementation_encoded_bytes_per_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_txt_get")]
+  public static extern string switch_xml_txt_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_number_of_channels_set")]
-  public static extern void switch_codec_implementation_number_of_channels_set(HandleRef jarg1, byte jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_path_set")]
+  public static extern void switch_xml_free_path_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_number_of_channels_get")]
-  public static extern byte switch_codec_implementation_number_of_channels_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_path_get")]
+  public static extern string switch_xml_free_path_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_pref_frames_per_packet_set")]
-  public static extern void switch_codec_implementation_pref_frames_per_packet_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_off_set")]
+  public static extern void switch_xml_off_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_pref_frames_per_packet_get")]
-  public static extern int switch_codec_implementation_pref_frames_per_packet_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_off_get")]
+  public static extern IntPtr switch_xml_off_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_max_frames_per_packet_set")]
-  public static extern void switch_codec_implementation_max_frames_per_packet_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_next_set")]
+  public static extern void switch_xml_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_max_frames_per_packet_get")]
-  public static extern int switch_codec_implementation_max_frames_per_packet_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_next_get")]
+  public static extern IntPtr switch_xml_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_init_set")]
-  public static extern void switch_codec_implementation_init_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_sibling_set")]
+  public static extern void switch_xml_sibling_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_init_get")]
-  public static extern IntPtr switch_codec_implementation_init_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_sibling_get")]
+  public static extern IntPtr switch_xml_sibling_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encode_set")]
-  public static extern void switch_codec_implementation_encode_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_ordered_set")]
+  public static extern void switch_xml_ordered_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_encode_get")]
-  public static extern IntPtr switch_codec_implementation_encode_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_ordered_get")]
+  public static extern IntPtr switch_xml_ordered_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_decode_set")]
-  public static extern void switch_codec_implementation_decode_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child_set")]
+  public static extern void switch_xml_child_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_decode_get")]
-  public static extern IntPtr switch_codec_implementation_decode_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child_get")]
+  public static extern IntPtr switch_xml_child_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_destroy_set")]
-  public static extern void switch_codec_implementation_destroy_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parent_set")]
+  public static extern void switch_xml_parent_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_destroy_get")]
-  public static extern IntPtr switch_codec_implementation_destroy_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parent_get")]
+  public static extern IntPtr switch_xml_parent_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_id_set")]
-  public static extern void switch_codec_implementation_codec_id_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_flags_set")]
+  public static extern void switch_xml_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_codec_id_get")]
-  public static extern uint switch_codec_implementation_codec_id_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_flags_get")]
+  public static extern uint switch_xml_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_next_set")]
-  public static extern void switch_codec_implementation_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_xml")]
+  public static extern IntPtr new_switch_xml();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_implementation_next_get")]
-  public static extern IntPtr switch_codec_implementation_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_xml")]
+  public static extern void delete_switch_xml(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_implementation")]
-  public static extern IntPtr new_switch_codec_implementation();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_str")]
+  public static extern IntPtr switch_xml_parse_str(string jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_implementation")]
-  public static extern void delete_switch_codec_implementation(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_fd")]
+  public static extern IntPtr switch_xml_parse_fd(int jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_interface_name_set")]
-  public static extern void switch_codec_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_file")]
+  public static extern IntPtr switch_xml_parse_file(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_interface_name_get")]
-  public static extern string switch_codec_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_file_simple")]
+  public static extern IntPtr switch_xml_parse_file_simple(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_implementations_set")]
-  public static extern void switch_codec_interface_implementations_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_fp")]
+  public static extern IntPtr switch_xml_parse_fp(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_implementations_get")]
-  public static extern IntPtr switch_codec_interface_implementations_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child")]
+  public static extern IntPtr switch_xml_child(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_codec_id_set")]
-  public static extern void switch_codec_interface_codec_id_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_find_child")]
+  public static extern IntPtr switch_xml_find_child(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_codec_id_get")]
-  public static extern uint switch_codec_interface_codec_id_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr")]
+  public static extern string switch_xml_attr(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_rwlock_set")]
-  public static extern void switch_codec_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_soft")]
+  public static extern string switch_xml_attr_soft(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_rwlock_get")]
-  public static extern IntPtr switch_codec_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_get")]
+  public static extern IntPtr switch_xml_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_next_set")]
-  public static extern void switch_codec_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_toxml")]
+  public static extern string switch_xml_toxml(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_codec_interface_next_get")]
-  public static extern IntPtr switch_codec_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_toxml_buf")]
+  public static extern string switch_xml_toxml_buf(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_codec_interface")]
-  public static extern IntPtr new_switch_codec_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free")]
+  public static extern void switch_xml_free(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_codec_interface")]
-  public static extern void delete_switch_codec_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_in_thread")]
+  public static extern void switch_xml_free_in_thread(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_interface_name_set")]
-  public static extern void switch_application_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_error")]
+  public static extern string switch_xml_error(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_interface_name_get")]
-  public static extern string switch_application_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_new")]
+  public static extern IntPtr switch_xml_new(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_application_function_set")]
-  public static extern void switch_application_interface_application_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_add_child")]
+  public static extern IntPtr switch_xml_add_child(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_application_function_get")]
-  public static extern IntPtr switch_application_interface_application_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_txt")]
+  public static extern IntPtr switch_xml_set_txt(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_long_desc_set")]
-  public static extern void switch_application_interface_long_desc_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_attr")]
+  public static extern IntPtr switch_xml_set_attr(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_long_desc_get")]
-  public static extern string switch_application_interface_long_desc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_flag")]
+  public static extern IntPtr switch_xml_set_flag(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_short_desc_set")]
-  public static extern void switch_application_interface_short_desc_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_cut")]
+  public static extern IntPtr switch_xml_cut(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_short_desc_get")]
-  public static extern string switch_application_interface_short_desc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_insert")]
+  public static extern IntPtr switch_xml_insert(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_syntax_set")]
-  public static extern void switch_application_interface_syntax_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_open_root")]
+  public static extern IntPtr switch_xml_open_root(byte jarg1, ref string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_syntax_get")]
-  public static extern string switch_application_interface_syntax_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_init")]
+  public static extern int switch_xml_init(HandleRef jarg1, ref string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_flags_set")]
-  public static extern void switch_application_interface_flags_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_destroy")]
+  public static extern int switch_xml_destroy();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_flags_get")]
-  public static extern uint switch_application_interface_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_root")]
+  public static extern IntPtr switch_xml_root();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_rwlock_set")]
-  public static extern void switch_application_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate")]
+  public static extern int switch_xml_locate(string jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, HandleRef jarg6, HandleRef jarg7);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_rwlock_get")]
-  public static extern IntPtr switch_application_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate_domain")]
+  public static extern int switch_xml_locate_domain(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_next_set")]
-  public static extern void switch_application_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate_user")]
+  public static extern int switch_xml_locate_user(string jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_application_interface_next_get")]
-  public static extern IntPtr switch_application_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_open_cfg")]
+  public static extern IntPtr switch_xml_open_cfg(string jarg1, HandleRef jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_application_interface")]
-  public static extern IntPtr new_switch_application_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_bind_search_function")]
+  public static extern int switch_xml_bind_search_function(HandleRef jarg1, uint jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_application_interface")]
-  public static extern void delete_switch_application_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_unbind_search_function")]
+  public static extern int switch_xml_unbind_search_function(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_interface_name_set")]
-  public static extern void switch_api_interface_interface_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_unbind_search_function_ptr")]
+  public static extern int switch_xml_unbind_search_function_ptr(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_interface_name_get")]
-  public static extern string switch_api_interface_interface_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_section_string")]
+  public static extern uint switch_xml_parse_section_string(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_desc_set")]
-  public static extern void switch_api_interface_desc_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_outgoing_channel_set")]
+  public static extern void switch_io_event_hook_outgoing_channel_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_desc_get")]
-  public static extern string switch_api_interface_desc_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_outgoing_channel_get")]
+  public static extern IntPtr switch_io_event_hook_outgoing_channel_outgoing_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_function_set")]
-  public static extern void switch_api_interface_function_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_next_set")]
+  public static extern void switch_io_event_hook_outgoing_channel_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_function_get")]
-  public static extern IntPtr switch_api_interface_function_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_next_get")]
+  public static extern IntPtr switch_io_event_hook_outgoing_channel_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_syntax_set")]
-  public static extern void switch_api_interface_syntax_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_outgoing_channel")]
+  public static extern IntPtr new_switch_io_event_hook_outgoing_channel();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_syntax_get")]
-  public static extern string switch_api_interface_syntax_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_outgoing_channel")]
+  public static extern void delete_switch_io_event_hook_outgoing_channel(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_rwlock_set")]
-  public static extern void switch_api_interface_rwlock_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_receive_message_set")]
+  public static extern void switch_io_event_hook_receive_message_receive_message_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_rwlock_get")]
-  public static extern IntPtr switch_api_interface_rwlock_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_receive_message_get")]
+  public static extern IntPtr switch_io_event_hook_receive_message_receive_message_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_next_set")]
-  public static extern void switch_api_interface_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_next_set")]
+  public static extern void switch_io_event_hook_receive_message_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_api_interface_next_get")]
-  public static extern IntPtr switch_api_interface_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_next_get")]
+  public static extern IntPtr switch_io_event_hook_receive_message_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_api_interface")]
-  public static extern IntPtr new_switch_api_interface();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_receive_message")]
+  public static extern IntPtr new_switch_io_event_hook_receive_message();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_api_interface")]
-  public static extern void delete_switch_api_interface(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_receive_message")]
+  public static extern void delete_switch_io_event_hook_receive_message(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_profile_created_set")]
-  public static extern void switch_channel_timetable_profile_created_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_receive_event_set")]
+  public static extern void switch_io_event_hook_receive_event_receive_event_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_profile_created_get")]
-  public static extern IntPtr switch_channel_timetable_profile_created_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_receive_event_get")]
+  public static extern IntPtr switch_io_event_hook_receive_event_receive_event_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_created_set")]
-  public static extern void switch_channel_timetable_created_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_next_set")]
+  public static extern void switch_io_event_hook_receive_event_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_created_get")]
-  public static extern IntPtr switch_channel_timetable_created_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_next_get")]
+  public static extern IntPtr switch_io_event_hook_receive_event_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_answered_set")]
-  public static extern void switch_channel_timetable_answered_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_receive_event")]
+  public static extern IntPtr new_switch_io_event_hook_receive_event();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_answered_get")]
-  public static extern IntPtr switch_channel_timetable_answered_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_receive_event")]
+  public static extern void delete_switch_io_event_hook_receive_event(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_set")]
-  public static extern void switch_channel_timetable_progress_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_read_frame_set")]
+  public static extern void switch_io_event_hook_read_frame_read_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_get")]
-  public static extern IntPtr switch_channel_timetable_progress_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_read_frame_get")]
+  public static extern IntPtr switch_io_event_hook_read_frame_read_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_media_set")]
-  public static extern void switch_channel_timetable_progress_media_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_next_set")]
+  public static extern void switch_io_event_hook_read_frame_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_progress_media_get")]
-  public static extern IntPtr switch_channel_timetable_progress_media_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_next_get")]
+  public static extern IntPtr switch_io_event_hook_read_frame_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_hungup_set")]
-  public static extern void switch_channel_timetable_hungup_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_read_frame")]
+  public static extern IntPtr new_switch_io_event_hook_read_frame();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_hungup_get")]
-  public static extern IntPtr switch_channel_timetable_hungup_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_read_frame")]
+  public static extern void delete_switch_io_event_hook_read_frame(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_transferred_set")]
-  public static extern void switch_channel_timetable_transferred_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_video_read_frame_set")]
+  public static extern void switch_io_event_hook_video_read_frame_video_read_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_transferred_get")]
-  public static extern IntPtr switch_channel_timetable_transferred_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_video_read_frame_get")]
+  public static extern IntPtr switch_io_event_hook_video_read_frame_video_read_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_next_set")]
-  public static extern void switch_channel_timetable_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_next_set")]
+  public static extern void switch_io_event_hook_video_read_frame_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_timetable_next_get")]
-  public static extern IntPtr switch_channel_timetable_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_next_get")]
+  public static extern IntPtr switch_io_event_hook_video_read_frame_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_channel_timetable")]
-  public static extern IntPtr new_switch_channel_timetable();
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_video_read_frame")]
+  public static extern IntPtr new_switch_io_event_hook_video_read_frame();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_channel_timetable")]
-  public static extern void delete_switch_channel_timetable(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_video_read_frame")]
+  public static extern void delete_switch_io_event_hook_video_read_frame(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_state")]
-  public static extern int switch_channel_get_state(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_write_frame_set")]
+  public static extern void switch_io_event_hook_write_frame_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_running_state")]
-  public static extern int switch_channel_get_running_state(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_write_frame_get")]
+  public static extern IntPtr switch_io_event_hook_write_frame_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_ready")]
-  public static extern byte switch_channel_ready(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_next_set")]
+  public static extern void switch_io_event_hook_write_frame_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_wait_for_state")]
-  public static extern void switch_channel_wait_for_state(HandleRef jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_next_get")]
+  public static extern IntPtr switch_io_event_hook_write_frame_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_wait_for_flag")]
-  public static extern int switch_channel_wait_for_flag(HandleRef jarg1, uint jarg2, int jarg3, uint jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_write_frame")]
+  public static extern IntPtr new_switch_io_event_hook_write_frame();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_set_state")]
-  public static extern int switch_channel_perform_set_state(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_write_frame")]
+  public static extern void delete_switch_io_event_hook_write_frame(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_set_running_state")]
-  public static extern int switch_channel_perform_set_running_state(HandleRef jarg1, int jarg2, string jarg3, string jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_video_write_frame_set")]
+  public static extern void switch_io_event_hook_video_write_frame_video_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_str2cause")]
-  public static extern int switch_channel_str2cause(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_video_write_frame_get")]
+  public static extern IntPtr switch_io_event_hook_video_write_frame_video_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_cause")]
-  public static extern int switch_channel_get_cause(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_next_set")]
+  public static extern void switch_io_event_hook_video_write_frame_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_cause2str")]
-  public static extern string switch_channel_cause2str(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_next_get")]
+  public static extern IntPtr switch_io_event_hook_video_write_frame_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_timetable")]
-  public static extern IntPtr switch_channel_get_timetable(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_video_write_frame")]
+  public static extern IntPtr new_switch_io_event_hook_video_write_frame();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_alloc")]
-  public static extern int switch_channel_alloc(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_video_write_frame")]
+  public static extern void delete_switch_io_event_hook_video_write_frame(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_init")]
-  public static extern int switch_channel_init(HandleRef jarg1, HandleRef jarg2, int jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_kill_channel_set")]
+  public static extern void switch_io_event_hook_kill_channel_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_presence")]
-  public static extern void switch_channel_presence(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_kill_channel_get")]
+  public static extern IntPtr switch_io_event_hook_kill_channel_kill_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_uninit")]
-  public static extern void switch_channel_uninit(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_next_set")]
+  public static extern void switch_io_event_hook_kill_channel_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_caller_profile")]
-  public static extern void switch_channel_set_caller_profile(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_next_get")]
+  public static extern IntPtr switch_io_event_hook_kill_channel_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_caller_profile")]
-  public static extern IntPtr switch_channel_get_caller_profile(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_kill_channel")]
+  public static extern IntPtr new_switch_io_event_hook_kill_channel();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_originator_caller_profile")]
-  public static extern void switch_channel_set_originator_caller_profile(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_kill_channel")]
+  public static extern void delete_switch_io_event_hook_kill_channel(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_originator_caller_profile")]
-  public static extern IntPtr switch_channel_get_originator_caller_profile(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_send_dtmf_set")]
+  public static extern void switch_io_event_hook_send_dtmf_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_originatee_caller_profile")]
-  public static extern void switch_channel_set_originatee_caller_profile(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_send_dtmf_get")]
+  public static extern IntPtr switch_io_event_hook_send_dtmf_send_dtmf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_originatee_caller_profile")]
-  public static extern IntPtr switch_channel_get_originatee_caller_profile(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_next_set")]
+  public static extern void switch_io_event_hook_send_dtmf_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_uuid")]
-  public static extern string switch_channel_get_uuid(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_next_get")]
+  public static extern IntPtr switch_io_event_hook_send_dtmf_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_variable")]
-  public static extern int switch_channel_set_variable(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_send_dtmf")]
+  public static extern IntPtr new_switch_io_event_hook_send_dtmf();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_variable_partner")]
-  public static extern int switch_channel_set_variable_partner(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_send_dtmf")]
+  public static extern void delete_switch_io_event_hook_send_dtmf(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variable_partner")]
-  public static extern string switch_channel_get_variable_partner(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_recv_dtmf_set")]
+  public static extern void switch_io_event_hook_recv_dtmf_recv_dtmf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variable")]
-  public static extern string switch_channel_get_variable(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_recv_dtmf_get")]
+  public static extern IntPtr switch_io_event_hook_recv_dtmf_recv_dtmf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_variables")]
-  public static extern int switch_channel_get_variables(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_next_set")]
+  public static extern void switch_io_event_hook_recv_dtmf_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_variable_first")]
-  public static extern IntPtr switch_channel_variable_first(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_next_get")]
+  public static extern IntPtr switch_io_event_hook_recv_dtmf_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_variable_last")]
-  public static extern void switch_channel_variable_last(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_recv_dtmf")]
+  public static extern IntPtr new_switch_io_event_hook_recv_dtmf();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_caller_extension")]
-  public static extern void switch_channel_set_caller_extension(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_recv_dtmf")]
+  public static extern void delete_switch_io_event_hook_recv_dtmf(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_caller_extension")]
-  public static extern IntPtr switch_channel_get_caller_extension(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_state_change_set")]
+  public static extern void switch_io_event_hook_state_change_state_change_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_test_flag")]
-  public static extern uint switch_channel_test_flag(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_state_change_get")]
+  public static extern IntPtr switch_io_event_hook_state_change_state_change_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_flag")]
-  public static extern void switch_channel_set_flag(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_next_set")]
+  public static extern void switch_io_event_hook_state_change_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_flag_partner")]
-  public static extern int switch_channel_set_flag_partner(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_next_get")]
+  public static extern IntPtr switch_io_event_hook_state_change_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_flag_partner")]
-  public static extern int switch_channel_clear_flag_partner(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_state_change")]
+  public static extern IntPtr new_switch_io_event_hook_state_change();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_state_flag")]
-  public static extern void switch_channel_set_state_flag(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_state_change")]
+  public static extern void delete_switch_io_event_hook_state_change(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_flag")]
-  public static extern void switch_channel_clear_flag(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_resurrect_session_set")]
+  public static extern void switch_io_event_hook_resurrect_session_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_answer")]
-  public static extern int switch_channel_perform_answer(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_resurrect_session_get")]
+  public static extern IntPtr switch_io_event_hook_resurrect_session_resurrect_session_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_answered")]
-  public static extern int switch_channel_perform_mark_answered(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_next_set")]
+  public static extern void switch_io_event_hook_resurrect_session_next_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_ring_ready")]
-  public static extern int switch_channel_perform_ring_ready(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_next_get")]
+  public static extern IntPtr switch_io_event_hook_resurrect_session_next_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_pre_answer")]
-  public static extern int switch_channel_perform_pre_answer(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_resurrect_session")]
+  public static extern IntPtr new_switch_io_event_hook_resurrect_session();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_pre_answered")]
-  public static extern int switch_channel_perform_mark_pre_answered(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_resurrect_session")]
+  public static extern void delete_switch_io_event_hook_resurrect_session(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_mark_ring_ready")]
-  public static extern int switch_channel_perform_mark_ring_ready(HandleRef jarg1, string jarg2, string jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_outgoing_channel_set")]
+  public static extern void switch_io_event_hooks_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_add_state_handler")]
-  public static extern int switch_channel_add_state_handler(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_outgoing_channel_get")]
+  public static extern IntPtr switch_io_event_hooks_outgoing_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_clear_state_handler")]
-  public static extern void switch_channel_clear_state_handler(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_message_set")]
+  public static extern void switch_io_event_hooks_receive_message_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_state_handler")]
-  public static extern IntPtr switch_channel_get_state_handler(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_message_get")]
+  public static extern IntPtr switch_io_event_hooks_receive_message_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_private")]
-  public static extern int switch_channel_set_private(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_event_set")]
+  public static extern void switch_io_event_hooks_receive_event_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_private")]
-  public static extern IntPtr switch_channel_get_private(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_event_get")]
+  public static extern IntPtr switch_io_event_hooks_receive_event_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_name")]
-  public static extern int switch_channel_set_name(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_read_frame_set")]
+  public static extern void switch_io_event_hooks_read_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_get_name")]
-  public static extern string switch_channel_get_name(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_read_frame_get")]
+  public static extern IntPtr switch_io_event_hooks_read_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_perform_hangup")]
-  public static extern int switch_channel_perform_hangup(HandleRef jarg1, string jarg2, string jarg3, int jarg4, int jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_read_frame_set")]
+  public static extern void switch_io_event_hooks_video_read_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_has_dtmf")]
-  public static extern IntPtr switch_channel_has_dtmf(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_read_frame_get")]
+  public static extern IntPtr switch_io_event_hooks_video_read_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_queue_dtmf")]
-  public static extern int switch_channel_queue_dtmf(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_write_frame_set")]
+  public static extern void switch_io_event_hooks_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_queue_dtmf_string")]
-  public static extern int switch_channel_queue_dtmf_string(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_write_frame_get")]
+  public static extern IntPtr switch_io_event_hooks_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_dequeue_dtmf")]
-  public static extern int switch_channel_dequeue_dtmf(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_write_frame_set")]
+  public static extern void switch_io_event_hooks_video_write_frame_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_flush_dtmf")]
-  public static extern void switch_channel_flush_dtmf(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_write_frame_get")]
+  public static extern IntPtr switch_io_event_hooks_video_write_frame_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_dequeue_dtmf_string")]
-  public static extern IntPtr switch_channel_dequeue_dtmf_string(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_kill_channel_set")]
+  public static extern void switch_io_event_hooks_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_state_name")]
-  public static extern string switch_channel_state_name(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_kill_channel_get")]
+  public static extern IntPtr switch_io_event_hooks_kill_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_name_state")]
-  public static extern int switch_channel_name_state(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_send_dtmf_set")]
+  public static extern void switch_io_event_hooks_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_event_set_data")]
-  public static extern void switch_channel_event_set_data(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_send_dtmf_get")]
+  public static extern IntPtr switch_io_event_hooks_send_dtmf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_expand_variables")]
-  public static extern string switch_channel_expand_variables(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_recv_dtmf_set")]
+  public static extern void switch_io_event_hooks_recv_dtmf_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_build_param_string")]
-  public static extern string switch_channel_build_param_string(HandleRef jarg1, HandleRef jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_recv_dtmf_get")]
+  public static extern IntPtr switch_io_event_hooks_recv_dtmf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_channel_set_timestamps")]
-  public static extern int switch_channel_set_timestamps(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_state_change_set")]
+  public static extern void switch_io_event_hooks_state_change_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_create")]
-  public static extern int switch_buffer_create(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_state_change_get")]
+  public static extern IntPtr switch_io_event_hooks_state_change_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_create_dynamic")]
-  public static extern int switch_buffer_create_dynamic(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_resurrect_session_set")]
+  public static extern void switch_io_event_hooks_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_add_mutex")]
-  public static extern void switch_buffer_add_mutex(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_resurrect_session_get")]
+  public static extern IntPtr switch_io_event_hooks_resurrect_session_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_lock")]
-  public static extern void switch_buffer_lock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hooks")]
+  public static extern IntPtr new_switch_io_event_hooks();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_trylock")]
-  public static extern int switch_buffer_trylock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hooks")]
+  public static extern void delete_switch_io_event_hooks(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_unlock")]
-  public static extern void switch_buffer_unlock(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_outgoing_channel")]
+  public static extern int switch_core_event_hook_add_outgoing_channel(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_len")]
-  public static extern IntPtr switch_buffer_len(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_receive_message")]
+  public static extern int switch_core_event_hook_add_receive_message(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_freespace")]
-  public static extern IntPtr switch_buffer_freespace(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_receive_event")]
+  public static extern int switch_core_event_hook_add_receive_event(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_inuse")]
-  public static extern IntPtr switch_buffer_inuse(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_state_change")]
+  public static extern int switch_core_event_hook_add_state_change(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_read")]
-  public static extern IntPtr switch_buffer_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_read_frame")]
+  public static extern int switch_core_event_hook_add_read_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_read_loop")]
-  public static extern IntPtr switch_buffer_read_loop(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_write_frame")]
+  public static extern int switch_core_event_hook_add_write_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_set_loops")]
-  public static extern void switch_buffer_set_loops(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_video_read_frame")]
+  public static extern int switch_core_event_hook_add_video_read_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_write")]
-  public static extern IntPtr switch_buffer_write(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_video_write_frame")]
+  public static extern int switch_core_event_hook_add_video_write_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_toss")]
-  public static extern IntPtr switch_buffer_toss(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_kill_channel")]
+  public static extern int switch_core_event_hook_add_kill_channel(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_zero")]
-  public static extern void switch_buffer_zero(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_send_dtmf")]
+  public static extern int switch_core_event_hook_add_send_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_destroy")]
-  public static extern void switch_buffer_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_recv_dtmf")]
+  public static extern int switch_core_event_hook_add_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_buffer_zwrite")]
-  public static extern IntPtr switch_buffer_zwrite(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_resurrect_session")]
+  public static extern int switch_core_event_hook_add_resurrect_session(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_name_set")]
-  public static extern void switch_event_header_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_outgoing_channel")]
+  public static extern int switch_core_event_hook_remove_outgoing_channel(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_name_get")]
-  public static extern string switch_event_header_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_receive_message")]
+  public static extern int switch_core_event_hook_remove_receive_message(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_value_set")]
-  public static extern void switch_event_header_value_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_receive_event")]
+  public static extern int switch_core_event_hook_remove_receive_event(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_value_get")]
-  public static extern string switch_event_header_value_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_state_change")]
+  public static extern int switch_core_event_hook_remove_state_change(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_next_set")]
-  public static extern void switch_event_header_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_read_frame")]
+  public static extern int switch_core_event_hook_remove_read_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_header_next_get")]
-  public static extern IntPtr switch_event_header_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_write_frame")]
+  public static extern int switch_core_event_hook_remove_write_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_event_header")]
-  public static extern IntPtr new_switch_event_header();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_video_read_frame")]
+  public static extern int switch_core_event_hook_remove_video_read_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_event_header")]
-  public static extern void delete_switch_event_header(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_video_write_frame")]
+  public static extern int switch_core_event_hook_remove_video_write_frame(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_id_set")]
-  public static extern void switch_event_event_id_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_kill_channel")]
+  public static extern int switch_core_event_hook_remove_kill_channel(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_id_get")]
-  public static extern int switch_event_event_id_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_send_dtmf")]
+  public static extern int switch_core_event_hook_remove_send_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_priority_set")]
-  public static extern void switch_event_priority_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_recv_dtmf")]
+  public static extern int switch_core_event_hook_remove_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_priority_get")]
-  public static extern int switch_event_priority_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_resurrect_session")]
+  public static extern int switch_core_event_hook_remove_resurrect_session(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_owner_set")]
-  public static extern void switch_event_owner_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_created_set")]
+  public static extern void switch_scheduler_task_created_set(HandleRef jarg1, long jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_owner_get")]
-  public static extern string switch_event_owner_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_created_get")]
+  public static extern long switch_scheduler_task_created_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_subclass_name_set")]
-  public static extern void switch_event_subclass_name_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_runtime_set")]
+  public static extern void switch_scheduler_task_runtime_set(HandleRef jarg1, long jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_subclass_name_get")]
-  public static extern string switch_event_subclass_name_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_runtime_get")]
+  public static extern long switch_scheduler_task_runtime_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_headers_set")]
-  public static extern void switch_event_headers_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_id_set")]
+  public static extern void switch_scheduler_task_cmd_id_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_headers_get")]
-  public static extern IntPtr switch_event_headers_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_id_get")]
+  public static extern uint switch_scheduler_task_cmd_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_last_header_set")]
-  public static extern void switch_event_last_header_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_group_set")]
+  public static extern void switch_scheduler_task_group_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_last_header_get")]
-  public static extern IntPtr switch_event_last_header_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_group_get")]
+  public static extern string switch_scheduler_task_group_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_body_set")]
-  public static extern void switch_event_body_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_arg_set")]
+  public static extern void switch_scheduler_task_cmd_arg_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_body_get")]
-  public static extern string switch_event_body_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_arg_get")]
+  public static extern IntPtr switch_scheduler_task_cmd_arg_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_user_data_set")]
-  public static extern void switch_event_bind_user_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_task_id_set")]
+  public static extern void switch_scheduler_task_task_id_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_user_data_get")]
-  public static extern IntPtr switch_event_bind_user_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_task_id_get")]
+  public static extern uint switch_scheduler_task_task_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_user_data_set")]
-  public static extern void switch_event_event_user_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_scheduler_task")]
+  public static extern IntPtr new_switch_scheduler_task();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_event_user_data_get")]
-  public static extern IntPtr switch_event_event_user_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_scheduler_task")]
+  public static extern void delete_switch_scheduler_task(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_key_set")]
-  public static extern void switch_event_key_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_add_task")]
+  public static extern uint switch_scheduler_add_task(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, uint jarg5, HandleRef jarg6, uint jarg7);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_key_get")]
-  public static extern uint switch_event_key_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_del_task_id")]
+  public static extern uint switch_scheduler_del_task_id(uint jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_next_set")]
-  public static extern void switch_event_next_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_del_task_group")]
+  public static extern uint switch_scheduler_del_task_group(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_next_get")]
-  public static extern IntPtr switch_event_next_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_thread_start")]
+  public static extern void switch_scheduler_task_thread_start();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_event")]
-  public static extern IntPtr new_switch_event();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_thread_stop")]
+  public static extern void switch_scheduler_task_thread_stop();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_event")]
-  public static extern void delete_switch_event(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_file_set")]
+  public static extern void switch_config_file_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_init")]
-  public static extern int switch_event_init(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_file_get")]
+  public static extern IntPtr switch_config_file_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_shutdown")]
-  public static extern int switch_event_shutdown();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_path_set")]
+  public static extern void switch_config_path_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_create_subclass")]
-  public static extern int switch_event_create_subclass(HandleRef jarg1, int jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_path_get")]
+  public static extern string switch_config_path_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_set_priority")]
-  public static extern int switch_event_set_priority(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_category_set")]
+  public static extern void switch_config_category_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_get_header")]
-  public static extern string switch_event_get_header(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_category_get")]
+  public static extern string switch_config_category_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_get_body")]
-  public static extern string switch_event_get_body(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_section_set")]
+  public static extern void switch_config_section_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_add_header_string")]
-  public static extern int switch_event_add_header_string(HandleRef jarg1, int jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_section_get")]
+  public static extern string switch_config_section_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_del_header")]
-  public static extern int switch_event_del_header(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_buf_set")]
+  public static extern void switch_config_buf_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_destroy")]
-  public static extern void switch_event_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_buf_get")]
+  public static extern string switch_config_buf_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_dup")]
-  public static extern int switch_event_dup(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lineno_set")]
+  public static extern void switch_config_lineno_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_fire_detailed")]
-  public static extern int switch_event_fire_detailed(string jarg1, string jarg2, int jarg3, HandleRef jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lineno_get")]
+  public static extern int switch_config_lineno_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind")]
-  public static extern int switch_event_bind(string jarg1, int jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_catno_set")]
+  public static extern void switch_config_catno_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_bind_removable")]
-  public static extern int switch_event_bind_removable(string jarg1, int jarg2, string jarg3, HandleRef jarg4, HandleRef jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_catno_get")]
+  public static extern int switch_config_catno_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_unbind")]
-  public static extern int switch_event_unbind(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_sectno_set")]
+  public static extern void switch_config_sectno_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_unbind_callback")]
-  public static extern int switch_event_unbind_callback(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_sectno_get")]
+  public static extern int switch_config_sectno_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_name")]
-  public static extern string switch_event_name(int jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lockto_set")]
+  public static extern void switch_config_lockto_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_name_event")]
-  public static extern int switch_name_event(string jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lockto_get")]
+  public static extern int switch_config_lockto_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_reserve_subclass_detailed")]
-  public static extern int switch_event_reserve_subclass_detailed(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_config")]
+  public static extern IntPtr new_switch_config();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_free_subclass_detailed")]
-  public static extern int switch_event_free_subclass_detailed(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_config")]
+  public static extern void delete_switch_config(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_serialize")]
-  public static extern int switch_event_serialize(HandleRef jarg1, ref string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_open_file")]
+  public static extern int switch_config_open_file(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_running")]
-  public static extern int switch_event_running();
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_close_file")]
+  public static extern void switch_config_close_file(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_expand_headers")]
-  public static extern string switch_event_expand_headers(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_next_pair")]
+  public static extern int switch_config_next_pair(HandleRef jarg1, ref string jarg2, ref string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_create_pres_in_detailed")]
-  public static extern int switch_event_create_pres_in_detailed(string jarg1, string jarg2, int jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, string jarg10, int jarg11, string jarg12, string jarg13, string jarg14, string jarg15);
+  [DllImport("mod_managed", EntryPoint="CSharp_consoleLog")]
+  public static extern void consoleLog(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_deliver")]
-  public static extern void switch_event_deliver(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_consoleCleanLog")]
+  public static extern void consoleCleanLog(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_event_build_param_string")]
-  public static extern string switch_event_build_param_string(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_IvrMenu")]
+  public static extern IntPtr new_IvrMenu(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, int jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_resampler_set")]
-  public static extern void switch_audio_resampler_t_resampler_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_IvrMenu")]
+  public static extern void delete_IvrMenu(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_resampler_get")]
-  public static extern IntPtr switch_audio_resampler_t_resampler_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_IvrMenu_bindAction")]
+  public static extern void IvrMenu_bindAction(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_rate_set")]
-  public static extern void switch_audio_resampler_t_from_rate_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_IvrMenu_Execute")]
+  public static extern void IvrMenu_Execute(HandleRef jarg1, HandleRef jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_rate_get")]
-  public static extern int switch_audio_resampler_t_from_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_Api")]
+  public static extern IntPtr new_Api();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_rate_set")]
-  public static extern void switch_audio_resampler_t_to_rate_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_Api")]
+  public static extern void delete_Api(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_rate_get")]
-  public static extern int switch_audio_resampler_t_to_rate_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_Api_Execute")]
+  public static extern string Api_Execute(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_factor_set")]
-  public static extern void switch_audio_resampler_t_factor_set(HandleRef jarg1, double jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Api_ExecuteString")]
+  public static extern string Api_ExecuteString(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_factor_get")]
-  public static extern double switch_audio_resampler_t_factor_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_function_set")]
+  public static extern void input_callback_state_t_function_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_rfactor_set")]
-  public static extern void switch_audio_resampler_t_rfactor_set(HandleRef jarg1, double jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_function_get")]
+  public static extern IntPtr input_callback_state_t_function_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_rfactor_get")]
-  public static extern double switch_audio_resampler_t_rfactor_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_threadState_set")]
+  public static extern void input_callback_state_t_threadState_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_set")]
-  public static extern void switch_audio_resampler_t_from_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_threadState_get")]
+  public static extern IntPtr input_callback_state_t_threadState_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_get")]
-  public static extern IntPtr switch_audio_resampler_t_from_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_extra_set")]
+  public static extern void input_callback_state_t_extra_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_len_set")]
-  public static extern void switch_audio_resampler_t_from_len_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_extra_get")]
+  public static extern IntPtr input_callback_state_t_extra_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_len_get")]
-  public static extern int switch_audio_resampler_t_from_len_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_funcargs_set")]
+  public static extern void input_callback_state_t_funcargs_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_size_set")]
-  public static extern void switch_audio_resampler_t_from_size_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_funcargs_get")]
+  public static extern string input_callback_state_t_funcargs_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_from_size_get")]
-  public static extern IntPtr switch_audio_resampler_t_from_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_input_callback_state_t")]
+  public static extern IntPtr new_input_callback_state_t();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_set")]
-  public static extern void switch_audio_resampler_t_to_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_input_callback_state_t")]
+  public static extern void delete_input_callback_state_t(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_get")]
-  public static extern IntPtr switch_audio_resampler_t_to_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_digit_set")]
+  public static extern void DTMF_digit_set(HandleRef jarg1, char jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_len_set")]
-  public static extern void switch_audio_resampler_t_to_len_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_digit_get")]
+  public static extern char DTMF_digit_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_len_get")]
-  public static extern uint switch_audio_resampler_t_to_len_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_duration_set")]
+  public static extern void DTMF_duration_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_size_set")]
-  public static extern void switch_audio_resampler_t_to_size_set(HandleRef jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_duration_get")]
+  public static extern uint DTMF_duration_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_audio_resampler_t_to_size_get")]
-  public static extern uint switch_audio_resampler_t_to_size_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_DTMF")]
+  public static extern IntPtr new_DTMF(char jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_audio_resampler_t")]
-  public static extern IntPtr new_switch_audio_resampler_t();
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_DTMF")]
+  public static extern void delete_DTMF(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_audio_resampler_t")]
-  public static extern void delete_switch_audio_resampler_t(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_Stream__SWIG_0")]
+  public static extern IntPtr new_Stream__SWIG_0();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_create")]
-  public static extern int switch_resample_create(HandleRef jarg1, int jarg2, HandleRef jarg3, int jarg4, uint jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_Stream__SWIG_1")]
+  public static extern IntPtr new_Stream__SWIG_1(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_destroy")]
-  public static extern void switch_resample_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_Stream")]
+  public static extern void delete_Stream(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_resample_process")]
-  public static extern uint switch_resample_process(HandleRef jarg1, HandleRef jarg2, int jarg3, HandleRef jarg4, uint jarg5, int jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_Stream_Write")]
+  public static extern void Stream_Write(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_float_to_short")]
-  public static extern IntPtr switch_float_to_short(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Stream_get_data")]
+  public static extern string Stream_get_data(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_char_to_float")]
-  public static extern int switch_char_to_float(string jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_InternalEvent_set")]
+  public static extern void Event_InternalEvent_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_float_to_char")]
-  public static extern int switch_float_to_char(HandleRef jarg1, string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_InternalEvent_get")]
+  public static extern IntPtr Event_InternalEvent_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_short_to_float")]
-  public static extern int switch_short_to_float(HandleRef jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_serialized_string_set")]
+  public static extern void Event_serialized_string_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_swap_linear")]
-  public static extern void switch_swap_linear(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_serialized_string_get")]
+  public static extern string Event_serialized_string_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_generate_sln_silence")]
-  public static extern void switch_generate_sln_silence(HandleRef jarg1, uint jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_mine_set")]
+  public static extern void Event_mine_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_change_sln_volume")]
-  public static extern void switch_change_sln_volume(HandleRef jarg1, uint jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_mine_get")]
+  public static extern int Event_mine_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_merge_sln")]
-  public static extern uint switch_merge_sln(HandleRef jarg1, uint jarg2, HandleRef jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_Event__SWIG_0")]
+  public static extern IntPtr new_Event__SWIG_0(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_session_set")]
-  public static extern void switch_unicast_conninfo_session_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_Event__SWIG_1")]
+  public static extern IntPtr new_Event__SWIG_1(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_session_get")]
-  public static extern IntPtr switch_unicast_conninfo_session_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_Event")]
+  public static extern void delete_Event(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_read_codec_set")]
-  public static extern void switch_unicast_conninfo_read_codec_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_Serialize")]
+  public static extern string Event_Serialize(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_read_codec_get")]
-  public static extern IntPtr switch_unicast_conninfo_read_codec_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_SetPriority")]
+  public static extern bool Event_SetPriority(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_set")]
-  public static extern void switch_unicast_conninfo_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetHeader")]
+  public static extern string Event_GetHeader(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_get")]
-  public static extern IntPtr switch_unicast_conninfo_write_frame_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetBody")]
+  public static extern string Event_GetBody(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_data_set")]
-  public static extern void switch_unicast_conninfo_write_frame_data_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetEventType")]
+  public static extern string Event_GetEventType(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_write_frame_data_get")]
-  public static extern IntPtr switch_unicast_conninfo_write_frame_data_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_AddBody")]
+  public static extern bool Event_AddBody(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_socket_set")]
-  public static extern void switch_unicast_conninfo_socket_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_AddHeader")]
+  public static extern bool Event_AddHeader(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_socket_get")]
-  public static extern IntPtr switch_unicast_conninfo_socket_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_DeleteHeader")]
+  public static extern bool Event_DeleteHeader(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_ip_set")]
-  public static extern void switch_unicast_conninfo_local_ip_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_Event_Fire")]
+  public static extern bool Event_Fire(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_ip_get")]
-  public static extern string switch_unicast_conninfo_local_ip_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_events_set")]
+  public static extern void EventConsumer_events_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_port_set")]
-  public static extern void switch_unicast_conninfo_local_port_set(HandleRef jarg1, ushort jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_events_get")]
+  public static extern IntPtr EventConsumer_events_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_port_get")]
-  public static extern ushort switch_unicast_conninfo_local_port_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_event_id_set")]
+  public static extern void EventConsumer_e_event_id_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_ip_set")]
-  public static extern void switch_unicast_conninfo_remote_ip_set(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_event_id_get")]
+  public static extern int EventConsumer_e_event_id_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_ip_get")]
-  public static extern string switch_unicast_conninfo_remote_ip_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_node_set")]
+  public static extern void EventConsumer_node_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_port_set")]
-  public static extern void switch_unicast_conninfo_remote_port_set(HandleRef jarg1, ushort jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_node_get")]
+  public static extern IntPtr EventConsumer_node_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_port_get")]
-  public static extern ushort switch_unicast_conninfo_remote_port_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_callback_set")]
+  public static extern void EventConsumer_e_callback_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_addr_set")]
-  public static extern void switch_unicast_conninfo_local_addr_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_callback_get")]
+  public static extern string EventConsumer_e_callback_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_local_addr_get")]
-  public static extern IntPtr switch_unicast_conninfo_local_addr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_subclass_name_set")]
+  public static extern void EventConsumer_e_subclass_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_addr_set")]
-  public static extern void switch_unicast_conninfo_remote_addr_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_subclass_name_get")]
+  public static extern string EventConsumer_e_subclass_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_remote_addr_get")]
-  public static extern IntPtr switch_unicast_conninfo_remote_addr_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_cb_arg_set")]
+  public static extern void EventConsumer_e_cb_arg_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flag_mutex_set")]
-  public static extern void switch_unicast_conninfo_flag_mutex_set(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_cb_arg_get")]
+  public static extern string EventConsumer_e_cb_arg_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flag_mutex_get")]
-  public static extern IntPtr switch_unicast_conninfo_flag_mutex_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_EventConsumer")]
+  public static extern IntPtr new_EventConsumer(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flags_set")]
-  public static extern void switch_unicast_conninfo_flags_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_EventConsumer")]
+  public static extern void delete_EventConsumer(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_flags_get")]
-  public static extern int switch_unicast_conninfo_flags_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_pop")]
+  public static extern IntPtr EventConsumer_pop(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_type_set")]
-  public static extern void switch_unicast_conninfo_type_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_CoreSession")]
+  public static extern void delete_CoreSession(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_type_get")]
-  public static extern int switch_unicast_conninfo_type_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_InternalSession_set")]
+  public static extern void CoreSession_InternalSession_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_transport_set")]
-  public static extern void switch_unicast_conninfo_transport_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_InternalSession_get")]
+  public static extern IntPtr CoreSession_InternalSession_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_transport_get")]
-  public static extern int switch_unicast_conninfo_transport_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_channel_set")]
+  public static extern void CoreSession_channel_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_stream_id_set")]
-  public static extern void switch_unicast_conninfo_stream_id_set(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_channel_get")]
+  public static extern IntPtr CoreSession_channel_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_unicast_conninfo_stream_id_get")]
-  public static extern int switch_unicast_conninfo_stream_id_get(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flags_set")]
+  public static extern void CoreSession_flags_set(HandleRef jarg1, uint jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_unicast_conninfo")]
-  public static extern IntPtr new_switch_unicast_conninfo();
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flags_get")]
+  public static extern uint CoreSession_flags_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_unicast_conninfo")]
-  public static extern void delete_switch_unicast_conninfo(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_allocated_set")]
+  public static extern void CoreSession_allocated_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_deactivate_unicast")]
-  public static extern int switch_ivr_deactivate_unicast(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_allocated_get")]
+  public static extern int CoreSession_allocated_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_activate_unicast")]
-  public static extern int switch_ivr_activate_unicast(HandleRef jarg1, string jarg2, ushort jarg3, string jarg4, ushort jarg5, string jarg6, string jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_cb_state_set")]
+  public static extern void CoreSession_cb_state_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_generate_xml_cdr")]
-  public static extern int switch_ivr_generate_xml_cdr(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_cb_state_get")]
+  public static extern IntPtr CoreSession_cb_state_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_xml_profile_data")]
-  public static extern int switch_ivr_set_xml_profile_data(HandleRef jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_HookState_set")]
+  public static extern void CoreSession_HookState_set(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_xml_chan_vars")]
-  public static extern int switch_ivr_set_xml_chan_vars(HandleRef jarg1, HandleRef jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_HookState_get")]
+  public static extern int CoreSession_HookState_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_event")]
-  public static extern int switch_ivr_parse_event(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_uuid_set")]
+  public static extern void CoreSession_uuid_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_all_events")]
-  public static extern int switch_ivr_parse_all_events(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_uuid_get")]
+  public static extern string CoreSession_uuid_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_parse_next_event")]
-  public static extern int switch_ivr_parse_next_event(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_tts_name_set")]
+  public static extern void CoreSession_tts_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_sleep")]
-  public static extern int switch_ivr_sleep(HandleRef jarg1, uint jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_tts_name_get")]
+  public static extern string CoreSession_tts_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_park")]
-  public static extern int switch_ivr_park(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_voice_name_set")]
+  public static extern void CoreSession_voice_name_set(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_collect_digits_callback")]
-  public static extern int switch_ivr_collect_digits_callback(HandleRef jarg1, HandleRef jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_voice_name_get")]
+  public static extern string CoreSession_voice_name_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_collect_digits_count")]
-  public static extern int switch_ivr_collect_digits_count(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, string jarg5, string jarg6, uint jarg7, uint jarg8, uint jarg9);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Answer")]
+  public static extern int CoreSession_Answer(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech")]
-  public static extern int switch_ivr_detect_speech(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_preAnswer")]
+  public static extern int CoreSession_preAnswer(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_detect_speech")]
-  public static extern int switch_ivr_stop_detect_speech(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Hangup")]
+  public static extern void CoreSession_Hangup(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_pause_detect_speech")]
-  public static extern int switch_ivr_pause_detect_speech(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetVariable")]
+  public static extern void CoreSession_SetVariable(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_resume_detect_speech")]
-  public static extern int switch_ivr_resume_detect_speech(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetPrivate")]
+  public static extern void CoreSession_SetPrivate(HandleRef jarg1, string jarg2, HandleRef jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech_load_grammar")]
-  public static extern int switch_ivr_detect_speech_load_grammar(HandleRef jarg1, string jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetPrivate")]
+  public static extern IntPtr CoreSession_GetPrivate(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_detect_speech_unload_grammar")]
-  public static extern int switch_ivr_detect_speech_unload_grammar(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetVariable")]
+  public static extern string CoreSession_GetVariable(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_record_session")]
-  public static extern int switch_ivr_record_session(HandleRef jarg1, string jarg2, uint jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Say")]
+  public static extern void CoreSession_Say(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_eavesdrop_session")]
-  public static extern int switch_ivr_eavesdrop_session(HandleRef jarg1, string jarg2, string jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SayPhrase")]
+  public static extern void CoreSession_SayPhrase(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_displace_session")]
-  public static extern int switch_ivr_displace_session(HandleRef jarg1, string jarg2, uint jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_RecordFile")]
+  public static extern int CoreSession_RecordFile(HandleRef jarg1, string jarg2, int jarg3, int jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_displace_session")]
-  public static extern int switch_ivr_stop_displace_session(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetCallerData")]
+  public static extern void CoreSession_SetCallerData(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_record_session")]
-  public static extern int switch_ivr_stop_record_session(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Originate")]
+  public static extern int CoreSession_Originate(HandleRef jarg1, HandleRef jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_inband_dtmf_session")]
-  public static extern int switch_ivr_inband_dtmf_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_destroy")]
+  public static extern void CoreSession_destroy(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_inband_dtmf_session")]
-  public static extern int switch_ivr_stop_inband_dtmf_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Speak")]
+  public static extern int CoreSession_Speak(HandleRef jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_inband_dtmf_generate_session")]
-  public static extern int switch_ivr_inband_dtmf_generate_session(HandleRef jarg1, int jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetTtsParameters")]
+  public static extern void CoreSession_SetTtsParameters(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_inband_dtmf_generate_session")]
-  public static extern int switch_ivr_stop_inband_dtmf_generate_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_CollectDigits")]
+  public static extern int CoreSession_CollectDigits(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_session_echo")]
-  public static extern void switch_ivr_session_echo(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetDigits__SWIG_0")]
+  public static extern string CoreSession_GetDigits__SWIG_0(HandleRef jarg1, int jarg2, string jarg3, int jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_stop_tone_detect_session")]
-  public static extern int switch_ivr_stop_tone_detect_session(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetDigits__SWIG_1")]
+  public static extern string CoreSession_GetDigits__SWIG_1(HandleRef jarg1, int jarg2, string jarg3, int jarg4, int jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_tone_detect_session")]
-  public static extern int switch_ivr_tone_detect_session(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, string jarg6, string jarg7);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Transfer")]
+  public static extern int CoreSession_Transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_play_file")]
-  public static extern int switch_ivr_play_file(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_read")]
+  public static extern string CoreSession_read(HandleRef jarg1, int jarg2, int jarg3, string jarg4, int jarg5, string jarg6);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_wait_for_silence")]
-  public static extern int switch_ivr_wait_for_silence(HandleRef jarg1, uint jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_PlayAndGetDigits")]
+  public static extern string CoreSession_PlayAndGetDigits(HandleRef jarg1, int jarg2, int jarg3, int jarg4, int jarg5, string jarg6, string jarg7, string jarg8, string jarg9);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_gentones")]
-  public static extern int switch_ivr_gentones(HandleRef jarg1, string jarg2, int jarg3, HandleRef jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_StreamFile")]
+  public static extern int CoreSession_StreamFile(HandleRef jarg1, string jarg2, int jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_record_file")]
-  public static extern int switch_ivr_record_file(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4, uint jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_sleep")]
+  public static extern int CoreSession_sleep(HandleRef jarg1, int jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_play_and_get_digits")]
-  public static extern int switch_play_and_get_digits(HandleRef jarg1, uint jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6, string jarg7, string jarg8, HandleRef jarg9, uint jarg10, string jarg11);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flushEvents")]
+  public static extern int CoreSession_flushEvents(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_speak_text_handle")]
-  public static extern int switch_ivr_speak_text_handle(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, string jarg5, HandleRef jarg6);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flushDigits")]
+  public static extern int CoreSession_flushDigits(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_clear_speech_cache")]
-  public static extern void switch_ivr_clear_speech_cache(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetAutoHangup")]
+  public static extern int CoreSession_SetAutoHangup(HandleRef jarg1, bool jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_speak_text")]
-  public static extern int switch_ivr_speak_text(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Ready")]
+  public static extern bool CoreSession_Ready(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_originate")]
-  public static extern int switch_ivr_originate(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, string jarg4, uint jarg5, HandleRef jarg6, string jarg7, string jarg8, HandleRef jarg9, uint jarg10);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_answered")]
+  public static extern bool CoreSession_answered(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_multi_threaded_bridge")]
-  public static extern int switch_ivr_multi_threaded_bridge(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_mediaReady")]
+  public static extern bool CoreSession_mediaReady(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_signal_bridge")]
-  public static extern int switch_ivr_signal_bridge(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_waitForAnswer")]
+  public static extern void CoreSession_waitForAnswer(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_session_transfer")]
-  public static extern int switch_ivr_session_transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Execute")]
+  public static extern void CoreSession_Execute(HandleRef jarg1, string jarg2, string jarg3);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_transfer")]
-  public static extern uint switch_ivr_schedule_transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_sendEvent")]
+  public static extern void CoreSession_sendEvent(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_hangup")]
-  public static extern uint switch_ivr_schedule_hangup(HandleRef jarg1, string jarg2, int jarg3, int jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_setEventData")]
+  public static extern void CoreSession_setEventData(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_uuid_bridge")]
-  public static extern int switch_ivr_uuid_bridge(string jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_getXMLCDR")]
+  public static extern string CoreSession_getXMLCDR(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_media")]
-  public static extern int switch_ivr_media(string jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_begin_allow_threads")]
+  public static extern bool CoreSession_begin_allow_threads(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_nomedia")]
-  public static extern int switch_ivr_nomedia(string jarg1, uint jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_end_allow_threads")]
+  public static extern bool CoreSession_end_allow_threads(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_hold_uuid")]
-  public static extern int switch_ivr_hold_uuid(string jarg1, string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetUuid")]
+  public static extern string CoreSession_GetUuid(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unhold_uuid")]
-  public static extern int switch_ivr_unhold_uuid(string jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_get_cb_args")]
+  public static extern IntPtr CoreSession_get_cb_args(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_hold")]
-  public static extern int switch_ivr_hold(HandleRef jarg1, string jarg2, int jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_check_hangup_hook")]
+  public static extern void CoreSession_check_hangup_hook(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unhold")]
-  public static extern int switch_ivr_unhold(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_console_log")]
+  public static extern void console_log(string jarg1, string jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_schedule_broadcast")]
-  public static extern uint switch_ivr_schedule_broadcast(HandleRef jarg1, string jarg2, string jarg3, uint jarg4);
+  [DllImport("mod_managed", EntryPoint="CSharp_console_clean_log")]
+  public static extern void console_clean_log(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_broadcast")]
-  public static extern int switch_ivr_broadcast(string jarg1, string jarg2, uint jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_bridge")]
+  public static extern void bridge(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_transfer_variable")]
-  public static extern int switch_ivr_transfer_variable(HandleRef jarg1, HandleRef jarg2, string jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_hanguphook")]
+  public static extern int hanguphook(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_new")]
-  public static extern int switch_ivr_digit_stream_parser_new(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_dtmf_callback")]
+  public static extern int dtmf_callback(HandleRef jarg1, HandleRef jarg2, int jarg3, HandleRef jarg4, uint jarg5);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_destroy")]
-  public static extern int switch_ivr_digit_stream_parser_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_0")]
+  public static extern IntPtr new_ManagedSession__SWIG_0();
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_new")]
-  public static extern int switch_ivr_digit_stream_new(HandleRef jarg1, HandleRef jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_1")]
+  public static extern IntPtr new_ManagedSession__SWIG_1(string jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_destroy")]
-  public static extern int switch_ivr_digit_stream_destroy(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_2")]
+  public static extern IntPtr new_ManagedSession__SWIG_2(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_set_event")]
-  public static extern int switch_ivr_digit_stream_parser_set_event(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_delete_ManagedSession")]
+  public static extern void delete_ManagedSession(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_del_event")]
-  public static extern int switch_ivr_digit_stream_parser_del_event(HandleRef jarg1, string jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSession_dtmfDelegate_set")]
+  public static extern void ManagedSession_dtmfDelegate_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_feed")]
-  public static extern IntPtr switch_ivr_digit_stream_parser_feed(HandleRef jarg1, HandleRef jarg2, char jarg3);
+  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSession_dtmfDelegate_get")]
+  public static extern IntPtr ManagedSession_dtmfDelegate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_reset")]
-  public static extern int switch_ivr_digit_stream_reset(HandleRef jarg1);
+  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSession_hangupDelegate_set")]
+  public static extern void ManagedSession_hangupDelegate_set(HandleRef jarg1, HandleRef jarg2);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_digit_stream_parser_set_terminator")]
-  public static extern int switch_ivr_digit_stream_parser_set_terminator(HandleRef jarg1, char jarg2);
+  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSession_hangupDelegate_get")]
+  public static extern IntPtr ManagedSession_hangupDelegate_get(HandleRef jarg1);
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_init")]
-  public static extern int switch_ivr_menu_init(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, string jarg9, int jarg10, int jarg11, int jarg12, int jarg13, int jarg14, HandleRef jarg15);
+  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSessionUpcast")]
+  public static extern IntPtr ManagedSessionUpcast(IntPtr objectRef);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_bind_action")]
-  public static extern int switch_ivr_menu_bind_action(HandleRef jarg1, int jarg2, string jarg3, string jarg4);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_bind_function")]
-  public static extern int switch_ivr_menu_bind_function(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_execute")]
-  public static extern int switch_ivr_menu_execute(HandleRef jarg1, HandleRef jarg2, string jarg3, HandleRef jarg4);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_free")]
-  public static extern int switch_ivr_menu_stack_free(HandleRef jarg1);
+public class SWIGTYPE_p_f_void__void {
+  private HandleRef swigCPtr;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_build")]
-  public static extern int switch_ivr_menu_stack_xml_build(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  internal SWIGTYPE_p_f_void__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_str2action")]
-  public static extern int switch_ivr_menu_str2action(string jarg1, HandleRef jarg2);
+  protected SWIGTYPE_p_f_void__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_add_custom")]
-  public static extern int switch_ivr_menu_stack_xml_add_custom(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_void__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_menu_stack_xml_init")]
-  public static extern int switch_ivr_menu_stack_xml_init(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_phrase_macro")]
-  public static extern int switch_ivr_phrase_macro(HandleRef jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_delay_echo")]
-  public static extern void switch_ivr_delay_echo(HandleRef jarg1, uint jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_find_bridged_uuid")]
-  public static extern int switch_ivr_find_bridged_uuid(string jarg1, string jarg2, HandleRef jarg3);
+public class SWIGTYPE_p_switch_queue_t {
+  private HandleRef swigCPtr;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_intercept_session")]
-  public static extern void switch_ivr_intercept_session(HandleRef jarg1, string jarg2, int jarg3);
+  internal SWIGTYPE_p_switch_queue_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_park_session")]
-  public static extern void switch_ivr_park_session(HandleRef jarg1);
+  protected SWIGTYPE_p_switch_queue_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_wait_for_answer")]
-  public static extern int switch_ivr_wait_for_answer(HandleRef jarg1, HandleRef jarg2);
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_queue_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_read")]
-  public static extern int switch_ivr_read(HandleRef jarg1, uint jarg2, uint jarg3, string jarg4, string jarg5, string jarg6, HandleRef jarg7, uint jarg8, string jarg9);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_bind_dtmf_meta_session")]
-  public static extern int switch_ivr_bind_dtmf_meta_session(HandleRef jarg1, uint jarg2, uint jarg3, string jarg4);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_unbind_dtmf_meta_session")]
-  public static extern int switch_ivr_unbind_dtmf_meta_session(HandleRef jarg1);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_soft_hold")]
-  public static extern int switch_ivr_soft_hold(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+public class SWIGTYPE_p_f_p_void__void {
+  private HandleRef swigCPtr;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_say")]
-  public static extern int switch_ivr_say(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, HandleRef jarg6);
+  internal SWIGTYPE_p_f_p_void__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_get_say_method_by_name")]
-  public static extern int switch_ivr_get_say_method_by_name(string jarg1);
+  protected SWIGTYPE_p_f_p_void__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_get_say_type_by_name")]
-  public static extern int switch_ivr_get_say_type_by_name(string jarg1);
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_void__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_ivr_set_user")]
-  public static extern int switch_ivr_set_user(HandleRef jarg1, string jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_MAX_BUF_LEN_get")]
-  public static extern int SWITCH_RTP_MAX_BUF_LEN_get();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_MAX_CRYPTO_LEN_get")]
-  public static extern int SWITCH_RTP_MAX_CRYPTO_LEN_get();
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_KEY_LEN_get")]
-  public static extern int SWITCH_RTP_KEY_LEN_get();
+public class SWIGTYPE_p_f_p_switch_event__void {
+  private HandleRef swigCPtr;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CRYPTO_KEY_32_get")]
-  public static extern string SWITCH_RTP_CRYPTO_KEY_32_get();
+  internal SWIGTYPE_p_f_p_switch_event__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_RTP_CRYPTO_KEY_80_get")]
-  public static extern string SWITCH_RTP_CRYPTO_KEY_80_get();
+  protected SWIGTYPE_p_f_p_switch_event__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_index_set")]
-  public static extern void switch_rtp_crypto_key_index_set(HandleRef jarg1, uint jarg2);
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_event__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_index_get")]
-  public static extern uint switch_rtp_crypto_key_index_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_type_set")]
-  public static extern void switch_rtp_crypto_key_type_set(HandleRef jarg1, int jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_type_get")]
-  public static extern int switch_rtp_crypto_key_type_get(HandleRef jarg1);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_key_set")]
-  public static extern void switch_rtp_crypto_key_key_set(HandleRef jarg1, HandleRef jarg2);
+public class SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int {
+  private HandleRef swigCPtr;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_key_get")]
-  public static extern IntPtr switch_rtp_crypto_key_key_get(HandleRef jarg1);
+  internal SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_keylen_set")]
-  public static extern void switch_rtp_crypto_key_keylen_set(HandleRef jarg1, HandleRef jarg2);
+  protected SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_keylen_get")]
-  public static extern IntPtr switch_rtp_crypto_key_keylen_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_next_set")]
-  public static extern void switch_rtp_crypto_key_next_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_crypto_key_next_get")]
-  public static extern IntPtr switch_rtp_crypto_key_next_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_rtp_crypto_key")]
-  public static extern IntPtr new_switch_rtp_crypto_key();
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_rtp_crypto_key")]
-  public static extern void delete_switch_rtp_crypto_key(HandleRef jarg1);
+public class switch_dtmf_t : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_add_crypto_key")]
-  public static extern int switch_rtp_add_crypto_key(HandleRef jarg1, int jarg2, uint jarg3, int jarg4, HandleRef jarg5, HandleRef jarg6);
+  internal switch_dtmf_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_random")]
-  public static extern void switch_rtp_get_random(HandleRef jarg1, uint jarg2);
+  internal static HandleRef getCPtr(switch_dtmf_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_init")]
-  public static extern void switch_rtp_init(HandleRef jarg1);
+  ~switch_dtmf_t() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_shutdown")]
-  public static extern void switch_rtp_shutdown();
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_dtmf_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_start_port")]
-  public static extern ushort switch_rtp_set_start_port(ushort jarg1);
+  public char digit {
+    set {
+      freeswitchPINVOKE.switch_dtmf_t_digit_set(swigCPtr, value);
+    } 
+    get {
+      char ret = freeswitchPINVOKE.switch_dtmf_t_digit_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_end_port")]
-  public static extern ushort switch_rtp_set_end_port(ushort jarg1);
+  public uint duration {
+    set {
+      freeswitchPINVOKE.switch_dtmf_t_duration_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_dtmf_t_duration_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_request_port")]
-  public static extern ushort switch_rtp_request_port(string jarg1);
+  public switch_dtmf_t() : this(freeswitchPINVOKE.new_switch_dtmf_t(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_release_port")]
-  public static extern void switch_rtp_release_port(string jarg1, ushort jarg2);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_create")]
-  public static extern int switch_rtp_create(HandleRef jarg1, byte jarg2, uint jarg3, uint jarg4, uint jarg5, string jarg6, ref string jarg7, HandleRef jarg8);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_new")]
-  public static extern IntPtr switch_rtp_new(string jarg1, ushort jarg2, string jarg3, ushort jarg4, byte jarg5, uint jarg6, uint jarg7, uint jarg8, string jarg9, ref string jarg10, HandleRef jarg11);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_remote_address")]
-  public static extern int switch_rtp_set_remote_address(HandleRef jarg1, string jarg2, ushort jarg3, ref string jarg4);
+[System.Flags] public enum switch_bind_flag_enum_t {
+  SBF_DIAL_ALEG = (1 << 0),
+  SBF_EXEC_ALEG = (1 << 1),
+  SBF_DIAL_BLEG = (1 << 2),
+  SBF_EXEC_BLEG = (1 << 3),
+  SBF_EXEC_OPPOSITE = (1 << 4),
+  SBF_EXEC_SAME = (1 << 5)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_remote_host")]
-  public static extern string switch_rtp_get_remote_host(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_remote_port")]
-  public static extern ushort switch_rtp_get_remote_port(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_max_missed_packets")]
-  public static extern void switch_rtp_set_max_missed_packets(HandleRef jarg1, uint jarg2);
+public enum switch_dtmf_direction_t {
+  SWITCH_DTMF_RECV = 0,
+  SWITCH_DTMF_SEND = 1
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_local_address")]
-  public static extern int switch_rtp_set_local_address(HandleRef jarg1, string jarg2, ushort jarg3, ref string jarg4);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_kill_socket")]
-  public static extern void switch_rtp_kill_socket(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_break")]
-  public static extern void switch_rtp_break(HandleRef jarg1);
+[System.Flags] public enum switch_originate_flag_enum_t {
+  SOF_NONE = 0,
+  SOF_NOBLOCK = (1 << 0),
+  SOF_FORKED_DIAL = (1 << 1),
+  SOF_NO_EFFECTIVE_CID_NUM = (1 << 2),
+  SOF_NO_EFFECTIVE_CID_NAME = (1 << 3)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_ready")]
-  public static extern byte switch_rtp_ready(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_destroy")]
-  public static extern void switch_rtp_destroy(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_ice")]
-  public static extern int switch_rtp_activate_ice(HandleRef jarg1, string jarg2, string jarg3);
+[System.Flags] public enum switch_port_flag_enum_t {
+  SPF_NONE = 0,
+  SPF_ODD = (1 << 0),
+  SPF_EVEN = (1 << 1)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_jitter_buffer")]
-  public static extern int switch_rtp_activate_jitter_buffer(HandleRef jarg1, uint jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_flag")]
-  public static extern void switch_rtp_set_flag(HandleRef jarg1, uint jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_test_flag")]
-  public static extern uint switch_rtp_test_flag(HandleRef jarg1, uint jarg2);
+[System.Flags] public enum switch_eavesdrop_flag_enum_t {
+  ED_MUX_READ = (1 << 0),
+  ED_MUX_WRITE = (1 << 1),
+  ED_DTMF = (1 << 2)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_clear_flag")]
-  public static extern void switch_rtp_clear_flag(HandleRef jarg1, uint jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_rtp_socket")]
-  public static extern IntPtr switch_rtp_get_rtp_socket(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_default_samples_per_interval")]
-  public static extern void switch_rtp_set_default_samples_per_interval(HandleRef jarg1, ushort jarg2);
+[System.Flags] public enum switch_core_flag_enum_t {
+  SCF_NONE = 0,
+  SCF_USE_SQL = (1 << 0),
+  SCF_NO_NEW_SESSIONS = (1 << 1),
+  SCF_SHUTTING_DOWN = (1 << 2),
+  SCF_CRASH_PROT = (1 << 3),
+  SCF_VG = (1 << 4),
+  SCF_RESTART = (1 << 5),
+  SCF_SHUTDOWN_REQUESTED = (1 << 6)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_default_samples_per_interval")]
-  public static extern uint switch_rtp_get_default_samples_per_interval(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_default_payload")]
-  public static extern void switch_rtp_set_default_payload(HandleRef jarg1, byte jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_default_payload")]
-  public static extern uint switch_rtp_get_default_payload(HandleRef jarg1);
+public enum switch_module_interface_name_t {
+  SWITCH_ENDPOINT_INTERFACE,
+  SWITCH_TIMER_INTERFACE,
+  SWITCH_DIALPLAN_INTERFACE,
+  SWITCH_CODEC_INTERFACE,
+  SWITCH_APPLICATION_INTERFACE,
+  SWITCH_API_INTERFACE,
+  SWITCH_FILE_INTERFACE,
+  SWITCH_SPEECH_INTERFACE,
+  SWITCH_DIRECTORY_INTERFACE,
+  SWITCH_CHAT_INTERFACE,
+  SWITCH_SAY_INTERFACE,
+  SWITCH_ASR_INTERFACE,
+  SWITCH_MANAGEMENT_INTERFACE
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_invald_handler")]
-  public static extern void switch_rtp_set_invald_handler(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_read")]
-  public static extern int switch_rtp_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, uint jarg6);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_queue_rfc2833")]
-  public static extern int switch_rtp_queue_rfc2833(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_unicast_flag_enum_t {
+  SUF_NONE = 0,
+  SUF_THREAD_RUNNING = (1 << 0),
+  SUF_READY = (1 << 1),
+  SUF_NATIVE = (1 << 2)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_queue_rfc2833_in")]
-  public static extern int switch_rtp_queue_rfc2833_in(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_has_dtmf")]
-  public static extern IntPtr switch_rtp_has_dtmf(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_dequeue_dtmf")]
-  public static extern IntPtr switch_rtp_dequeue_dtmf(HandleRef jarg1, HandleRef jarg2);
+public enum switch_bool_t {
+  SWITCH_FALSE = 0,
+  SWITCH_TRUE = 1
+}
+
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_zerocopy_read")]
-  public static extern int switch_rtp_zerocopy_read(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4, HandleRef jarg5, uint jarg6);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_zerocopy_read_frame")]
-  public static extern int switch_rtp_zerocopy_read_frame(HandleRef jarg1, HandleRef jarg2, uint jarg3);
+public enum switch_say_method_t {
+  SSM_NA,
+  SSM_PRONOUNCED,
+  SSM_ITERATED,
+  SSM_COUNTED
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_enable_vad")]
-  public static extern int switch_rtp_enable_vad(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3, uint jarg4);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_disable_vad")]
-  public static extern int switch_rtp_disable_vad(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_write_frame")]
-  public static extern int switch_rtp_write_frame(HandleRef jarg1, HandleRef jarg2);
+public enum switch_say_type_t {
+  SST_NUMBER,
+  SST_ITEMS,
+  SST_PERSONS,
+  SST_MESSAGES,
+  SST_CURRENCY,
+  SST_TIME_MEASUREMENT,
+  SST_CURRENT_DATE,
+  SST_CURRENT_TIME,
+  SST_CURRENT_DATE_TIME,
+  SST_TELEPHONE_NUMBER,
+  SST_TELEPHONE_EXTENSION,
+  SST_URL,
+  SST_IP_ADDRESS,
+  SST_EMAIL_ADDRESS,
+  SST_POSTAL_ADDRESS,
+  SST_ACCOUNT_NUMBER,
+  SST_NAME_SPELLED,
+  SST_NAME_PHONETIC
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_write_manual")]
-  public static extern int switch_rtp_write_manual(HandleRef jarg1, HandleRef jarg2, uint jarg3, byte jarg4, byte jarg5, uint jarg6, HandleRef jarg7);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_ssrc")]
-  public static extern uint switch_rtp_get_ssrc(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_private")]
-  public static extern void switch_rtp_set_private(HandleRef jarg1, HandleRef jarg2);
+public enum switch_management_action_t {
+  SMA_NONE,
+  SMA_GET,
+  SMA_SET
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_telephony_event")]
-  public static extern void switch_rtp_set_telephony_event(HandleRef jarg1, byte jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_set_cng_pt")]
-  public static extern void switch_rtp_set_cng_pt(HandleRef jarg1, byte jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_get_private")]
-  public static extern IntPtr switch_rtp_get_private(HandleRef jarg1);
+[System.Flags] public enum switch_scheduler_flag_enum_t {
+  SSHF_NONE = 0,
+  SSHF_OWN_THREAD = (1 << 0),
+  SSHF_FREE_ARG = (1 << 1),
+  SSHF_NO_DEL = (1 << 2)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_rtp_activate_stun_ping")]
-  public static extern int switch_rtp_activate_stun_ping(HandleRef jarg1, string jarg2, ushort jarg3, uint jarg4, int jarg5);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_data_set")]
-  public static extern void switch_log_node_t_data_set(HandleRef jarg1, string jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_data_get")]
-  public static extern string switch_log_node_t_data_get(HandleRef jarg1);
+[System.Flags] public enum switch_media_flag_enum_t {
+  SMF_NONE = 0,
+  SMF_REBRIDGE = (1 << 0),
+  SMF_ECHO_ALEG = (1 << 1),
+  SMF_ECHO_BLEG = (1 << 2),
+  SMF_FORCE = (1 << 3),
+  SMF_LOOP = (1 << 4),
+  SMF_HOLD_BLEG = (1 << 5),
+  SMF_IMMEDIATE = (1 << 6)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_file_set")]
-  public static extern void switch_log_node_t_file_set(HandleRef jarg1, string jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_file_get")]
-  public static extern string switch_log_node_t_file_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_line_set")]
-  public static extern void switch_log_node_t_line_set(HandleRef jarg1, uint jarg2);
+public enum switch_bitpack_mode_t {
+  SWITCH_BITPACK_MODE_RFC3551,
+  SWITCH_BITPACK_MODE_AAL2
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_line_get")]
-  public static extern uint switch_log_node_t_line_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_func_set")]
-  public static extern void switch_log_node_t_func_set(HandleRef jarg1, string jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_func_get")]
-  public static extern string switch_log_node_t_func_get(HandleRef jarg1);
+public enum switch_abc_type_t {
+  SWITCH_ABC_TYPE_INIT,
+  SWITCH_ABC_TYPE_READ,
+  SWITCH_ABC_TYPE_WRITE,
+  SWITCH_ABC_TYPE_WRITE_REPLACE,
+  SWITCH_ABC_TYPE_READ_REPLACE,
+  SWITCH_ABC_TYPE_READ_PING,
+  SWITCH_ABC_TYPE_CLOSE
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_level_set")]
-  public static extern void switch_log_node_t_level_set(HandleRef jarg1, int jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_level_get")]
-  public static extern int switch_log_node_t_level_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_timestamp_set")]
-  public static extern void switch_log_node_t_timestamp_set(HandleRef jarg1, HandleRef jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_timestamp_get")]
-  public static extern IntPtr switch_log_node_t_timestamp_get(HandleRef jarg1);
+public class switch_bitpack_t : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_content_set")]
-  public static extern void switch_log_node_t_content_set(HandleRef jarg1, string jarg2);
+  internal switch_bitpack_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_content_get")]
-  public static extern string switch_log_node_t_content_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_bitpack_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_userdata_set")]
-  public static extern void switch_log_node_t_userdata_set(HandleRef jarg1, string jarg2);
+  ~switch_bitpack_t() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_node_t_userdata_get")]
-  public static extern string switch_log_node_t_userdata_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_bitpack_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_log_node_t")]
-  public static extern IntPtr new_switch_log_node_t();
+  public SWIGTYPE_p_unsigned_char buf {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_buf_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_bitpack_t_buf_get(swigCPtr);
+      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_log_node_t")]
-  public static extern void delete_switch_log_node_t(HandleRef jarg1);
+  public uint buflen {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_buflen_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_bitpack_t_buflen_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_init")]
-  public static extern int switch_log_init(HandleRef jarg1, int jarg2);
+  public SWIGTYPE_p_unsigned_char cur {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_cur_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_bitpack_t_cur_get(swigCPtr);
+      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_shutdown")]
-  public static extern int switch_log_shutdown();
+  public uint bytes {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_bytes_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_bitpack_t_bytes_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_bind_logger")]
-  public static extern int switch_log_bind_logger(HandleRef jarg1, int jarg2, int jarg3);
+  public uint bits_tot {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_bits_tot_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_bitpack_t_bits_tot_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public byte bits_cur {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_bits_cur_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_bits_cur_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_unbind_logger")]
-  public static extern int switch_log_unbind_logger(HandleRef jarg1);
+  public byte bits_rem {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_bits_rem_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_bits_rem_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_level2str")]
-  public static extern string switch_log_level2str(int jarg1);
+  public byte frame_bits {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_frame_bits_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_frame_bits_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_str2level")]
-  public static extern int switch_log_str2level(string jarg1);
+  public byte shiftby {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_shiftby_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_shiftby_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_log_str2mask")]
-  public static extern uint switch_log_str2mask(string jarg1);
+  public byte this_byte {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_this_byte_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_this_byte_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_SWITCH_XML_BUFSIZE_get")]
-  public static extern int SWITCH_XML_BUFSIZE_get();
+  public byte under {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_under_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_under_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_name_set")]
-  public static extern void switch_xml_name_set(HandleRef jarg1, string jarg2);
+  public byte over {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_over_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_bitpack_t_over_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_name_get")]
-  public static extern string switch_xml_name_get(HandleRef jarg1);
+  public switch_bitpack_mode_t mode {
+    set {
+      freeswitchPINVOKE.switch_bitpack_t_mode_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_bitpack_mode_t ret = (switch_bitpack_mode_t)freeswitchPINVOKE.switch_bitpack_t_mode_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_set")]
-  public static extern void switch_xml_attr_set(HandleRef jarg1, ref string jarg2);
+  public switch_bitpack_t() : this(freeswitchPINVOKE.new_switch_bitpack_t(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_get")]
-  public static extern string switch_xml_attr_get(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_txt_set")]
-  public static extern void switch_xml_txt_set(HandleRef jarg1, string jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_txt_get")]
-  public static extern string switch_xml_txt_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_path_set")]
-  public static extern void switch_xml_free_path_set(HandleRef jarg1, string jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_path_get")]
-  public static extern string switch_xml_free_path_get(HandleRef jarg1);
+public class switch_directories : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_off_set")]
-  public static extern void switch_xml_off_set(HandleRef jarg1, HandleRef jarg2);
+  internal switch_directories(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_off_get")]
-  public static extern IntPtr switch_xml_off_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_directories obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_next_set")]
-  public static extern void switch_xml_next_set(HandleRef jarg1, HandleRef jarg2);
+  ~switch_directories() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_next_get")]
-  public static extern IntPtr switch_xml_next_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_directories(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_sibling_set")]
-  public static extern void switch_xml_sibling_set(HandleRef jarg1, HandleRef jarg2);
+  public string base_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_base_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_base_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_sibling_get")]
-  public static extern IntPtr switch_xml_sibling_get(HandleRef jarg1);
+  public string mod_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_mod_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_mod_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_ordered_set")]
-  public static extern void switch_xml_ordered_set(HandleRef jarg1, HandleRef jarg2);
+  public string conf_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_conf_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_conf_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_ordered_get")]
-  public static extern IntPtr switch_xml_ordered_get(HandleRef jarg1);
+  public string log_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_log_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_log_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child_set")]
-  public static extern void switch_xml_child_set(HandleRef jarg1, HandleRef jarg2);
+  public string db_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_db_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_db_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child_get")]
-  public static extern IntPtr switch_xml_child_get(HandleRef jarg1);
+  public string script_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_script_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_script_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parent_set")]
-  public static extern void switch_xml_parent_set(HandleRef jarg1, HandleRef jarg2);
+  public string temp_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_temp_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_temp_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parent_get")]
-  public static extern IntPtr switch_xml_parent_get(HandleRef jarg1);
+  public string htdocs_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_htdocs_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_htdocs_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_flags_set")]
-  public static extern void switch_xml_flags_set(HandleRef jarg1, uint jarg2);
+  public string grammar_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_grammar_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_grammar_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_flags_get")]
-  public static extern uint switch_xml_flags_get(HandleRef jarg1);
+  public string storage_dir {
+    set {
+      freeswitchPINVOKE.switch_directories_storage_dir_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directories_storage_dir_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_xml")]
-  public static extern IntPtr new_switch_xml();
+  public switch_directories() : this(freeswitchPINVOKE.new_switch_directories(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_xml")]
-  public static extern void delete_switch_xml(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_str")]
-  public static extern IntPtr switch_xml_parse_str(string jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_fd")]
-  public static extern IntPtr switch_xml_parse_fd(int jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_file")]
-  public static extern IntPtr switch_xml_parse_file(string jarg1);
+[System.Flags] public enum switch_caller_profile_flag_enum_t {
+  SWITCH_CPF_SCREEN = (1 << 0),
+  SWITCH_CPF_HIDE_NAME = (1 << 1),
+  SWITCH_CPF_HIDE_NUMBER = (1 << 2)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_file_simple")]
-  public static extern IntPtr switch_xml_parse_file_simple(string jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_fp")]
-  public static extern IntPtr switch_xml_parse_fp(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_child")]
-  public static extern IntPtr switch_xml_child(HandleRef jarg1, string jarg2);
+public enum switch_audio_col_t {
+  SWITCH_AUDIO_COL_STR_TITLE = 0x01,
+  SWITCH_AUDIO_COL_STR_COPYRIGHT = 0x02,
+  SWITCH_AUDIO_COL_STR_SOFTWARE = 0x03,
+  SWITCH_AUDIO_COL_STR_ARTIST = 0x04,
+  SWITCH_AUDIO_COL_STR_COMMENT = 0x05,
+  SWITCH_AUDIO_COL_STR_DATE = 0x06
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_find_child")]
-  public static extern IntPtr switch_xml_find_child(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr")]
-  public static extern string switch_xml_attr(HandleRef jarg1, string jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_attr_soft")]
-  public static extern string switch_xml_attr_soft(HandleRef jarg1, string jarg2);
+[System.Flags] public enum switch_xml_section_enum_t {
+  SWITCH_XML_SECTION_RESULT = 0,
+  SWITCH_XML_SECTION_CONFIG = (1 << 0),
+  SWITCH_XML_SECTION_DIRECTORY = (1 << 1),
+  SWITCH_XML_SECTION_DIALPLAN = (1 << 2),
+  SWITCH_XML_SECTION_PHRASES = (1 << 3)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_get")]
-  public static extern IntPtr switch_xml_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_toxml")]
-  public static extern string switch_xml_toxml(HandleRef jarg1, int jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_toxml_buf")]
-  public static extern string switch_xml_toxml_buf(HandleRef jarg1, string jarg2, HandleRef jarg3, HandleRef jarg4, int jarg5);
+[System.Flags] public enum switch_vad_flag_enum_t {
+  SWITCH_VAD_FLAG_TALKING = (1 << 0),
+  SWITCH_VAD_FLAG_EVENTS_TALK = (1 << 1),
+  SWITCH_VAD_FLAG_EVENTS_NOTALK = (1 << 2),
+  SWITCH_VAD_FLAG_CNG = (1 << 3)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free")]
-  public static extern void switch_xml_free(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_free_in_thread")]
-  public static extern void switch_xml_free_in_thread(HandleRef jarg1, int jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_error")]
-  public static extern string switch_xml_error(HandleRef jarg1);
+[System.Flags] public enum switch_rtp_flag_enum_t {
+  SWITCH_RTP_FLAG_NOBLOCK = (1 << 0),
+  SWITCH_RTP_FLAG_IO = (1 << 1),
+  SWITCH_RTP_FLAG_USE_TIMER = (1 << 2),
+  SWITCH_RTP_FLAG_TIMER_RECLOCK = (1 << 3),
+  SWITCH_RTP_FLAG_SECURE_SEND = (1 << 4),
+  SWITCH_RTP_FLAG_SECURE_RECV = (1 << 5),
+  SWITCH_RTP_FLAG_AUTOADJ = (1 << 6),
+  SWITCH_RTP_FLAG_RAW_WRITE = (1 << 7),
+  SWITCH_RTP_FLAG_GOOGLEHACK = (1 << 8),
+  SWITCH_RTP_FLAG_VAD = (1 << 9),
+  SWITCH_RTP_FLAG_BREAK = (1 << 10),
+  SWITCH_RTP_FLAG_MINI = (1 << 11),
+  SWITCH_RTP_FLAG_DATAWAIT = (1 << 12),
+  SWITCH_RTP_FLAG_BUGGY_2833 = (1 << 13),
+  SWITCH_RTP_FLAG_PASS_RFC2833 = (1 << 14),
+  SWITCH_RTP_FLAG_AUTO_CNG = (1 << 15),
+  SWITCH_RTP_FLAG_SECURE_SEND_RESET = (1 << 16),
+  SWITCH_RTP_FLAG_SECURE_RECV_RESET = (1 << 17),
+  SWITCH_RTP_FLAG_PROXY_MEDIA = (1 << 18),
+  SWITCH_RTP_FLAG_SHUTDOWN = (1 << 19)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_new")]
-  public static extern IntPtr switch_xml_new(string jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_add_child")]
-  public static extern IntPtr switch_xml_add_child(HandleRef jarg1, string jarg2, HandleRef jarg3);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_txt")]
-  public static extern IntPtr switch_xml_set_txt(HandleRef jarg1, string jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_attr")]
-  public static extern IntPtr switch_xml_set_attr(HandleRef jarg1, string jarg2, string jarg3);
+public class switch_rtp_hdr_t : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_set_flag")]
-  public static extern IntPtr switch_xml_set_flag(HandleRef jarg1, int jarg2);
+  internal switch_rtp_hdr_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_cut")]
-  public static extern IntPtr switch_xml_cut(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_rtp_hdr_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_insert")]
-  public static extern IntPtr switch_xml_insert(HandleRef jarg1, HandleRef jarg2, HandleRef jarg3);
+  ~switch_rtp_hdr_t() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_open_root")]
-  public static extern IntPtr switch_xml_open_root(byte jarg1, ref string jarg2);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_rtp_hdr_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_init")]
-  public static extern int switch_xml_init(HandleRef jarg1, ref string jarg2);
+  public uint version {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_version_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_version_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_destroy")]
-  public static extern int switch_xml_destroy();
+  public uint p {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_p_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_p_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_root")]
-  public static extern IntPtr switch_xml_root();
+  public uint x {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_x_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_x_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate")]
-  public static extern int switch_xml_locate(string jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, HandleRef jarg6, HandleRef jarg7);
+  public uint cc {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_cc_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_cc_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate_domain")]
-  public static extern int switch_xml_locate_domain(string jarg1, HandleRef jarg2, HandleRef jarg3, HandleRef jarg4);
+  public uint m {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_m_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_m_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_locate_user")]
-  public static extern int switch_xml_locate_user(string jarg1, string jarg2, string jarg3, string jarg4, HandleRef jarg5, HandleRef jarg6, HandleRef jarg7, HandleRef jarg8);
+  public uint pt {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_pt_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_pt_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_open_cfg")]
-  public static extern IntPtr switch_xml_open_cfg(string jarg1, HandleRef jarg2, HandleRef jarg3);
+  public uint seq {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_seq_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_seq_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_bind_search_function")]
-  public static extern int switch_xml_bind_search_function(HandleRef jarg1, uint jarg2, HandleRef jarg3);
+  public uint ts {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_ts_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_ts_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_unbind_search_function")]
-  public static extern int switch_xml_unbind_search_function(HandleRef jarg1);
+  public uint ssrc {
+    set {
+      freeswitchPINVOKE.switch_rtp_hdr_t_ssrc_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_ssrc_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_unbind_search_function_ptr")]
-  public static extern int switch_xml_unbind_search_function_ptr(HandleRef jarg1);
+  public switch_rtp_hdr_t() : this(freeswitchPINVOKE.new_switch_rtp_hdr_t(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_xml_parse_section_string")]
-  public static extern uint switch_xml_parse_section_string(string jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_outgoing_channel_set")]
-  public static extern void switch_io_event_hook_outgoing_channel_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_outgoing_channel_get")]
-  public static extern IntPtr switch_io_event_hook_outgoing_channel_outgoing_channel_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_next_set")]
-  public static extern void switch_io_event_hook_outgoing_channel_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_priority_t {
+  SWITCH_PRIORITY_NORMAL,
+  SWITCH_PRIORITY_LOW,
+  SWITCH_PRIORITY_HIGH
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_outgoing_channel_next_get")]
-  public static extern IntPtr switch_io_event_hook_outgoing_channel_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_outgoing_channel")]
-  public static extern IntPtr new_switch_io_event_hook_outgoing_channel();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_outgoing_channel")]
-  public static extern void delete_switch_io_event_hook_outgoing_channel(HandleRef jarg1);
+public enum switch_ivr_option_enum_t {
+  SWITCH_IVR_OPTION_NONE = 0,
+  SWITCH_IVR_OPTION_ASYNC = (1 << 0),
+  SWITCH_IVR_OPTION_FILE = (1 << 1)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_receive_message_set")]
-  public static extern void switch_io_event_hook_receive_message_receive_message_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_receive_message_get")]
-  public static extern IntPtr switch_io_event_hook_receive_message_receive_message_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_next_set")]
-  public static extern void switch_io_event_hook_receive_message_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_core_session_message_types_t {
+  SWITCH_MESSAGE_REDIRECT_AUDIO,
+  SWITCH_MESSAGE_TRANSMIT_TEXT,
+  SWITCH_MESSAGE_INDICATE_ANSWER,
+  SWITCH_MESSAGE_INDICATE_PROGRESS,
+  SWITCH_MESSAGE_INDICATE_BRIDGE,
+  SWITCH_MESSAGE_INDICATE_UNBRIDGE,
+  SWITCH_MESSAGE_INDICATE_TRANSFER,
+  SWITCH_MESSAGE_INDICATE_RINGING,
+  SWITCH_MESSAGE_INDICATE_MEDIA,
+  SWITCH_MESSAGE_INDICATE_NOMEDIA,
+  SWITCH_MESSAGE_INDICATE_HOLD,
+  SWITCH_MESSAGE_INDICATE_UNHOLD,
+  SWITCH_MESSAGE_INDICATE_REDIRECT,
+  SWITCH_MESSAGE_INDICATE_RESPOND,
+  SWITCH_MESSAGE_INDICATE_BROADCAST,
+  SWITCH_MESSAGE_INDICATE_MEDIA_REDIRECT,
+  SWITCH_MESSAGE_INDICATE_DEFLECT,
+  SWITCH_MESSAGE_INDICATE_VIDEO_REFRESH_REQ,
+  SWITCH_MESSAGE_INDICATE_DISPLAY,
+  SWITCH_MESSAGE_INDICATE_TRANSCODING_NECESSARY
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_message_next_get")]
-  public static extern IntPtr switch_io_event_hook_receive_message_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_receive_message")]
-  public static extern IntPtr new_switch_io_event_hook_receive_message();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_receive_message")]
-  public static extern void delete_switch_io_event_hook_receive_message(HandleRef jarg1);
+public enum switch_stack_t {
+  SWITCH_STACK_BOTTOM,
+  SWITCH_STACK_TOP
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_receive_event_set")]
-  public static extern void switch_io_event_hook_receive_event_receive_event_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_receive_event_get")]
-  public static extern IntPtr switch_io_event_hook_receive_event_receive_event_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_next_set")]
-  public static extern void switch_io_event_hook_receive_event_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_status_t {
+  SWITCH_STATUS_SUCCESS,
+  SWITCH_STATUS_FALSE,
+  SWITCH_STATUS_TIMEOUT,
+  SWITCH_STATUS_RESTART,
+  SWITCH_STATUS_TERM,
+  SWITCH_STATUS_NOTIMPL,
+  SWITCH_STATUS_MEMERR,
+  SWITCH_STATUS_NOOP,
+  SWITCH_STATUS_RESAMPLE,
+  SWITCH_STATUS_GENERR,
+  SWITCH_STATUS_INUSE,
+  SWITCH_STATUS_BREAK,
+  SWITCH_STATUS_SOCKERR,
+  SWITCH_STATUS_MORE_DATA,
+  SWITCH_STATUS_NOTFOUND,
+  SWITCH_STATUS_UNLOAD,
+  SWITCH_STATUS_NOUNLOAD,
+  SWITCH_STATUS_IGNORE
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_receive_event_next_get")]
-  public static extern IntPtr switch_io_event_hook_receive_event_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_receive_event")]
-  public static extern IntPtr new_switch_io_event_hook_receive_event();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_receive_event")]
-  public static extern void delete_switch_io_event_hook_receive_event(HandleRef jarg1);
+public enum switch_log_level_t {
+  SWITCH_LOG_DEBUG = 7,
+  SWITCH_LOG_INFO = 6,
+  SWITCH_LOG_NOTICE = 5,
+  SWITCH_LOG_WARNING = 4,
+  SWITCH_LOG_ERROR = 3,
+  SWITCH_LOG_CRIT = 2,
+  SWITCH_LOG_ALERT = 1,
+  SWITCH_LOG_CONSOLE = 0,
+  SWITCH_LOG_INVALID = 64
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_read_frame_set")]
-  public static extern void switch_io_event_hook_read_frame_read_frame_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_read_frame_get")]
-  public static extern IntPtr switch_io_event_hook_read_frame_read_frame_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_next_set")]
-  public static extern void switch_io_event_hook_read_frame_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_text_channel_t {
+  SWITCH_CHANNEL_ID_LOG,
+  SWITCH_CHANNEL_ID_LOG_CLEAN,
+  SWITCH_CHANNEL_ID_EVENT
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_read_frame_next_get")]
-  public static extern IntPtr switch_io_event_hook_read_frame_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_read_frame")]
-  public static extern IntPtr new_switch_io_event_hook_read_frame();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_read_frame")]
-  public static extern void delete_switch_io_event_hook_read_frame(HandleRef jarg1);
+[System.Flags] public enum switch_core_session_message_flag_enum_t {
+  SCSMF_DYNAMIC = (1 << 0)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_video_read_frame_set")]
-  public static extern void switch_io_event_hook_video_read_frame_video_read_frame_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_video_read_frame_get")]
-  public static extern IntPtr switch_io_event_hook_video_read_frame_video_read_frame_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_next_set")]
-  public static extern void switch_io_event_hook_video_read_frame_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_channel_state_t {
+  CS_NEW,
+  CS_INIT,
+  CS_ROUTING,
+  CS_SOFT_EXECUTE,
+  CS_EXECUTE,
+  CS_EXCHANGE_MEDIA,
+  CS_PARK,
+  CS_CONSUME_MEDIA,
+  CS_HIBERNATE,
+  CS_RESET,
+  CS_HANGUP,
+  CS_DONE,
+  CS_NONE
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_read_frame_next_get")]
-  public static extern IntPtr switch_io_event_hook_video_read_frame_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_video_read_frame")]
-  public static extern IntPtr new_switch_io_event_hook_video_read_frame();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_video_read_frame")]
-  public static extern void delete_switch_io_event_hook_video_read_frame(HandleRef jarg1);
+[System.Flags] public enum switch_channel_flag_enum_t {
+  CF_ANSWERED = (1 << 0),
+  CF_OUTBOUND = (1 << 1),
+  CF_EARLY_MEDIA = (1 << 2),
+  CF_ORIGINATOR = (1 << 3),
+  CF_TRANSFER = (1 << 4),
+  CF_ACCEPT_CNG = (1 << 5),
+  CF_WAIT_FOR_ME = (1 << 6),
+  CF_BRIDGED = (1 << 7),
+  CF_HOLD = (1 << 8),
+  CF_SERVICE = (1 << 9),
+  CF_TAGGED = (1 << 10),
+  CF_WINNER = (1 << 11),
+  CF_CONTROLLED = (1 << 12),
+  CF_PROXY_MODE = (1 << 13),
+  CF_SUSPEND = (1 << 14),
+  CF_EVENT_PARSE = (1 << 15),
+  CF_REPEAT_STATE = (1 << 16),
+  CF_GEN_RINGBACK = (1 << 17),
+  CF_RING_READY = (1 << 18),
+  CF_BREAK = (1 << 19),
+  CF_BROADCAST = (1 << 20),
+  CF_UNICAST = (1 << 21),
+  CF_VIDEO = (1 << 22),
+  CF_EVENT_LOCK = (1 << 23),
+  CF_RESET = (1 << 24),
+  CF_ORIGINATING = (1 << 25),
+  CF_STOP_BROADCAST = (1 << 26),
+  CF_PROXY_MEDIA = (1 << 27),
+  CF_INNER_BRIDGE = (1 << 28),
+  CF_REQ_MEDIA = (1 << 29),
+  CF_VERBOSE_EVENTS = (1 << 30)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_write_frame_set")]
-  public static extern void switch_io_event_hook_write_frame_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_write_frame_get")]
-  public static extern IntPtr switch_io_event_hook_write_frame_write_frame_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_next_set")]
-  public static extern void switch_io_event_hook_write_frame_next_set(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_frame_flag_enum_t {
+  SFF_NONE = 0,
+  SFF_CNG = (1 << 0),
+  SFF_RAW_RTP = (1 << 1),
+  SFF_RTP_HEADER = (1 << 2),
+  SFF_PLC = (1 << 3),
+  SFF_RFC2833 = (1 << 4),
+  SFF_PROXY_PACKET = (1 << 5)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_write_frame_next_get")]
-  public static extern IntPtr switch_io_event_hook_write_frame_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_write_frame")]
-  public static extern IntPtr new_switch_io_event_hook_write_frame();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_write_frame")]
-  public static extern void delete_switch_io_event_hook_write_frame(HandleRef jarg1);
+[System.Flags] public enum switch_application_flag_enum_t {
+  SAF_NONE = 0,
+  SAF_SUPPORT_NOMEDIA = (1 << 0)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_video_write_frame_set")]
-  public static extern void switch_io_event_hook_video_write_frame_video_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_video_write_frame_get")]
-  public static extern IntPtr switch_io_event_hook_video_write_frame_video_write_frame_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_next_set")]
-  public static extern void switch_io_event_hook_video_write_frame_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_signal_t {
+  SWITCH_SIG_NONE,
+  SWITCH_SIG_KILL,
+  SWITCH_SIG_XFER,
+  SWITCH_SIG_BREAK
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_video_write_frame_next_get")]
-  public static extern IntPtr switch_io_event_hook_video_write_frame_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_video_write_frame")]
-  public static extern IntPtr new_switch_io_event_hook_video_write_frame();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_video_write_frame")]
-  public static extern void delete_switch_io_event_hook_video_write_frame(HandleRef jarg1);
+[System.Flags] public enum switch_codec_flag_enum_t {
+  SWITCH_CODEC_FLAG_ENCODE = (1 << 0),
+  SWITCH_CODEC_FLAG_DECODE = (1 << 1),
+  SWITCH_CODEC_FLAG_SILENCE_START = (1 << 2),
+  SWITCH_CODEC_FLAG_SILENCE_STOP = (1 << 3),
+  SWITCH_CODEC_FLAG_SILENCE = (1 << 4),
+  SWITCH_CODEC_FLAG_FREE_POOL = (1 << 5),
+  SWITCH_CODEC_FLAG_AAL2 = (1 << 6),
+  SWITCH_CODEC_FLAG_PASSTHROUGH = (1 << 7)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_kill_channel_set")]
-  public static extern void switch_io_event_hook_kill_channel_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_kill_channel_get")]
-  public static extern IntPtr switch_io_event_hook_kill_channel_kill_channel_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_next_set")]
-  public static extern void switch_io_event_hook_kill_channel_next_set(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_speech_flag_enum_t {
+  SWITCH_SPEECH_FLAG_NONE = 0,
+  SWITCH_SPEECH_FLAG_HASTEXT = (1 << 0),
+  SWITCH_SPEECH_FLAG_PEEK = (1 << 1),
+  SWITCH_SPEECH_FLAG_FREE_POOL = (1 << 2),
+  SWITCH_SPEECH_FLAG_BLOCKING = (1 << 3),
+  SWITCH_SPEECH_FLAG_PAUSE = (1 << 4)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_kill_channel_next_get")]
-  public static extern IntPtr switch_io_event_hook_kill_channel_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_kill_channel")]
-  public static extern IntPtr new_switch_io_event_hook_kill_channel();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_kill_channel")]
-  public static extern void delete_switch_io_event_hook_kill_channel(HandleRef jarg1);
+[System.Flags] public enum switch_asr_flag_enum_t {
+  SWITCH_ASR_FLAG_NONE = 0,
+  SWITCH_ASR_FLAG_DATA = (1 << 0),
+  SWITCH_ASR_FLAG_FREE_POOL = (1 << 1),
+  SWITCH_ASR_FLAG_CLOSED = (1 << 2),
+  SWITCH_ASR_FLAG_FIRE_EVENTS = (1 << 3),
+  SWITCH_ASR_FLAG_AUTO_RESUME = (1 << 4)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_send_dtmf_set")]
-  public static extern void switch_io_event_hook_send_dtmf_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_send_dtmf_get")]
-  public static extern IntPtr switch_io_event_hook_send_dtmf_send_dtmf_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_next_set")]
-  public static extern void switch_io_event_hook_send_dtmf_next_set(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_directory_flag_enum_t {
+  SWITCH_DIRECTORY_FLAG_FREE_POOL = (1 << 0)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_send_dtmf_next_get")]
-  public static extern IntPtr switch_io_event_hook_send_dtmf_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_send_dtmf")]
-  public static extern IntPtr new_switch_io_event_hook_send_dtmf();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_send_dtmf")]
-  public static extern void delete_switch_io_event_hook_send_dtmf(HandleRef jarg1);
+public enum switch_codec_type_t {
+  SWITCH_CODEC_TYPE_AUDIO,
+  SWITCH_CODEC_TYPE_VIDEO,
+  SWITCH_CODEC_TYPE_T38,
+  SWITCH_CODEC_TYPE_APP
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_recv_dtmf_set")]
-  public static extern void switch_io_event_hook_recv_dtmf_recv_dtmf_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_recv_dtmf_get")]
-  public static extern IntPtr switch_io_event_hook_recv_dtmf_recv_dtmf_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_next_set")]
-  public static extern void switch_io_event_hook_recv_dtmf_next_set(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_timer_flag_enum_t {
+  SWITCH_TIMER_FLAG_FREE_POOL = (1 << 0)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_recv_dtmf_next_get")]
-  public static extern IntPtr switch_io_event_hook_recv_dtmf_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_recv_dtmf")]
-  public static extern IntPtr new_switch_io_event_hook_recv_dtmf();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_recv_dtmf")]
-  public static extern void delete_switch_io_event_hook_recv_dtmf(HandleRef jarg1);
+[System.Flags] public enum switch_media_bug_flag_enum_t {
+  SMBF_BOTH = 0,
+  SMBF_READ_STREAM = (1 << 0),
+  SMBF_WRITE_STREAM = (1 << 1),
+  SMBF_WRITE_REPLACE = (1 << 2),
+  SMBF_READ_REPLACE = (1 << 3),
+  SMBF_READ_PING = (1 << 4),
+  SMBF_STEREO = (1 << 5),
+  SMBF_RECORD_ANSWER_REQ = (1 << 6),
+  SMBF_THREAD_LOCK = (1 << 7)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_state_change_set")]
-  public static extern void switch_io_event_hook_state_change_state_change_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_state_change_get")]
-  public static extern IntPtr switch_io_event_hook_state_change_state_change_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_next_set")]
-  public static extern void switch_io_event_hook_state_change_next_set(HandleRef jarg1, HandleRef jarg2);
+[System.Flags] public enum switch_file_flag_enum_t {
+  SWITCH_FILE_FLAG_READ = (1 << 0),
+  SWITCH_FILE_FLAG_WRITE = (1 << 1),
+  SWITCH_FILE_FLAG_FREE_POOL = (1 << 2),
+  SWITCH_FILE_DATA_SHORT = (1 << 3),
+  SWITCH_FILE_DATA_INT = (1 << 4),
+  SWITCH_FILE_DATA_FLOAT = (1 << 5),
+  SWITCH_FILE_DATA_DOUBLE = (1 << 6),
+  SWITCH_FILE_DATA_RAW = (1 << 7),
+  SWITCH_FILE_PAUSE = (1 << 8),
+  SWITCH_FILE_NATIVE = (1 << 9),
+  SWITCH_FILE_SEEK = (1 << 10),
+  SWITCH_FILE_OPEN = (1 << 11),
+  SWITCH_FILE_CALLBACK = (1 << 12)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_state_change_next_get")]
-  public static extern IntPtr switch_io_event_hook_state_change_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_state_change")]
-  public static extern IntPtr new_switch_io_event_hook_state_change();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_state_change")]
-  public static extern void delete_switch_io_event_hook_state_change(HandleRef jarg1);
+[System.Flags] public enum switch_io_flag_enum_t {
+  SWITCH_IO_FLAG_NONE = 0,
+  SWITCH_IO_FLAG_NOBLOCK = (1 << 0)
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_resurrect_session_set")]
-  public static extern void switch_io_event_hook_resurrect_session_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_resurrect_session_get")]
-  public static extern IntPtr switch_io_event_hook_resurrect_session_resurrect_session_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_next_set")]
-  public static extern void switch_io_event_hook_resurrect_session_next_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_event_types_t {
+  SWITCH_EVENT_CUSTOM,
+  SWITCH_EVENT_CHANNEL_CREATE,
+  SWITCH_EVENT_CHANNEL_DESTROY,
+  SWITCH_EVENT_CHANNEL_STATE,
+  SWITCH_EVENT_CHANNEL_ANSWER,
+  SWITCH_EVENT_CHANNEL_HANGUP,
+  SWITCH_EVENT_CHANNEL_EXECUTE,
+  SWITCH_EVENT_CHANNEL_EXECUTE_COMPLETE,
+  SWITCH_EVENT_CHANNEL_BRIDGE,
+  SWITCH_EVENT_CHANNEL_UNBRIDGE,
+  SWITCH_EVENT_CHANNEL_PROGRESS,
+  SWITCH_EVENT_CHANNEL_PROGRESS_MEDIA,
+  SWITCH_EVENT_CHANNEL_OUTGOING,
+  SWITCH_EVENT_CHANNEL_PARK,
+  SWITCH_EVENT_CHANNEL_UNPARK,
+  SWITCH_EVENT_CHANNEL_APPLICATION,
+  SWITCH_EVENT_CHANNEL_ORIGINATE,
+  SWITCH_EVENT_API,
+  SWITCH_EVENT_LOG,
+  SWITCH_EVENT_INBOUND_CHAN,
+  SWITCH_EVENT_OUTBOUND_CHAN,
+  SWITCH_EVENT_STARTUP,
+  SWITCH_EVENT_SHUTDOWN,
+  SWITCH_EVENT_PUBLISH,
+  SWITCH_EVENT_UNPUBLISH,
+  SWITCH_EVENT_TALK,
+  SWITCH_EVENT_NOTALK,
+  SWITCH_EVENT_SESSION_CRASH,
+  SWITCH_EVENT_MODULE_LOAD,
+  SWITCH_EVENT_MODULE_UNLOAD,
+  SWITCH_EVENT_DTMF,
+  SWITCH_EVENT_MESSAGE,
+  SWITCH_EVENT_PRESENCE_IN,
+  SWITCH_EVENT_PRESENCE_OUT,
+  SWITCH_EVENT_PRESENCE_PROBE,
+  SWITCH_EVENT_MESSAGE_WAITING,
+  SWITCH_EVENT_MESSAGE_QUERY,
+  SWITCH_EVENT_ROSTER,
+  SWITCH_EVENT_CODEC,
+  SWITCH_EVENT_BACKGROUND_JOB,
+  SWITCH_EVENT_DETECTED_SPEECH,
+  SWITCH_EVENT_DETECTED_TONE,
+  SWITCH_EVENT_PRIVATE_COMMAND,
+  SWITCH_EVENT_HEARTBEAT,
+  SWITCH_EVENT_TRAP,
+  SWITCH_EVENT_ADD_SCHEDULE,
+  SWITCH_EVENT_DEL_SCHEDULE,
+  SWITCH_EVENT_EXE_SCHEDULE,
+  SWITCH_EVENT_RE_SCHEDULE,
+  SWITCH_EVENT_RELOADXML,
+  SWITCH_EVENT_NOTIFY,
+  SWITCH_EVENT_SEND_MESSAGE,
+  SWITCH_EVENT_RECV_MESSAGE,
+  SWITCH_EVENT_REQUEST_PARAMS,
+  SWITCH_EVENT_CHANNEL_DATA,
+  SWITCH_EVENT_GENERAL,
+  SWITCH_EVENT_COMMAND,
+  SWITCH_EVENT_ALL
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hook_resurrect_session_next_get")]
-  public static extern IntPtr switch_io_event_hook_resurrect_session_next_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hook_resurrect_session")]
-  public static extern IntPtr new_switch_io_event_hook_resurrect_session();
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hook_resurrect_session")]
-  public static extern void delete_switch_io_event_hook_resurrect_session(HandleRef jarg1);
+public enum switch_input_type_t {
+  SWITCH_INPUT_TYPE_DTMF,
+  SWITCH_INPUT_TYPE_EVENT
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_outgoing_channel_set")]
-  public static extern void switch_io_event_hooks_outgoing_channel_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_outgoing_channel_get")]
-  public static extern IntPtr switch_io_event_hooks_outgoing_channel_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_message_set")]
-  public static extern void switch_io_event_hooks_receive_message_set(HandleRef jarg1, HandleRef jarg2);
+public enum switch_call_cause_t {
+  SWITCH_CAUSE_NONE = 0,
+  SWITCH_CAUSE_UNALLOCATED_NUMBER = 1,
+  SWITCH_CAUSE_NO_ROUTE_TRANSIT_NET = 2,
+  SWITCH_CAUSE_NO_ROUTE_DESTINATION = 3,
+  SWITCH_CAUSE_CHANNEL_UNACCEPTABLE = 6,
+  SWITCH_CAUSE_CALL_AWARDED_DELIVERED = 7,
+  SWITCH_CAUSE_NORMAL_CLEARING = 16,
+  SWITCH_CAUSE_USER_BUSY = 17,
+  SWITCH_CAUSE_NO_USER_RESPONSE = 18,
+  SWITCH_CAUSE_NO_ANSWER = 19,
+  SWITCH_CAUSE_SUBSCRIBER_ABSENT = 20,
+  SWITCH_CAUSE_CALL_REJECTED = 21,
+  SWITCH_CAUSE_NUMBER_CHANGED = 22,
+  SWITCH_CAUSE_REDIRECTION_TO_NEW_DESTINATION = 23,
+  SWITCH_CAUSE_EXCHANGE_ROUTING_ERROR = 25,
+  SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER = 27,
+  SWITCH_CAUSE_INVALID_NUMBER_FORMAT = 28,
+  SWITCH_CAUSE_FACILITY_REJECTED = 29,
+  SWITCH_CAUSE_RESPONSE_TO_STATUS_ENQUIRY = 30,
+  SWITCH_CAUSE_NORMAL_UNSPECIFIED = 31,
+  SWITCH_CAUSE_NORMAL_CIRCUIT_CONGESTION = 34,
+  SWITCH_CAUSE_NETWORK_OUT_OF_ORDER = 38,
+  SWITCH_CAUSE_NORMAL_TEMPORARY_FAILURE = 41,
+  SWITCH_CAUSE_SWITCH_CONGESTION = 42,
+  SWITCH_CAUSE_ACCESS_INFO_DISCARDED = 43,
+  SWITCH_CAUSE_REQUESTED_CHAN_UNAVAIL = 44,
+  SWITCH_CAUSE_PRE_EMPTED = 45,
+  SWITCH_CAUSE_FACILITY_NOT_SUBSCRIBED = 50,
+  SWITCH_CAUSE_OUTGOING_CALL_BARRED = 52,
+  SWITCH_CAUSE_INCOMING_CALL_BARRED = 54,
+  SWITCH_CAUSE_BEARERCAPABILITY_NOTAUTH = 57,
+  SWITCH_CAUSE_BEARERCAPABILITY_NOTAVAIL = 58,
+  SWITCH_CAUSE_SERVICE_UNAVAILABLE = 63,
+  SWITCH_CAUSE_BEARERCAPABILITY_NOTIMPL = 65,
+  SWITCH_CAUSE_CHAN_NOT_IMPLEMENTED = 66,
+  SWITCH_CAUSE_FACILITY_NOT_IMPLEMENTED = 69,
+  SWITCH_CAUSE_SERVICE_NOT_IMPLEMENTED = 79,
+  SWITCH_CAUSE_INVALID_CALL_REFERENCE = 81,
+  SWITCH_CAUSE_INCOMPATIBLE_DESTINATION = 88,
+  SWITCH_CAUSE_INVALID_MSG_UNSPECIFIED = 95,
+  SWITCH_CAUSE_MANDATORY_IE_MISSING = 96,
+  SWITCH_CAUSE_MESSAGE_TYPE_NONEXIST = 97,
+  SWITCH_CAUSE_WRONG_MESSAGE = 98,
+  SWITCH_CAUSE_IE_NONEXIST = 99,
+  SWITCH_CAUSE_INVALID_IE_CONTENTS = 100,
+  SWITCH_CAUSE_WRONG_CALL_STATE = 101,
+  SWITCH_CAUSE_RECOVERY_ON_TIMER_EXPIRE = 102,
+  SWITCH_CAUSE_MANDATORY_IE_LENGTH_ERROR = 103,
+  SWITCH_CAUSE_PROTOCOL_ERROR = 111,
+  SWITCH_CAUSE_INTERWORKING = 127,
+  SWITCH_CAUSE_SUCCESS = 142,
+  SWITCH_CAUSE_ORIGINATOR_CANCEL = 487,
+  SWITCH_CAUSE_CRASH = 500,
+  SWITCH_CAUSE_SYSTEM_SHUTDOWN = 501,
+  SWITCH_CAUSE_LOSE_RACE = 502,
+  SWITCH_CAUSE_MANAGER_REQUEST = 503,
+  SWITCH_CAUSE_BLIND_TRANSFER = 600,
+  SWITCH_CAUSE_ATTENDED_TRANSFER = 601,
+  SWITCH_CAUSE_ALLOTTED_TIMEOUT = 602,
+  SWITCH_CAUSE_USER_CHALLENGE = 603,
+  SWITCH_CAUSE_MEDIA_TIMEOUT = 604,
+  SWITCH_CAUSE_PICKED_OFF = 605,
+  SWITCH_CAUSE_USER_NOT_REGISTERED = 606
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_message_get")]
-  public static extern IntPtr switch_io_event_hooks_receive_message_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_event_set")]
-  public static extern void switch_io_event_hooks_receive_event_set(HandleRef jarg1, HandleRef jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_receive_event_get")]
-  public static extern IntPtr switch_io_event_hooks_receive_event_get(HandleRef jarg1);
+public enum switch_session_ctl_t {
+  SCSC_PAUSE_INBOUND,
+  SCSC_HUPALL,
+  SCSC_SHUTDOWN,
+  SCSC_CHECK_RUNNING,
+  SCSC_LOGLEVEL,
+  SCSC_SPS,
+  SCSC_LAST_SPS,
+  SCSC_RECLAIM,
+  SCSC_MAX_SESSIONS,
+  SCSC_SYNC_CLOCK,
+  SCSC_MAX_DTMF_DURATION,
+  SCSC_DEFAULT_DTMF_DURATION,
+  SCSC_SHUTDOWN_ELEGANT,
+  SCSC_CANCEL_SHUTDOWN
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_read_frame_set")]
-  public static extern void switch_io_event_hooks_read_frame_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_read_frame_get")]
-  public static extern IntPtr switch_io_event_hooks_read_frame_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_read_frame_set")]
-  public static extern void switch_io_event_hooks_video_read_frame_set(HandleRef jarg1, HandleRef jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_read_frame_get")]
-  public static extern IntPtr switch_io_event_hooks_video_read_frame_get(HandleRef jarg1);
+public class switch_input_args_t : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_write_frame_set")]
-  public static extern void switch_io_event_hooks_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+  internal switch_input_args_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_write_frame_get")]
-  public static extern IntPtr switch_io_event_hooks_write_frame_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_input_args_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_write_frame_set")]
-  public static extern void switch_io_event_hooks_video_write_frame_set(HandleRef jarg1, HandleRef jarg2);
+  ~switch_input_args_t() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_video_write_frame_get")]
-  public static extern IntPtr switch_io_event_hooks_video_write_frame_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_input_args_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_kill_channel_set")]
-  public static extern void switch_io_event_hooks_kill_channel_set(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t input_callback {
+    set {
+      freeswitchPINVOKE.switch_input_args_t_input_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_input_callback_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_kill_channel_get")]
-  public static extern IntPtr switch_io_event_hooks_kill_channel_get(HandleRef jarg1);
+  public SWIGTYPE_p_void buf {
+    set {
+      freeswitchPINVOKE.switch_input_args_t_buf_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_buf_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_send_dtmf_set")]
-  public static extern void switch_io_event_hooks_send_dtmf_set(HandleRef jarg1, HandleRef jarg2);
+  public uint buflen {
+    set {
+      freeswitchPINVOKE.switch_input_args_t_buflen_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_input_args_t_buflen_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_send_dtmf_get")]
-  public static extern IntPtr switch_io_event_hooks_send_dtmf_get(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t read_frame_callback {
+    set {
+      freeswitchPINVOKE.switch_input_args_t_read_frame_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_read_frame_callback_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_recv_dtmf_set")]
-  public static extern void switch_io_event_hooks_recv_dtmf_set(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_void user_data {
+    set {
+      freeswitchPINVOKE.switch_input_args_t_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_user_data_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_recv_dtmf_get")]
-  public static extern IntPtr switch_io_event_hooks_recv_dtmf_get(HandleRef jarg1);
+  public switch_input_args_t() : this(freeswitchPINVOKE.new_switch_input_args_t(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_state_change_set")]
-  public static extern void switch_io_event_hooks_state_change_set(HandleRef jarg1, HandleRef jarg2);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_state_change_get")]
-  public static extern IntPtr switch_io_event_hooks_state_change_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_resurrect_session_set")]
-  public static extern void switch_io_event_hooks_resurrect_session_set(HandleRef jarg1, HandleRef jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_io_event_hooks_resurrect_session_get")]
-  public static extern IntPtr switch_io_event_hooks_resurrect_session_get(HandleRef jarg1);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_io_event_hooks")]
-  public static extern IntPtr new_switch_io_event_hooks();
+public class switch_loadable_module_function_table_t : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_io_event_hooks")]
-  public static extern void delete_switch_io_event_hooks(HandleRef jarg1);
+  internal switch_loadable_module_function_table_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_outgoing_channel")]
-  public static extern int switch_core_event_hook_add_outgoing_channel(HandleRef jarg1, HandleRef jarg2);
+  internal static HandleRef getCPtr(switch_loadable_module_function_table_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_receive_message")]
-  public static extern int switch_core_event_hook_add_receive_message(HandleRef jarg1, HandleRef jarg2);
+  ~switch_loadable_module_function_table_t() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_receive_event")]
-  public static extern int switch_core_event_hook_add_receive_event(HandleRef jarg1, HandleRef jarg2);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_loadable_module_function_table_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_state_change")]
-  public static extern int switch_core_event_hook_add_state_change(HandleRef jarg1, HandleRef jarg2);
+  public int switch_api_version {
+    set {
+      freeswitchPINVOKE.switch_loadable_module_function_table_t_switch_api_version_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_loadable_module_function_table_t_switch_api_version_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_read_frame")]
-  public static extern int switch_core_event_hook_add_read_frame(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t load {
+    set {
+      freeswitchPINVOKE.switch_loadable_module_function_table_t_load_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_load_get(swigCPtr);
+      SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_write_frame")]
-  public static extern int switch_core_event_hook_add_write_frame(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_f_void__switch_status_t shutdown {
+    set {
+      freeswitchPINVOKE.switch_loadable_module_function_table_t_shutdown_set(swigCPtr, SWIGTYPE_p_f_void__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_shutdown_get(swigCPtr);
+      SWIGTYPE_p_f_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_void__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_video_read_frame")]
-  public static extern int switch_core_event_hook_add_video_read_frame(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_f_void__switch_status_t runtime {
+    set {
+      freeswitchPINVOKE.switch_loadable_module_function_table_t_runtime_set(swigCPtr, SWIGTYPE_p_f_void__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_runtime_get(swigCPtr);
+      SWIGTYPE_p_f_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_void__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_video_write_frame")]
-  public static extern int switch_core_event_hook_add_video_write_frame(HandleRef jarg1, HandleRef jarg2);
+  public switch_loadable_module_function_table_t() : this(freeswitchPINVOKE.new_switch_loadable_module_function_table_t(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_kill_channel")]
-  public static extern int switch_core_event_hook_add_kill_channel(HandleRef jarg1, HandleRef jarg2);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_send_dtmf")]
-  public static extern int switch_core_event_hook_add_send_dtmf(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_recv_dtmf")]
-  public static extern int switch_core_event_hook_add_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_add_resurrect_session")]
-  public static extern int switch_core_event_hook_add_resurrect_session(HandleRef jarg1, HandleRef jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_outgoing_channel")]
-  public static extern int switch_core_event_hook_remove_outgoing_channel(HandleRef jarg1, HandleRef jarg2);
+public class switch_core_time_duration : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_receive_message")]
-  public static extern int switch_core_event_hook_remove_receive_message(HandleRef jarg1, HandleRef jarg2);
+  internal switch_core_time_duration(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_receive_event")]
-  public static extern int switch_core_event_hook_remove_receive_event(HandleRef jarg1, HandleRef jarg2);
+  internal static HandleRef getCPtr(switch_core_time_duration obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_state_change")]
-  public static extern int switch_core_event_hook_remove_state_change(HandleRef jarg1, HandleRef jarg2);
+  ~switch_core_time_duration() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_read_frame")]
-  public static extern int switch_core_event_hook_remove_read_frame(HandleRef jarg1, HandleRef jarg2);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_core_time_duration(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_write_frame")]
-  public static extern int switch_core_event_hook_remove_write_frame(HandleRef jarg1, HandleRef jarg2);
+  public uint mms {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_mms_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_mms_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_video_read_frame")]
-  public static extern int switch_core_event_hook_remove_video_read_frame(HandleRef jarg1, HandleRef jarg2);
+  public uint ms {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_ms_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_ms_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_video_write_frame")]
-  public static extern int switch_core_event_hook_remove_video_write_frame(HandleRef jarg1, HandleRef jarg2);
+  public uint sec {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_sec_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_sec_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_kill_channel")]
-  public static extern int switch_core_event_hook_remove_kill_channel(HandleRef jarg1, HandleRef jarg2);
+  public uint min {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_min_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_min_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_send_dtmf")]
-  public static extern int switch_core_event_hook_remove_send_dtmf(HandleRef jarg1, HandleRef jarg2);
+  public uint hr {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_hr_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_hr_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_recv_dtmf")]
-  public static extern int switch_core_event_hook_remove_recv_dtmf(HandleRef jarg1, HandleRef jarg2);
+  public uint day {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_day_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_day_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_core_event_hook_remove_resurrect_session")]
-  public static extern int switch_core_event_hook_remove_resurrect_session(HandleRef jarg1, HandleRef jarg2);
+  public uint yr {
+    set {
+      freeswitchPINVOKE.switch_core_time_duration_yr_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_time_duration_yr_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_created_set")]
-  public static extern void switch_scheduler_task_created_set(HandleRef jarg1, long jarg2);
+  public switch_core_time_duration() : this(freeswitchPINVOKE.new_switch_core_time_duration(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_created_get")]
-  public static extern long switch_scheduler_task_created_get(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_runtime_set")]
-  public static extern void switch_scheduler_task_runtime_set(HandleRef jarg1, long jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_runtime_get")]
-  public static extern long switch_scheduler_task_runtime_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_id_set")]
-  public static extern void switch_scheduler_task_cmd_id_set(HandleRef jarg1, uint jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_id_get")]
-  public static extern uint switch_scheduler_task_cmd_id_get(HandleRef jarg1);
+public class switch_app_log : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_group_set")]
-  public static extern void switch_scheduler_task_group_set(HandleRef jarg1, string jarg2);
+  internal switch_app_log(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_group_get")]
-  public static extern string switch_scheduler_task_group_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_app_log obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_arg_set")]
-  public static extern void switch_scheduler_task_cmd_arg_set(HandleRef jarg1, HandleRef jarg2);
+  ~switch_app_log() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_cmd_arg_get")]
-  public static extern IntPtr switch_scheduler_task_cmd_arg_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_app_log(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_task_id_set")]
-  public static extern void switch_scheduler_task_task_id_set(HandleRef jarg1, uint jarg2);
+  public string app {
+    set {
+      freeswitchPINVOKE.switch_app_log_app_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_app_log_app_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_task_id_get")]
-  public static extern uint switch_scheduler_task_task_id_get(HandleRef jarg1);
+  public string arg {
+    set {
+      freeswitchPINVOKE.switch_app_log_arg_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_app_log_arg_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_scheduler_task")]
-  public static extern IntPtr new_switch_scheduler_task();
+  public switch_app_log next {
+    set {
+      freeswitchPINVOKE.switch_app_log_next_set(swigCPtr, switch_app_log.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_app_log_next_get(swigCPtr);
+      switch_app_log ret = (cPtr == IntPtr.Zero) ? null : new switch_app_log(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_scheduler_task")]
-  public static extern void delete_switch_scheduler_task(HandleRef jarg1);
+  public switch_app_log() : this(freeswitchPINVOKE.new_switch_app_log(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_add_task")]
-  public static extern uint switch_scheduler_add_task(HandleRef jarg1, HandleRef jarg2, string jarg3, string jarg4, uint jarg5, HandleRef jarg6, uint jarg7);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_del_task_id")]
-  public static extern uint switch_scheduler_del_task_id(uint jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_del_task_group")]
-  public static extern uint switch_scheduler_del_task_group(string jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_thread_start")]
-  public static extern void switch_scheduler_task_thread_start();
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_scheduler_task_thread_stop")]
-  public static extern void switch_scheduler_task_thread_stop();
+public class switch_core_session_message : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_file_set")]
-  public static extern void switch_config_file_set(HandleRef jarg1, HandleRef jarg2);
+  internal switch_core_session_message(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_file_get")]
-  public static extern IntPtr switch_config_file_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_core_session_message obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_path_set")]
-  public static extern void switch_config_path_set(HandleRef jarg1, string jarg2);
+  ~switch_core_session_message() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_path_get")]
-  public static extern string switch_config_path_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_core_session_message(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_category_set")]
-  public static extern void switch_config_category_set(HandleRef jarg1, string jarg2);
+  public string from {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_from_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_core_session_message_from_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_category_get")]
-  public static extern string switch_config_category_get(HandleRef jarg1);
+  public switch_core_session_message_types_t message_id {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_message_id_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_core_session_message_types_t ret = (switch_core_session_message_types_t)freeswitchPINVOKE.switch_core_session_message_message_id_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_section_set")]
-  public static extern void switch_config_section_set(HandleRef jarg1, string jarg2);
+  public int numeric_arg {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_numeric_arg_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_core_session_message_numeric_arg_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_section_get")]
-  public static extern string switch_config_section_get(HandleRef jarg1);
+  public string string_arg {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_string_arg_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_core_session_message_string_arg_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_buf_set")]
-  public static extern void switch_config_buf_set(HandleRef jarg1, string jarg2);
+  public SWIGTYPE_p_switch_size_t string_arg_size {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_string_arg_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_string_arg_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_buf_get")]
-  public static extern string switch_config_buf_get(HandleRef jarg1);
+  public SWIGTYPE_p_void pointer_arg {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_pointer_arg_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_session_message_pointer_arg_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lineno_set")]
-  public static extern void switch_config_lineno_set(HandleRef jarg1, int jarg2);
+  public SWIGTYPE_p_switch_size_t pointer_arg_size {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_pointer_arg_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_pointer_arg_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lineno_get")]
-  public static extern int switch_config_lineno_get(HandleRef jarg1);
+  public int numeric_reply {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_numeric_reply_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_core_session_message_numeric_reply_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_catno_set")]
-  public static extern void switch_config_catno_set(HandleRef jarg1, int jarg2);
+  public string string_reply {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_string_reply_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_core_session_message_string_reply_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_catno_get")]
-  public static extern int switch_config_catno_get(HandleRef jarg1);
+  public SWIGTYPE_p_switch_size_t string_reply_size {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_string_reply_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_string_reply_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_sectno_set")]
-  public static extern void switch_config_sectno_set(HandleRef jarg1, int jarg2);
+  public SWIGTYPE_p_void pointer_reply {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_pointer_reply_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_session_message_pointer_reply_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_sectno_get")]
-  public static extern int switch_config_sectno_get(HandleRef jarg1);
+  public SWIGTYPE_p_switch_size_t pointer_reply_size {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_pointer_reply_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_pointer_reply_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lockto_set")]
-  public static extern void switch_config_lockto_set(HandleRef jarg1, int jarg2);
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_core_session_message_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_core_session_message_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_lockto_get")]
-  public static extern int switch_config_lockto_get(HandleRef jarg1);
+  public switch_core_session_message() : this(freeswitchPINVOKE.new_switch_core_session_message(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_switch_config")]
-  public static extern IntPtr new_switch_config();
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_switch_config")]
-  public static extern void delete_switch_config(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_open_file")]
-  public static extern int switch_config_open_file(HandleRef jarg1, string jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_close_file")]
-  public static extern void switch_config_close_file(HandleRef jarg1);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_switch_config_next_pair")]
-  public static extern int switch_config_next_pair(HandleRef jarg1, ref string jarg2, ref string jarg3);
+public class switch_core_thread_session : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_consoleLog")]
-  public static extern void consoleLog(string jarg1, string jarg2);
+  internal switch_core_thread_session(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_consoleCleanLog")]
-  public static extern void consoleCleanLog(string jarg1);
+  internal static HandleRef getCPtr(switch_core_thread_session obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_IvrMenu")]
-  public static extern IntPtr new_IvrMenu(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5, string jarg6, string jarg7, string jarg8, int jarg9, int jarg10, int jarg11, int jarg12, int jarg13);
+  ~switch_core_thread_session() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_IvrMenu")]
-  public static extern void delete_IvrMenu(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_core_thread_session(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_IvrMenu_bindAction")]
-  public static extern void IvrMenu_bindAction(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  public int running {
+    set {
+      freeswitchPINVOKE.switch_core_thread_session_running_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_core_thread_session_running_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_IvrMenu_Execute")]
-  public static extern void IvrMenu_Execute(HandleRef jarg1, HandleRef jarg2, string jarg3);
+  public SWIGTYPE_p_switch_mutex_t mutex {
+    set {
+      freeswitchPINVOKE.switch_core_thread_session_mutex_set(swigCPtr, SWIGTYPE_p_switch_mutex_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_mutex_get(swigCPtr);
+      SWIGTYPE_p_switch_mutex_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_mutex_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_Api")]
-  public static extern IntPtr new_Api();
+  public SWIGTYPE_p_p_void objs {
+    set {
+      freeswitchPINVOKE.switch_core_thread_session_objs_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_objs_get(swigCPtr);
+      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_Api")]
-  public static extern void delete_Api(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t input_callback {
+    set {
+      freeswitchPINVOKE.switch_core_thread_session_input_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_input_callback_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Api_Execute")]
-  public static extern string Api_Execute(HandleRef jarg1, string jarg2, string jarg3);
+  public SWIGTYPE_p_apr_pool_t pool {
+    set {
+      freeswitchPINVOKE.switch_core_thread_session_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Api_ExecuteString")]
-  public static extern string Api_ExecuteString(HandleRef jarg1, string jarg2);
+  public switch_core_thread_session() : this(freeswitchPINVOKE.new_switch_core_thread_session(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_function_set")]
-  public static extern void input_callback_state_t_function_set(HandleRef jarg1, HandleRef jarg2);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_function_get")]
-  public static extern IntPtr input_callback_state_t_function_get(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_threadState_set")]
-  public static extern void input_callback_state_t_threadState_set(HandleRef jarg1, HandleRef jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_threadState_get")]
-  public static extern IntPtr input_callback_state_t_threadState_get(HandleRef jarg1);
+public enum switch_uri_flags {
+  SWITCH_URI_NUMERIC_HOST = 1,
+  SWITCH_URI_NUMERIC_PORT = 2,
+  SWITCH_URI_NO_SCOPE = 4
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_extra_set")]
-  public static extern void input_callback_state_t_extra_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_extra_get")]
-  public static extern IntPtr input_callback_state_t_extra_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_funcargs_set")]
-  public static extern void input_callback_state_t_funcargs_set(HandleRef jarg1, string jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_input_callback_state_t_funcargs_get")]
-  public static extern string input_callback_state_t_funcargs_get(HandleRef jarg1);
+public class switch_caller_profile : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_input_callback_state_t")]
-  public static extern IntPtr new_input_callback_state_t();
+  internal switch_caller_profile(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_input_callback_state_t")]
-  public static extern void delete_input_callback_state_t(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_caller_profile obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_digit_set")]
-  public static extern void DTMF_digit_set(HandleRef jarg1, char jarg2);
+  ~switch_caller_profile() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_digit_get")]
-  public static extern char DTMF_digit_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_caller_profile(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_duration_set")]
-  public static extern void DTMF_duration_set(HandleRef jarg1, uint jarg2);
+  public string username {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_username_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_username_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_DTMF_duration_get")]
-  public static extern uint DTMF_duration_get(HandleRef jarg1);
+  public string dialplan {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_dialplan_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_dialplan_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_DTMF")]
-  public static extern IntPtr new_DTMF(char jarg1, uint jarg2);
+  public string caller_id_name {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_caller_id_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_caller_id_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_DTMF")]
-  public static extern void delete_DTMF(HandleRef jarg1);
+  public string caller_id_number {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_caller_id_number_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_caller_id_number_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_Stream__SWIG_0")]
-  public static extern IntPtr new_Stream__SWIG_0();
+  public byte caller_ton {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_caller_ton_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_caller_ton_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_Stream__SWIG_1")]
-  public static extern IntPtr new_Stream__SWIG_1(HandleRef jarg1);
+  public byte caller_numplan {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_caller_numplan_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_caller_numplan_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_Stream")]
-  public static extern void delete_Stream(HandleRef jarg1);
+  public string network_addr {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_network_addr_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_network_addr_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Stream_Write")]
-  public static extern void Stream_Write(HandleRef jarg1, string jarg2);
+  public string ani {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_ani_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_ani_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Stream_get_data")]
-  public static extern string Stream_get_data(HandleRef jarg1);
+  public byte ani_ton {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_ani_ton_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_ani_ton_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_InternalEvent_set")]
-  public static extern void Event_InternalEvent_set(HandleRef jarg1, HandleRef jarg2);
+  public byte ani_numplan {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_ani_numplan_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_ani_numplan_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_InternalEvent_get")]
-  public static extern IntPtr Event_InternalEvent_get(HandleRef jarg1);
+  public string aniii {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_aniii_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_aniii_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_serialized_string_set")]
-  public static extern void Event_serialized_string_set(HandleRef jarg1, string jarg2);
+  public string rdnis {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_rdnis_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_rdnis_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_serialized_string_get")]
-  public static extern string Event_serialized_string_get(HandleRef jarg1);
+  public byte rdnis_ton {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_rdnis_ton_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_rdnis_ton_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_mine_set")]
-  public static extern void Event_mine_set(HandleRef jarg1, int jarg2);
+  public byte rdnis_numplan {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_rdnis_numplan_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_rdnis_numplan_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_mine_get")]
-  public static extern int Event_mine_get(HandleRef jarg1);
+  public string destination_number {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_destination_number_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_destination_number_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_Event__SWIG_0")]
-  public static extern IntPtr new_Event__SWIG_0(string jarg1, string jarg2);
+  public byte destination_number_ton {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_destination_number_ton_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_destination_number_ton_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_Event__SWIG_1")]
-  public static extern IntPtr new_Event__SWIG_1(HandleRef jarg1, int jarg2);
+  public byte destination_number_numplan {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_destination_number_numplan_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_caller_profile_destination_number_numplan_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_Event")]
-  public static extern void delete_Event(HandleRef jarg1);
+  public string source {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_source_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_source_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_Serialize")]
-  public static extern string Event_Serialize(HandleRef jarg1, string jarg2);
+  public string chan_name {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_chan_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_chan_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_SetPriority")]
-  public static extern bool Event_SetPriority(HandleRef jarg1, int jarg2);
+  public string uuid {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_uuid_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_uuid_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetHeader")]
-  public static extern string Event_GetHeader(HandleRef jarg1, string jarg2);
+  public string context {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_context_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_context_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetBody")]
-  public static extern string Event_GetBody(HandleRef jarg1);
+  public string profile_index {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_profile_index_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_profile_profile_index_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_GetEventType")]
-  public static extern string Event_GetEventType(HandleRef jarg1);
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_caller_profile_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_AddBody")]
-  public static extern bool Event_AddBody(HandleRef jarg1, string jarg2);
+  public switch_caller_profile originator_caller_profile {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_originator_caller_profile_set(swigCPtr, switch_caller_profile.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_originator_caller_profile_get(swigCPtr);
+      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_AddHeader")]
-  public static extern bool Event_AddHeader(HandleRef jarg1, string jarg2, string jarg3);
+  public switch_caller_profile originatee_caller_profile {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_originatee_caller_profile_set(swigCPtr, switch_caller_profile.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_originatee_caller_profile_get(swigCPtr);
+      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_DeleteHeader")]
-  public static extern bool Event_DeleteHeader(HandleRef jarg1, string jarg2);
+  public switch_channel_timetable times {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_times_set(swigCPtr, switch_channel_timetable.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_times_get(swigCPtr);
+      switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_Event_Fire")]
-  public static extern bool Event_Fire(HandleRef jarg1);
+  public switch_caller_extension caller_extension {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_caller_extension_set(swigCPtr, switch_caller_extension.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_caller_extension_get(swigCPtr);
+      switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_events_set")]
-  public static extern void EventConsumer_events_set(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_apr_pool_t pool {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_events_get")]
-  public static extern IntPtr EventConsumer_events_get(HandleRef jarg1);
+  public switch_caller_profile next {
+    set {
+      freeswitchPINVOKE.switch_caller_profile_next_set(swigCPtr, switch_caller_profile.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_next_get(swigCPtr);
+      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_event_id_set")]
-  public static extern void EventConsumer_e_event_id_set(HandleRef jarg1, int jarg2);
+  public switch_caller_profile() : this(freeswitchPINVOKE.new_switch_caller_profile(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_event_id_get")]
-  public static extern int EventConsumer_e_event_id_get(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_node_set")]
-  public static extern void EventConsumer_node_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_node_get")]
-  public static extern IntPtr EventConsumer_node_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_callback_set")]
-  public static extern void EventConsumer_e_callback_set(HandleRef jarg1, string jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_callback_get")]
-  public static extern string EventConsumer_e_callback_get(HandleRef jarg1);
+public class switch_caller_application : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_subclass_name_set")]
-  public static extern void EventConsumer_e_subclass_name_set(HandleRef jarg1, string jarg2);
+  internal switch_caller_application(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_subclass_name_get")]
-  public static extern string EventConsumer_e_subclass_name_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_caller_application obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_cb_arg_set")]
-  public static extern void EventConsumer_e_cb_arg_set(HandleRef jarg1, string jarg2);
+  ~switch_caller_application() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_e_cb_arg_get")]
-  public static extern string EventConsumer_e_cb_arg_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_caller_application(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_EventConsumer")]
-  public static extern IntPtr new_EventConsumer(string jarg1, string jarg2);
+  public string application_name {
+    set {
+      freeswitchPINVOKE.switch_caller_application_application_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_application_application_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_EventConsumer")]
-  public static extern void delete_EventConsumer(HandleRef jarg1);
+  public string application_data {
+    set {
+      freeswitchPINVOKE.switch_caller_application_application_data_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_application_application_data_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_EventConsumer_pop")]
-  public static extern IntPtr EventConsumer_pop(HandleRef jarg1, int jarg2);
+  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void application_function {
+    set {
+      freeswitchPINVOKE.switch_caller_application_application_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_application_application_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_CoreSession")]
-  public static extern void delete_CoreSession(HandleRef jarg1);
+  public switch_caller_application next {
+    set {
+      freeswitchPINVOKE.switch_caller_application_next_set(swigCPtr, switch_caller_application.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_application_next_get(swigCPtr);
+      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_InternalSession_set")]
-  public static extern void CoreSession_InternalSession_set(HandleRef jarg1, HandleRef jarg2);
+  public switch_caller_application() : this(freeswitchPINVOKE.new_switch_caller_application(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_InternalSession_get")]
-  public static extern IntPtr CoreSession_InternalSession_get(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_channel_set")]
-  public static extern void CoreSession_channel_set(HandleRef jarg1, HandleRef jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_channel_get")]
-  public static extern IntPtr CoreSession_channel_get(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flags_set")]
-  public static extern void CoreSession_flags_set(HandleRef jarg1, uint jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flags_get")]
-  public static extern uint CoreSession_flags_get(HandleRef jarg1);
+public class switch_caller_extension : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_allocated_set")]
-  public static extern void CoreSession_allocated_set(HandleRef jarg1, int jarg2);
+  internal switch_caller_extension(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_allocated_get")]
-  public static extern int CoreSession_allocated_get(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_caller_extension obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_cb_state_set")]
-  public static extern void CoreSession_cb_state_set(HandleRef jarg1, HandleRef jarg2);
+  ~switch_caller_extension() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_cb_state_get")]
-  public static extern IntPtr CoreSession_cb_state_get(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_caller_extension(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public string extension_name {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_extension_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_extension_extension_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_HookState_set")]
-  public static extern void CoreSession_HookState_set(HandleRef jarg1, int jarg2);
+  public string extension_number {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_extension_number_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_caller_extension_extension_number_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_HookState_get")]
-  public static extern int CoreSession_HookState_get(HandleRef jarg1);
+  public switch_caller_application current_application {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_current_application_set(swigCPtr, switch_caller_application.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_current_application_get(swigCPtr);
+      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_uuid_set")]
-  public static extern void CoreSession_uuid_set(HandleRef jarg1, string jarg2);
+  public switch_caller_application last_application {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_last_application_set(swigCPtr, switch_caller_application.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_last_application_get(swigCPtr);
+      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_uuid_get")]
-  public static extern string CoreSession_uuid_get(HandleRef jarg1);
+  public switch_caller_application applications {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_applications_set(swigCPtr, switch_caller_application.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_applications_get(swigCPtr);
+      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_tts_name_set")]
-  public static extern void CoreSession_tts_name_set(HandleRef jarg1, string jarg2);
+  public switch_caller_profile children {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_children_set(swigCPtr, switch_caller_profile.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_children_get(swigCPtr);
+      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_tts_name_get")]
-  public static extern string CoreSession_tts_name_get(HandleRef jarg1);
+  public switch_caller_extension next {
+    set {
+      freeswitchPINVOKE.switch_caller_extension_next_set(swigCPtr, switch_caller_extension.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_next_get(swigCPtr);
+      switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_voice_name_set")]
-  public static extern void CoreSession_voice_name_set(HandleRef jarg1, string jarg2);
+  public switch_caller_extension() : this(freeswitchPINVOKE.new_switch_caller_extension(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_voice_name_get")]
-  public static extern string CoreSession_voice_name_get(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Answer")]
-  public static extern int CoreSession_Answer(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_preAnswer")]
-  public static extern int CoreSession_preAnswer(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Hangup")]
-  public static extern void CoreSession_Hangup(HandleRef jarg1, string jarg2);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetVariable")]
-  public static extern void CoreSession_SetVariable(HandleRef jarg1, string jarg2, string jarg3);
+public class switch_frame : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetPrivate")]
-  public static extern void CoreSession_SetPrivate(HandleRef jarg1, string jarg2, HandleRef jarg3);
+  internal switch_frame(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetPrivate")]
-  public static extern IntPtr CoreSession_GetPrivate(HandleRef jarg1, string jarg2);
+  internal static HandleRef getCPtr(switch_frame obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetVariable")]
-  public static extern string CoreSession_GetVariable(HandleRef jarg1, string jarg2);
+  ~switch_frame() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Say")]
-  public static extern void CoreSession_Say(HandleRef jarg1, string jarg2, string jarg3, string jarg4, string jarg5);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_frame(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SayPhrase")]
-  public static extern void CoreSession_SayPhrase(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  public switch_codec codec {
+    set {
+      freeswitchPINVOKE.switch_frame_codec_set(swigCPtr, switch_codec.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_frame_codec_get(swigCPtr);
+      switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_RecordFile")]
-  public static extern int CoreSession_RecordFile(HandleRef jarg1, string jarg2, int jarg3, int jarg4, int jarg5);
+  public string source {
+    set {
+      freeswitchPINVOKE.switch_frame_source_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_frame_source_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetCallerData")]
-  public static extern void CoreSession_SetCallerData(HandleRef jarg1, string jarg2, string jarg3);
+  public SWIGTYPE_p_void packet {
+    set {
+      freeswitchPINVOKE.switch_frame_packet_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_frame_packet_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Originate")]
-  public static extern int CoreSession_Originate(HandleRef jarg1, HandleRef jarg2, string jarg3, int jarg4);
+  public uint packetlen {
+    set {
+      freeswitchPINVOKE.switch_frame_packetlen_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_packetlen_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_destroy")]
-  public static extern void CoreSession_destroy(HandleRef jarg1);
+  public SWIGTYPE_p_void data {
+    set {
+      freeswitchPINVOKE.switch_frame_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_frame_data_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Speak")]
-  public static extern int CoreSession_Speak(HandleRef jarg1, string jarg2);
+  public uint datalen {
+    set {
+      freeswitchPINVOKE.switch_frame_datalen_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_datalen_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetTtsParameters")]
-  public static extern void CoreSession_SetTtsParameters(HandleRef jarg1, string jarg2, string jarg3);
+  public uint buflen {
+    set {
+      freeswitchPINVOKE.switch_frame_buflen_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_buflen_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_CollectDigits")]
-  public static extern int CoreSession_CollectDigits(HandleRef jarg1, int jarg2);
+  public uint samples {
+    set {
+      freeswitchPINVOKE.switch_frame_samples_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_samples_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetDigits__SWIG_0")]
-  public static extern string CoreSession_GetDigits__SWIG_0(HandleRef jarg1, int jarg2, string jarg3, int jarg4);
+  public uint rate {
+    set {
+      freeswitchPINVOKE.switch_frame_rate_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_rate_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetDigits__SWIG_1")]
-  public static extern string CoreSession_GetDigits__SWIG_1(HandleRef jarg1, int jarg2, string jarg3, int jarg4, int jarg5);
+  public byte payload {
+    set {
+      freeswitchPINVOKE.switch_frame_payload_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_frame_payload_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Transfer")]
-  public static extern int CoreSession_Transfer(HandleRef jarg1, string jarg2, string jarg3, string jarg4);
+  public SWIGTYPE_p_switch_size_t timestamp {
+    set {
+      freeswitchPINVOKE.switch_frame_timestamp_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_frame_timestamp_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_read")]
-  public static extern string CoreSession_read(HandleRef jarg1, int jarg2, int jarg3, string jarg4, int jarg5, string jarg6);
+  public ushort seq {
+    set {
+      freeswitchPINVOKE.switch_frame_seq_set(swigCPtr, value);
+    } 
+    get {
+      ushort ret = freeswitchPINVOKE.switch_frame_seq_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_PlayAndGetDigits")]
-  public static extern string CoreSession_PlayAndGetDigits(HandleRef jarg1, int jarg2, int jarg3, int jarg4, int jarg5, string jarg6, string jarg7, string jarg8, string jarg9);
+  public uint ssrc {
+    set {
+      freeswitchPINVOKE.switch_frame_ssrc_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_ssrc_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_StreamFile")]
-  public static extern int CoreSession_StreamFile(HandleRef jarg1, string jarg2, int jarg3);
+  public switch_bool_t m {
+    set {
+      freeswitchPINVOKE.switch_frame_m_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_frame_m_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_sleep")]
-  public static extern int CoreSession_sleep(HandleRef jarg1, int jarg2);
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_frame_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_frame_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flushEvents")]
-  public static extern int CoreSession_flushEvents(HandleRef jarg1);
+  public switch_frame() : this(freeswitchPINVOKE.new_switch_frame(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_flushDigits")]
-  public static extern int CoreSession_flushDigits(HandleRef jarg1);
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_SetAutoHangup")]
-  public static extern int CoreSession_SetAutoHangup(HandleRef jarg1, bool jarg2);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Ready")]
-  public static extern bool CoreSession_Ready(HandleRef jarg1);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_answered")]
-  public static extern bool CoreSession_answered(HandleRef jarg1);
+public enum switch_state_handler_name_t {
+  SWITCH_SHN_ON_INIT,
+  SWITCH_SHN_ON_ROUTING,
+  SWITCH_SHN_ON_EXECUTE,
+  SWITCH_SHN_ON_HANGUP,
+  SWITCH_SHN_ON_EXCHANGE_MEDIA,
+  SWITCH_SHN_ON_SOFT_EXECUTE,
+  SWITCH_SHN_ON_CONSUME_MEDIA,
+  SWITCH_SHN_ON_HIBERNATE,
+  SWITCH_SHN_ON_RESET,
+  SWITCH_SHN_ON_PARK
+}
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_mediaReady")]
-  public static extern bool CoreSession_mediaReady(HandleRef jarg1);
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_waitForAnswer")]
-  public static extern void CoreSession_waitForAnswer(HandleRef jarg1, HandleRef jarg2);
+namespace FreeSWITCH.Native {
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_Execute")]
-  public static extern void CoreSession_Execute(HandleRef jarg1, string jarg2, string jarg3);
+using System;
+using System.Runtime.InteropServices;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_sendEvent")]
-  public static extern void CoreSession_sendEvent(HandleRef jarg1, HandleRef jarg2);
+public class switch_state_handler_table : IDisposable {
+  private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_setEventData")]
-  public static extern void CoreSession_setEventData(HandleRef jarg1, HandleRef jarg2);
+  internal switch_state_handler_table(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_getXMLCDR")]
-  public static extern string CoreSession_getXMLCDR(HandleRef jarg1);
+  internal static HandleRef getCPtr(switch_state_handler_table obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_begin_allow_threads")]
-  public static extern bool CoreSession_begin_allow_threads(HandleRef jarg1);
+  ~switch_state_handler_table() {
+    Dispose();
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_end_allow_threads")]
-  public static extern bool CoreSession_end_allow_threads(HandleRef jarg1);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_state_handler_table(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_GetUuid")]
-  public static extern string CoreSession_GetUuid(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_init {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_init_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_get_cb_args")]
-  public static extern IntPtr CoreSession_get_cb_args(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_routing {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_routing_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_routing_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_CoreSession_check_hangup_hook")]
-  public static extern void CoreSession_check_hangup_hook(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_execute {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_execute_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_execute_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_console_log")]
-  public static extern void console_log(string jarg1, string jarg2);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_hangup {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_hangup_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_hangup_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_console_clean_log")]
-  public static extern void console_clean_log(string jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_exchange_media {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_exchange_media_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_exchange_media_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_bridge")]
-  public static extern void bridge(HandleRef jarg1, HandleRef jarg2);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_soft_execute {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_soft_execute_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_soft_execute_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_hanguphook")]
-  public static extern int hanguphook(HandleRef jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_consume_media {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_consume_media_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_consume_media_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_dtmf_callback")]
-  public static extern int dtmf_callback(HandleRef jarg1, HandleRef jarg2, int jarg3, HandleRef jarg4, uint jarg5);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_hibernate {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_hibernate_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_hibernate_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_0")]
-  public static extern IntPtr new_ManagedSession__SWIG_0();
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_reset {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_reset_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_reset_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_1")]
-  public static extern IntPtr new_ManagedSession__SWIG_1(string jarg1);
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_park {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_on_park_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_park_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_new_ManagedSession__SWIG_2")]
-  public static extern IntPtr new_ManagedSession__SWIG_2(HandleRef jarg1);
+  public SWIGTYPE_p_p_void padding {
+    set {
+      freeswitchPINVOKE.switch_state_handler_table_padding_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_padding_get(swigCPtr);
+      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_delete_ManagedSession")]
-  public static extern void delete_ManagedSession(HandleRef jarg1);
+  public switch_state_handler_table() : this(freeswitchPINVOKE.new_switch_state_handler_table(), true) {
+  }
 
-  [DllImport("mod_managed", EntryPoint="CSharp_ManagedSessionUpcast")]
-  public static extern IntPtr ManagedSessionUpcast(IntPtr objectRef);
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10052,20 +9983,20 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class input_callback_state_t : IDisposable {
+public class switch_stream_handle : IDisposable {
   private HandleRef swigCPtr;
   protected bool swigCMemOwn;
 
-  internal input_callback_state_t(IntPtr cPtr, bool cMemoryOwn) {
+  internal switch_stream_handle(IntPtr cPtr, bool cMemoryOwn) {
     swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(input_callback_state_t obj) {
+  internal static HandleRef getCPtr(switch_stream_handle obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~input_callback_state_t() {
+  ~switch_stream_handle() {
     Dispose();
   }
 
@@ -10073,57 +10004,117 @@
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_input_callback_state_t(swigCPtr);
+        freeswitchPINVOKE.delete_switch_stream_handle(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
     }
   }
 
-  public SWIGTYPE_p_void function {
+  public SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t write_function {
     set {
-      freeswitchPINVOKE.input_callback_state_t_function_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+      freeswitchPINVOKE.switch_stream_handle_write_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t.getCPtr(value));
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_function_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_write_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t(cPtr, false);
       return ret;
     } 
   }
 
-  public SWIGTYPE_p_void threadState {
+  public SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t raw_write_function {
     set {
-      freeswitchPINVOKE.input_callback_state_t_threadState_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+      freeswitchPINVOKE.switch_stream_handle_raw_write_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t.getCPtr(value));
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_threadState_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_raw_write_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_void data {
+    set {
+      freeswitchPINVOKE.switch_stream_handle_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_data_get(swigCPtr);
       SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
       return ret;
     } 
   }
 
-  public SWIGTYPE_p_void extra {
+  public SWIGTYPE_p_void end {
     set {
-      freeswitchPINVOKE.input_callback_state_t_extra_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+      freeswitchPINVOKE.switch_stream_handle_end_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_extra_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_end_get(swigCPtr);
       SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
       return ret;
     } 
   }
 
-  public string funcargs {
+  public SWIGTYPE_p_switch_size_t data_size {
     set {
-      freeswitchPINVOKE.input_callback_state_t_funcargs_set(swigCPtr, value);
+      freeswitchPINVOKE.switch_stream_handle_data_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
     } 
     get {
-      string ret = freeswitchPINVOKE.input_callback_state_t_funcargs_get(swigCPtr);
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_data_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
       return ret;
     } 
   }
 
-  public input_callback_state_t() : this(freeswitchPINVOKE.new_input_callback_state_t(), true) {
+  public SWIGTYPE_p_switch_size_t data_len {
+    set {
+      freeswitchPINVOKE.switch_stream_handle_data_len_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_data_len_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_size_t alloc_len {
+    set {
+      freeswitchPINVOKE.switch_stream_handle_alloc_len_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_alloc_len_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_size_t alloc_chunk {
+    set {
+      freeswitchPINVOKE.switch_stream_handle_alloc_chunk_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_alloc_chunk_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public switch_event param_event {
+    set {
+      freeswitchPINVOKE.switch_stream_handle_param_event_set(swigCPtr, switch_event.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_param_event_get(swigCPtr);
+      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_stream_handle() : this(freeswitchPINVOKE.new_switch_stream_handle(), true) {
   }
 
 }
@@ -10131,7 +10122,32 @@
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+public enum switch_io_routine_name_t {
+  SWITCH_IO_OUTGOING_CHANNEL,
+  SWITCH_IO_READ_FRAME,
+  SWITCH_IO_WRITE_FRAME,
+  SWITCH_IO_KILL_CHANNEL,
+  SWITCH_IO_SEND_DTMF,
+  SWITCH_IO_RECEIVE_MESSAGE,
+  SWITCH_IO_RECEIVE_EVENT,
+  SWITCH_IO_STATE_CHANGE,
+  SWITCH_IO_READ_VIDEO_FRAME,
+  SWITCH_IO_WRITE_VIDEO_FRAME,
+  SWITCH_IO_RESURRECT_SESSION
+}
+
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10142,20 +10158,20 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class IvrMenu : IDisposable {
+public class switch_io_routines : IDisposable {
   private HandleRef swigCPtr;
   protected bool swigCMemOwn;
 
-  internal IvrMenu(IntPtr cPtr, bool cMemoryOwn) {
+  internal switch_io_routines(IntPtr cPtr, bool cMemoryOwn) {
     swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(IvrMenu obj) {
+  internal static HandleRef getCPtr(switch_io_routines obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~IvrMenu() {
+  ~switch_io_routines() {
     Dispose();
   }
 
@@ -10163,99 +10179,154 @@
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_IvrMenu(swigCPtr);
+        freeswitchPINVOKE.delete_switch_io_routines(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
     }
   }
 
-  public IvrMenu(IvrMenu main, string name, string greeting_sound, string short_greeting_sound, string invalid_sound, string exit_sound, string confirm_macro, string confirm_key, int confirm_attempts, int inter_timeout, int digit_len, int timeout, int max_failures) : this(freeswitchPINVOKE.new_IvrMenu(IvrMenu.getCPtr(main), name, greeting_sound, short_greeting_sound, invalid_sound, exit_sound, confirm_macro, confirm_key, confirm_attempts, inter_timeout, digit_len, timeout, max_failures), true) {
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t outgoing_channel {
+    set {
+      freeswitchPINVOKE.switch_io_routines_outgoing_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_outgoing_channel_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public void bindAction(string action, string arg, string bind) {
-    freeswitchPINVOKE.IvrMenu_bindAction(swigCPtr, action, arg, bind);
+  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame {
+    set {
+      freeswitchPINVOKE.switch_io_routines_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_read_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public void Execute(CoreSession session, string name) {
-    freeswitchPINVOKE.IvrMenu_Execute(swigCPtr, CoreSession.getCPtr(session), name);
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame {
+    set {
+      freeswitchPINVOKE.switch_io_routines_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_write_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel {
+    set {
+      freeswitchPINVOKE.switch_io_routines_kill_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_kill_channel_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public partial class ManagedSession : CoreSession {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t send_dtmf {
+    set {
+      freeswitchPINVOKE.switch_io_routines_send_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_send_dtmf_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal ManagedSession(IntPtr cPtr, bool cMemoryOwn) : base(freeswitchPINVOKE.ManagedSessionUpcast(cPtr), cMemoryOwn) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message {
+    set {
+      freeswitchPINVOKE.switch_io_routines_receive_message_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_receive_message_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(ManagedSession obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event {
+    set {
+      freeswitchPINVOKE.switch_io_routines_receive_event_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_receive_event_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  ~ManagedSession() {
-    Dispose();
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change {
+    set {
+      freeswitchPINVOKE.switch_io_routines_state_change_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_state_change_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public override void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_ManagedSession(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-      base.Dispose();
-    }
+  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_video_frame {
+    set {
+      freeswitchPINVOKE.switch_io_routines_read_video_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_read_video_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public ManagedSession() : this(freeswitchPINVOKE.new_ManagedSession__SWIG_0(), true) {
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_video_frame {
+    set {
+      freeswitchPINVOKE.switch_io_routines_write_video_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_write_video_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public ManagedSession(string uuid) : this(freeswitchPINVOKE.new_ManagedSession__SWIG_1(uuid), true) {
+  public SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session {
+    set {
+      freeswitchPINVOKE.switch_io_routines_resurrect_session_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_resurrect_session_get(swigCPtr);
+      SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  public ManagedSession(SWIGTYPE_p_switch_core_session session) : this(freeswitchPINVOKE.new_ManagedSession__SWIG_2(SWIGTYPE_p_switch_core_session.getCPtr(session)), true) {
+  public SWIGTYPE_p_p_void padding {
+    set {
+      freeswitchPINVOKE.switch_io_routines_padding_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_padding_get(swigCPtr);
+      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
+  public switch_io_routines() : this(freeswitchPINVOKE.new_switch_io_routines(), true) {
+  }
 
-[System.Flags] public enum session_flag_t {
-  S_HUP = (1 << 0),
-  S_FREE = (1 << 1),
-  S_RDLOCK = (1 << 2)
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10266,20 +10337,20 @@
 using System;
 using System.Runtime.InteropServices;
 
-public partial class Stream : IDisposable {
+public class switch_endpoint_interface : IDisposable {
   private HandleRef swigCPtr;
   protected bool swigCMemOwn;
 
-  internal Stream(IntPtr cPtr, bool cMemoryOwn) {
+  internal switch_endpoint_interface(IntPtr cPtr, bool cMemoryOwn) {
     swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(Stream obj) {
+  internal static HandleRef getCPtr(switch_endpoint_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~Stream() {
+  ~switch_endpoint_interface() {
     Dispose();
   }
 
@@ -10287,184 +10358,87 @@
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_Stream(swigCPtr);
+        freeswitchPINVOKE.delete_switch_endpoint_interface(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
     }
   }
 
-  public Stream() : this(freeswitchPINVOKE.new_Stream__SWIG_0(), true) {
-  }
-
-  public Stream(switch_stream_handle arg0) : this(freeswitchPINVOKE.new_Stream__SWIG_1(switch_stream_handle.getCPtr(arg0)), true) {
-  }
-
-  public void Write(string data) {
-    freeswitchPINVOKE.Stream_Write(swigCPtr, data);
-  }
-
-  public string get_data() {
-    string ret = freeswitchPINVOKE.Stream_get_data(swigCPtr);
-    return ret;
-  }
-
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_apr_pool_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_apr_pool_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_apr_pool_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_apr_pool_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_FILE {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_FILE(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_FILE() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_FILE obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_float {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_float(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_float() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_endpoint_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_float obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_routines io_routines {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_io_routines_set(swigCPtr, switch_io_routines.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_io_routines_get(swigCPtr);
+      switch_io_routines ret = (cPtr == IntPtr.Zero) ? null : new switch_io_routines(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_state_handler_table state_handler {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_state_handler_set(swigCPtr, switch_state_handler_table.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_state_handler_get(swigCPtr);
+      switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_endpoint_interface next {
+    set {
+      freeswitchPINVOKE.switch_endpoint_interface_next_set(swigCPtr, switch_endpoint_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_next_get(swigCPtr);
+      switch_endpoint_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_endpoint_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_endpoint_interface() : this(freeswitchPINVOKE.new_switch_endpoint_interface(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10475,56 +10449,140 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t {
+public class switch_timer : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+  internal switch_timer(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_timer obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_timer() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_timer(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public int interval {
+    set {
+      freeswitchPINVOKE.switch_timer_interval_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_timer_interval_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_timer_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_timer_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint samples {
+    set {
+      freeswitchPINVOKE.switch_timer_samples_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_timer_samples_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint samplecount {
+    set {
+      freeswitchPINVOKE.switch_timer_samplecount_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_timer_samplecount_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_timer_interface timer_interface {
+    set {
+      freeswitchPINVOKE.switch_timer_timer_interface_set(swigCPtr, switch_timer_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_timer_interface_get(swigCPtr);
+      switch_timer_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_timer_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_timer_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_timer_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_size_t diff {
+    set {
+      freeswitchPINVOKE.switch_timer_diff_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_timer_diff_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_size_t tick {
+    set {
+      freeswitchPINVOKE.switch_timer_tick_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_timer_tick_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public switch_timer() : this(freeswitchPINVOKE.new_switch_timer(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10532,29 +10590,19 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+public enum switch_timer_func_name_t {
+  SWITCH_TIMER_FUNC_TIMER_INIT,
+  SWITCH_TIMER_FUNC_TIMER_NEXT,
+  SWITCH_TIMER_FUNC_TIMER_STEP,
+  SWITCH_TIMER_FUNC_TIMER_SYNC,
+  SWITCH_TIMER_FUNC_TIMER_CHECK,
+  SWITCH_TIMER_FUNC_TIMER_DESTROY
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10565,56 +10613,141 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t {
+public class switch_timer_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_timer_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_timer_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
+
+  ~switch_timer_interface() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_timer_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_timer_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_init {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_init_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_next {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_next_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_next_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_step {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_step_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_step_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_sync {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_sync_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_sync_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t timer_check {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_check_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_check_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_destroy {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_timer_destroy_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_destroy_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_timer_interface next {
+    set {
+      freeswitchPINVOKE.switch_timer_interface_next_set(swigCPtr, switch_timer_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_next_get(swigCPtr);
+      switch_timer_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_timer_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_timer_interface() : this(freeswitchPINVOKE.new_switch_timer_interface(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10625,56 +10758,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t {
+public class switch_dialplan_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_dialplan_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_dialplan_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_dialplan_interface() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_dialplan_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_dialplan_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_dialplan_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension hunt_function {
+    set {
+      freeswitchPINVOKE.switch_dialplan_interface_hunt_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_hunt_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_dialplan_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_dialplan_interface next {
+    set {
+      freeswitchPINVOKE.switch_dialplan_interface_next_set(swigCPtr, switch_dialplan_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_next_get(swigCPtr);
+      switch_dialplan_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_dialplan_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_dialplan_interface() : this(freeswitchPINVOKE.new_switch_dialplan_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10685,116 +10848,161 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t {
+public class switch_file_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_file_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_file_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_file_interface() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_file_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_file_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_file_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t file_open {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_open_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_f_p_switch_file_handle__switch_status_t file_close {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_close_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t file_read {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_read_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_read_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t file_write {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_write_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_write_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t file_seek {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_seek_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_seek_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t file_set_string {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_set_string_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_set_string_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t file_get_string {
+    set {
+      freeswitchPINVOKE.switch_file_interface_file_get_string_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_get_string_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  public string extens {
+  set { freeswitchPINVOKE.switch_file_interface_extens_set(swigCPtr, ref value); }
 
-using System;
-using System.Runtime.InteropServices;
+  get {
+    return freeswitchPINVOKE.switch_file_interface_extens_get(swigCPtr);
+  }
 
-public class SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  }
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_file_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_file_interface next {
+    set {
+      freeswitchPINVOKE.switch_file_interface_next_set(swigCPtr, switch_file_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_next_get(swigCPtr);
+      switch_file_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_file_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_file_interface() : this(freeswitchPINVOKE.new_switch_file_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -10805,236 +11013,376 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t {
+public class switch_file_handle : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_file_handle(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_file_handle obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_file_handle() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_file_handle(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_file_interface file_interface {
+    set {
+      freeswitchPINVOKE.switch_file_handle_file_interface_set(swigCPtr, switch_file_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_file_interface_get(swigCPtr);
+      switch_file_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_file_interface(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_file_handle_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_switch_file_t fd {
+    set {
+      freeswitchPINVOKE.switch_file_handle_fd_set(swigCPtr, SWIGTYPE_p_switch_file_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_fd_get(swigCPtr);
+      SWIGTYPE_p_switch_file_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_file_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint samples {
+    set {
+      freeswitchPINVOKE.switch_file_handle_samples_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_samples_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint samplerate {
+    set {
+      freeswitchPINVOKE.switch_file_handle_samplerate_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_samplerate_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint native_rate {
+    set {
+      freeswitchPINVOKE.switch_file_handle_native_rate_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_native_rate_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public byte channels {
+    set {
+      freeswitchPINVOKE.switch_file_handle_channels_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_file_handle_channels_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public uint format {
+    set {
+      freeswitchPINVOKE.switch_file_handle_format_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_format_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public uint sections {
+    set {
+      freeswitchPINVOKE.switch_file_handle_sections_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_sections_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public int seekable {
+    set {
+      freeswitchPINVOKE.switch_file_handle_seekable_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_file_handle_seekable_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_codec__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_switch_size_t sample_count {
+    set {
+      freeswitchPINVOKE.switch_file_handle_sample_count_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_file_handle_sample_count_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_codec__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int speed {
+    set {
+      freeswitchPINVOKE.switch_file_handle_speed_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_file_handle_speed_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_codec__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_file_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public uint prebuf {
+    set {
+      freeswitchPINVOKE.switch_file_handle_prebuf_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_prebuf_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint interval {
+    set {
+      freeswitchPINVOKE.switch_file_handle_interval_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_interval_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_file_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string handler {
+    set {
+      freeswitchPINVOKE.switch_file_handle_handler_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_file_handle_handler_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public long pos {
+    set {
+      freeswitchPINVOKE.switch_file_handle_pos_set(swigCPtr, value);
+    } 
+    get {
+      long ret = freeswitchPINVOKE.switch_file_handle_pos_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_switch_buffer audio_buffer {
+    set {
+      freeswitchPINVOKE.switch_file_handle_audio_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_audio_buffer_get(swigCPtr);
+      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_buffer sp_audio_buffer {
+    set {
+      freeswitchPINVOKE.switch_file_handle_sp_audio_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_sp_audio_buffer_get(swigCPtr);
+      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public uint thresh {
+    set {
+      freeswitchPINVOKE.switch_file_handle_thresh_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_thresh_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public uint silence_hits {
+    set {
+      freeswitchPINVOKE.switch_file_handle_silence_hits_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_silence_hits_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public uint offset_pos {
+    set {
+      freeswitchPINVOKE.switch_file_handle_offset_pos_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_offset_pos_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint last_pos {
+    set {
+      freeswitchPINVOKE.switch_file_handle_last_pos_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_file_handle_last_pos_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int vol {
+    set {
+      freeswitchPINVOKE.switch_file_handle_vol_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_file_handle_vol_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_audio_resampler_t resampler {
+    set {
+      freeswitchPINVOKE.switch_file_handle_resampler_set(swigCPtr, switch_audio_resampler_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_resampler_get(swigCPtr);
+      switch_audio_resampler_t ret = (cPtr == IntPtr.Zero) ? null : new switch_audio_resampler_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_buffer buffer {
+    set {
+      freeswitchPINVOKE.switch_file_handle_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_buffer_get(swigCPtr);
+      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public SWIGTYPE_p_unsigned_char dbuf {
+    set {
+      freeswitchPINVOKE.switch_file_handle_dbuf_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_dbuf_get(swigCPtr);
+      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_switch_size_t dbuflen {
+    set {
+      freeswitchPINVOKE.switch_file_handle_dbuflen_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_file_handle_dbuflen_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string file {
+    set {
+      freeswitchPINVOKE.switch_file_handle_file_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_file_handle_file_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void {
-  private HandleRef swigCPtr;
+  public string func {
+    set {
+      freeswitchPINVOKE.switch_file_handle_func_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_file_handle_func_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int line {
+    set {
+      freeswitchPINVOKE.switch_file_handle_line_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_file_handle_line_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_file_handle() : this(freeswitchPINVOKE.new_switch_file_handle(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11045,86 +11393,174 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t {
+public class switch_asr_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_asr_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_asr_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_asr_interface() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_asr_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_asr_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t asr_open {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_open_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t asr_load_grammar {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_load_grammar_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_load_grammar_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t asr_unload_grammar {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_unload_grammar_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_unload_grammar_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t asr_close {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_close_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t asr_feed {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_feed_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_feed_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t asr_resume {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_resume_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_resume_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t asr_pause {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_pause_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_pause_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t asr_check_results {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_check_results_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_check_results_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t asr_get_results {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_asr_get_results_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_get_results_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_asr_interface next {
+    set {
+      freeswitchPINVOKE.switch_asr_interface_next_set(swigCPtr, switch_asr_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_next_get(swigCPtr);
+      switch_asr_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_asr_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_asr_interface() : this(freeswitchPINVOKE.new_switch_asr_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11135,116 +11571,136 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t {
+public class switch_asr_handle : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+  internal switch_asr_handle(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t obj) {
+  internal static HandleRef getCPtr(switch_asr_handle obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_asr_handle() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_asr_handle(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_asr_interface asr_interface {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_asr_interface_set(swigCPtr, switch_asr_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_asr_interface_get(swigCPtr);
+      switch_asr_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_asr_interface(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_asr_handle_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string name {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_asr_handle_name_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string codec {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_codec_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_asr_handle_codec_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public uint rate {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_rate_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_asr_handle_rate_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string grammar {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_grammar_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_asr_handle_grammar_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string param {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_param_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_asr_handle_param_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_asr_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_asr_handle() : this(freeswitchPINVOKE.new_switch_asr_handle(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11255,86 +11711,163 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t {
+public class switch_speech_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_speech_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_speech_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_speech_interface() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_speech_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_speech_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t speech_open {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_open_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t speech_close {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_close_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t speech_feed_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_feed_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_feed_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t speech_read_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_read_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_read_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public SWIGTYPE_p_f_p_switch_speech_handle__void speech_flush_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_flush_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_flush_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle__void(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void speech_text_param_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_text_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_text_param_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void speech_numeric_param_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_numeric_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_numeric_param_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void speech_float_param_tts {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_speech_float_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_float_param_tts_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_speech_interface next {
+    set {
+      freeswitchPINVOKE.switch_speech_interface_next_set(swigCPtr, switch_speech_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_next_get(swigCPtr);
+      switch_speech_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_speech_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_speech_interface() : this(freeswitchPINVOKE.new_switch_speech_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11345,86 +11878,156 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_core_session__switch_status_t {
+public class switch_speech_handle : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_core_session__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_speech_handle(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_core_session__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_speech_handle obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_speech_handle() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_speech_handle(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_speech_interface speech_interface {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_speech_interface_set(swigCPtr, switch_speech_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_speech_interface_get(swigCPtr);
+      switch_speech_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_speech_interface(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_speech_handle_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string name {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_speech_handle_name_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint rate {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_rate_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_speech_handle_rate_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public uint speed {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_speed_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_speech_handle_speed_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public uint samples {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_samples_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_speech_handle_samples_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public string voice {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_voice_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_speech_handle_voice_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string engine {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_engine_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_speech_handle_engine_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t {
-  private HandleRef swigCPtr;
+  public string param {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_param_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_speech_handle_param_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_speech_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_speech_handle() : this(freeswitchPINVOKE.new_switch_speech_handle(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11435,56 +12038,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t {
+public class switch_say_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_say_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_say_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_say_interface() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_say_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_say_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_say_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t say_function {
+    set {
+      freeswitchPINVOKE.switch_say_interface_say_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_say_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_say_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_say_interface next {
+    set {
+      freeswitchPINVOKE.switch_say_interface_next_set(swigCPtr, switch_say_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_next_get(swigCPtr);
+      switch_say_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_say_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_say_interface() : this(freeswitchPINVOKE.new_switch_say_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11495,26 +12128,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_event__void {
+public class switch_chat_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_event__void(IntPtr cPtr, bool futureUse) {
+  internal switch_chat_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_event__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_chat_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_event__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_chat_interface() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_chat_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_chat_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_chat_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t chat_send {
+    set {
+      freeswitchPINVOKE.switch_chat_interface_chat_send_set(swigCPtr, SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_chat_send_get(swigCPtr);
+      SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_chat_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_chat_interface next {
+    set {
+      freeswitchPINVOKE.switch_chat_interface_next_set(swigCPtr, switch_chat_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_next_get(swigCPtr);
+      switch_chat_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_chat_interface(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_chat_interface() : this(freeswitchPINVOKE.new_switch_chat_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11525,26 +12218,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t {
+public class switch_management_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_management_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_management_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_management_interface() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_management_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public string relative_oid {
+    set {
+      freeswitchPINVOKE.switch_management_interface_relative_oid_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_management_interface_relative_oid_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t management_function {
+    set {
+      freeswitchPINVOKE.switch_management_interface_management_function_set(swigCPtr, SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_management_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_management_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_management_interface next {
+    set {
+      freeswitchPINVOKE.switch_management_interface_next_set(swigCPtr, switch_management_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_next_get(swigCPtr);
+      switch_management_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_management_interface(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_management_interface() : this(freeswitchPINVOKE.new_switch_management_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11555,56 +12308,130 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t {
+public class switch_directory_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_directory_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_directory_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_directory_interface() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_directory_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_directory_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t directory_open {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_directory_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_open_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t directory_close {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_directory_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_close_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t directory_query {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_directory_query_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_query_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t directory_next {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_directory_next_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_next_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t directory_next_pair {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_directory_next_pair_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_next_pair_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_directory_interface next {
+    set {
+      freeswitchPINVOKE.switch_directory_interface_next_set(swigCPtr, switch_directory_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_next_get(swigCPtr);
+      switch_directory_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_directory_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_directory_interface() : this(freeswitchPINVOKE.new_switch_directory_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11615,86 +12442,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t {
+public class switch_directory_handle : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_directory_handle(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_directory_handle obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_directory_handle() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_directory_handle(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_directory_interface directory_interface {
+    set {
+      freeswitchPINVOKE.switch_directory_handle_directory_interface_set(swigCPtr, switch_directory_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_directory_interface_get(swigCPtr);
+      switch_directory_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_directory_interface(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_file_handle__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_directory_handle_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_directory_handle_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_file_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_directory_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_file_handle__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_directory_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_directory_handle() : this(freeswitchPINVOKE.new_switch_directory_handle(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11705,146 +12532,203 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t {
+public class switch_codec_settings : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t(IntPtr cPtr, bool futureUse) {
+  internal switch_codec_settings(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t obj) {
+  internal static HandleRef getCPtr(switch_codec_settings obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  ~switch_codec_settings() {
+    Dispose();
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_codec_settings(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-public class SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void {
-  private HandleRef swigCPtr;
+  public int quality {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_quality_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_quality_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int complexity {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_complexity_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_complexity_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public int enhancement {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_enhancement_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_enhancement_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public int vad {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_vad_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_vad_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public int vbr {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_vbr_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_vbr_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public float vbr_quality {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_vbr_quality_set(swigCPtr, value);
+    } 
+    get {
+      float ret = freeswitchPINVOKE.switch_codec_settings_vbr_quality_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public int abr {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_abr_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_abr_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_scheduler_task__void {
-  private HandleRef swigCPtr;
+  public int dtx {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_dtx_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_dtx_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_scheduler_task__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int preproc {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_preproc_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_preproc_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_scheduler_task__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public int pp_vad {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_vad_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_pp_vad_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_scheduler_task__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public int pp_agc {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_agc_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_pp_agc_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public float pp_agc_level {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_agc_level_set(swigCPtr, value);
+    } 
+    get {
+      float ret = freeswitchPINVOKE.switch_codec_settings_pp_agc_level_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public int pp_denoise {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_denoise_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_pp_denoise_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public int pp_dereverb {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public float pp_dereverb_decay {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_decay_set(swigCPtr, value);
+    } 
+    get {
+      float ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_decay_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public float pp_dereverb_level {
+    set {
+      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_level_set(swigCPtr, value);
+    } 
+    get {
+      float ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_level_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_codec_settings() : this(freeswitchPINVOKE.new_switch_codec_settings(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11855,86 +12739,138 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void {
+public class switch_codec : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void(IntPtr cPtr, bool futureUse) {
+  internal switch_codec(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void obj) {
+  internal static HandleRef getCPtr(switch_codec obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_codec() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_codec(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_codec_interface codec_interface {
+    set {
+      freeswitchPINVOKE.switch_codec_codec_interface_set(swigCPtr, switch_codec_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_codec_interface_get(swigCPtr);
+      switch_codec_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_codec_implementation implementation {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_set(swigCPtr, switch_codec_implementation.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_get(swigCPtr);
+      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string fmtp_in {
+    set {
+      freeswitchPINVOKE.switch_codec_fmtp_in_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_codec_fmtp_in_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public string fmtp_out {
+    set {
+      freeswitchPINVOKE.switch_codec_fmtp_out_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_codec_fmtp_out_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public switch_codec_settings codec_settings {
+    set {
+      freeswitchPINVOKE.switch_codec_codec_settings_set(swigCPtr, switch_codec_settings.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_codec_settings_get(swigCPtr);
+      switch_codec_settings ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_settings(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_codec_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_apr_pool_t memory_pool {
+    set {
+      freeswitchPINVOKE.switch_codec_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_memory_pool_get(swigCPtr);
+      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_void private_info {
+    set {
+      freeswitchPINVOKE.switch_codec_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_private_info_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public byte agreed_pt {
+    set {
+      freeswitchPINVOKE.switch_codec_agreed_pt_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_codec_agreed_pt_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_codec() : this(freeswitchPINVOKE.new_switch_codec(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -11945,116 +12881,248 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t {
+public class switch_codec_implementation : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_codec_implementation(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_codec_implementation obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_codec_implementation() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_codec_implementation(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public switch_codec_type_t codec_type {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_codec_type_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_codec_type_t ret = (switch_codec_type_t)freeswitchPINVOKE.switch_codec_implementation_codec_type_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public byte ianacode {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_ianacode_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_codec_implementation_ianacode_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t {
-  private HandleRef swigCPtr;
+  public string iananame {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_iananame_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_codec_implementation_iananame_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string fmtp {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_fmtp_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_codec_implementation_fmtp_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint samples_per_second {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_samples_per_second_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_samples_per_second_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public uint actual_samples_per_second {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_actual_samples_per_second_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_actual_samples_per_second_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public int bits_per_second {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_bits_per_second_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_implementation_bits_per_second_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public int microseconds_per_frame {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_microseconds_per_frame_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_implementation_microseconds_per_frame_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public uint samples_per_frame {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_samples_per_frame_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_samples_per_frame_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_speech_handle__void {
-  private HandleRef swigCPtr;
+  public uint bytes_per_frame {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_bytes_per_frame_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_bytes_per_frame_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_speech_handle__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint encoded_bytes_per_frame {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_encoded_bytes_per_frame_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_encoded_bytes_per_frame_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_speech_handle__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public byte number_of_channels {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_number_of_channels_set(swigCPtr, value);
+    } 
+    get {
+      byte ret = freeswitchPINVOKE.switch_codec_implementation_number_of_channels_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public int pref_frames_per_packet {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_pref_frames_per_packet_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_implementation_pref_frames_per_packet_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public int max_frames_per_packet {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_max_frames_per_packet_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_codec_implementation_max_frames_per_packet_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t init {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_init_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t encode {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_encode_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_encode_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t decode {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_decode_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_decode_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_codec__switch_status_t destroy {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_destroy_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_destroy_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_codec__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public uint codec_id {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_codec_id_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_implementation_codec_id_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public switch_codec_implementation next {
+    set {
+      freeswitchPINVOKE.switch_codec_implementation_next_set(swigCPtr, switch_codec_implementation.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_next_get(swigCPtr);
+      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_codec_implementation() : this(freeswitchPINVOKE.new_switch_codec_implementation(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12065,86 +13133,96 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t {
+public class switch_codec_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_codec_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_codec_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_codec_interface() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_codec_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_codec_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_codec_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_codec_implementation implementations {
+    set {
+      freeswitchPINVOKE.switch_codec_interface_implementations_set(swigCPtr, switch_codec_implementation.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_implementations_get(swigCPtr);
+      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t {
-  private HandleRef swigCPtr;
+  public uint codec_id {
+    set {
+      freeswitchPINVOKE.switch_codec_interface_codec_id_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_codec_interface_codec_id_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_codec_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_codec_interface next {
+    set {
+      freeswitchPINVOKE.switch_codec_interface_next_set(swigCPtr, switch_codec_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_next_get(swigCPtr);
+      switch_codec_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_codec_interface() : this(freeswitchPINVOKE.new_switch_codec_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12155,86 +13233,126 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_p_switch_timer__switch_status_t {
+public class switch_application_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_p_switch_timer__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_application_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_p_switch_timer__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_timer__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_application_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_application_interface() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_application_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_application_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_application_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void application_function {
+    set {
+      freeswitchPINVOKE.switch_application_interface_application_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_application_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string long_desc {
+    set {
+      freeswitchPINVOKE.switch_application_interface_long_desc_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_application_interface_long_desc_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public string short_desc {
+    set {
+      freeswitchPINVOKE.switch_application_interface_short_desc_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_application_interface_short_desc_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public string syntax {
+    set {
+      freeswitchPINVOKE.switch_application_interface_syntax_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_application_interface_syntax_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_application_interface_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_application_interface_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_f_p_void__void {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_application_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_f_p_void__void(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_application_interface next {
+    set {
+      freeswitchPINVOKE.switch_application_interface_next_set(swigCPtr, switch_application_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_next_get(swigCPtr);
+      switch_application_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_application_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_f_p_void__void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_application_interface() : this(freeswitchPINVOKE.new_switch_application_interface(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_void__void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12245,86 +13363,106 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_f_void__switch_status_t {
+public class switch_api_interface : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_f_void__switch_status_t(IntPtr cPtr, bool futureUse) {
+  internal switch_api_interface(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_f_void__switch_status_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_f_void__switch_status_t obj) {
+  internal static HandleRef getCPtr(switch_api_interface obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_HashElem {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_HashElem(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_api_interface() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_HashElem() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_api_interface(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_HashElem obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string interface_name {
+    set {
+      freeswitchPINVOKE.switch_api_interface_interface_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_api_interface_interface_name_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  public string desc {
+    set {
+      freeswitchPINVOKE.switch_api_interface_desc_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_api_interface_desc_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t function {
+    set {
+      freeswitchPINVOKE.switch_api_interface_function_set(swigCPtr, SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_function_get(swigCPtr);
+      SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_int {
-  private HandleRef swigCPtr;
+  public string syntax {
+    set {
+      freeswitchPINVOKE.switch_api_interface_syntax_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_api_interface_syntax_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_int(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+    set {
+      freeswitchPINVOKE.switch_api_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_rwlock_get(swigCPtr);
+      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_int() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_api_interface next {
+    set {
+      freeswitchPINVOKE.switch_api_interface_next_set(swigCPtr, switch_api_interface.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_next_get(swigCPtr);
+      switch_api_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_api_interface(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_int obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_api_interface() : this(freeswitchPINVOKE.new_switch_api_interface(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12335,116 +13473,138 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_apr_pool_t {
+public class switch_channel_timetable : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_apr_pool_t(IntPtr cPtr, bool futureUse) {
+  internal switch_channel_timetable(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_apr_pool_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_apr_pool_t obj) {
+  internal static HandleRef getCPtr(switch_channel_timetable obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_char {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_char(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_channel_timetable() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_p_char() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_channel_timetable(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_char obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_time_t profile_created {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_profile_created_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_profile_created_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_switch_time_t created {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_created_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_created_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_switch_time_t answered {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_answered_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_answered_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_p_char {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_switch_time_t progress {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_progress_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_progress_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_p_char(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_time_t progress_media {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_progress_media_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_progress_media_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_p_char() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_switch_time_t hungup {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_hungup_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_hungup_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_p_char obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_time_t transferred {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_transferred_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_transferred_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_real_pcre {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_real_pcre(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_channel_timetable next {
+    set {
+      freeswitchPINVOKE.switch_channel_timetable_next_set(swigCPtr, switch_channel_timetable.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_channel_timetable_next_get(swigCPtr);
+      switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_real_pcre() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_channel_timetable() : this(freeswitchPINVOKE.new_switch_channel_timetable(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_real_pcre obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12455,56 +13615,74 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_sqlite3 {
+public class switch_event_header : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_sqlite3(IntPtr cPtr, bool futureUse) {
+  internal switch_event_header(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_sqlite3() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_sqlite3 obj) {
+  internal static HandleRef getCPtr(switch_event_header obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  ~switch_event_header() {
+    Dispose();
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_event_header(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-public class SWIGTYPE_p_p_sqlite3_stmt {
-  private HandleRef swigCPtr;
+  public string name {
+    set {
+      freeswitchPINVOKE.switch_event_header_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_event_header_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_sqlite3_stmt(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string value {
+    set {
+      freeswitchPINVOKE.switch_event_header_value_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_event_header_value_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_sqlite3_stmt() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_event_header next {
+    set {
+      freeswitchPINVOKE.switch_event_header_next_set(swigCPtr, switch_event_header.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_header_next_get(swigCPtr);
+      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_sqlite3_stmt obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_event_header() : this(freeswitchPINVOKE.new_switch_event_header(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12515,86 +13693,158 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_audio_resampler_t {
+public class switch_event : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_switch_audio_resampler_t(IntPtr cPtr, bool futureUse) {
+  internal switch_event(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_switch_audio_resampler_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_audio_resampler_t obj) {
+  internal static HandleRef getCPtr(switch_event obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_event() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_event(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_event_types_t event_id {
+    set {
+      freeswitchPINVOKE.switch_event_event_id_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_event_types_t ret = (switch_event_types_t)freeswitchPINVOKE.switch_event_event_id_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_buffer {
-  private HandleRef swigCPtr;
+  public switch_priority_t priority {
+    set {
+      freeswitchPINVOKE.switch_event_priority_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_priority_t ret = (switch_priority_t)freeswitchPINVOKE.switch_event_priority_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_buffer(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string owner {
+    set {
+      freeswitchPINVOKE.switch_event_owner_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_event_owner_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_buffer() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string subclass_name {
+    set {
+      freeswitchPINVOKE.switch_event_subclass_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_event_subclass_name_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_buffer obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_event_header headers {
+    set {
+      freeswitchPINVOKE.switch_event_headers_set(swigCPtr, switch_event_header.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_headers_get(swigCPtr);
+      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public switch_event_header last_header {
+    set {
+      freeswitchPINVOKE.switch_event_last_header_set(swigCPtr, switch_event_header.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_last_header_get(swigCPtr);
+      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public string body {
+    set {
+      freeswitchPINVOKE.switch_event_body_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_event_body_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_void bind_user_data {
+    set {
+      freeswitchPINVOKE.switch_event_bind_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_bind_user_data_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_caller_extension {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_void event_user_data {
+    set {
+      freeswitchPINVOKE.switch_event_event_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_event_user_data_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_caller_extension(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint key {
+    set {
+      freeswitchPINVOKE.switch_event_key_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_event_key_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_caller_extension() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_event next {
+    set {
+      freeswitchPINVOKE.switch_event_next_set(swigCPtr, switch_event.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_event_next_get(swigCPtr);
+      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_caller_extension obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_event() : this(freeswitchPINVOKE.new_switch_event(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12605,86 +13855,158 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_channel {
+public class switch_audio_resampler_t : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_switch_channel(IntPtr cPtr, bool futureUse) {
+  internal switch_audio_resampler_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_switch_channel() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_channel obj) {
+  internal static HandleRef getCPtr(switch_audio_resampler_t obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_audio_resampler_t() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_audio_resampler_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_void resampler {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_resampler_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_resampler_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_core_port_allocator {
-  private HandleRef swigCPtr;
+  public int from_rate {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_from_rate_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_audio_resampler_t_from_rate_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_core_port_allocator(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int to_rate {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_to_rate_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_audio_resampler_t_to_rate_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_core_port_allocator() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public double factor {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_factor_set(swigCPtr, value);
+    } 
+    get {
+      double ret = freeswitchPINVOKE.switch_audio_resampler_t_factor_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_port_allocator obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public double rfactor {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_rfactor_set(swigCPtr, value);
+    } 
+    get {
+      double ret = freeswitchPINVOKE.switch_audio_resampler_t_rfactor_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public SWIGTYPE_p_float from {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_from_set(swigCPtr, SWIGTYPE_p_float.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_from_get(swigCPtr);
+      SWIGTYPE_p_float ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_float(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public int from_len {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_from_len_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_audio_resampler_t_from_len_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_switch_size_t from_size {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_from_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_audio_resampler_t_from_size_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_core_session {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_float to {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_to_set(swigCPtr, SWIGTYPE_p_float.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_to_get(swigCPtr);
+      SWIGTYPE_p_float ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_float(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_core_session(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public uint to_len {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_to_len_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_audio_resampler_t_to_len_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_core_session() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint to_size {
+    set {
+      freeswitchPINVOKE.switch_audio_resampler_t_to_size_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_audio_resampler_t_to_size_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_session obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_audio_resampler_t() : this(freeswitchPINVOKE.new_switch_audio_resampler_t(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12695,146 +14017,211 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_core_session_message {
+public class switch_unicast_conninfo : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_switch_core_session_message(IntPtr cPtr, bool futureUse) {
+  internal switch_unicast_conninfo(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_switch_core_session_message() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_session_message obj) {
+  internal static HandleRef getCPtr(switch_unicast_conninfo obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  ~switch_unicast_conninfo() {
+    Dispose();
+  }
 
-namespace FreeSWITCH.Native {
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_unicast_conninfo(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_switch_core_session session {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_session_set(swigCPtr, SWIGTYPE_p_switch_core_session.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_session_get(swigCPtr);
+      SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_event {
-  private HandleRef swigCPtr;
+  public switch_codec read_codec {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_read_codec_set(swigCPtr, switch_codec.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_read_codec_get(swigCPtr);
+      switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_event(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_frame write_frame {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_write_frame_set(swigCPtr, switch_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_write_frame_get(swigCPtr);
+      switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_event() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_unsigned_char write_frame_data {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_write_frame_data_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_write_frame_data_get(swigCPtr);
+      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_event obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_socket_t socket {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_socket_set(swigCPtr, SWIGTYPE_p_switch_socket_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_socket_get(swigCPtr);
+      SWIGTYPE_p_switch_socket_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_socket_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_event_node {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_p_switch_event_node(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string local_ip {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_local_ip_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_unicast_conninfo_local_ip_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_event_node() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public ushort local_port {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_local_port_set(swigCPtr, value);
+    } 
+    get {
+      ushort ret = freeswitchPINVOKE.switch_unicast_conninfo_local_port_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_event_node obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string remote_ip {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_remote_ip_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_unicast_conninfo_remote_ip_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_frame {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_frame(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public ushort remote_port {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_remote_port_set(swigCPtr, value);
+    } 
+    get {
+      ushort ret = freeswitchPINVOKE.switch_unicast_conninfo_remote_port_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_frame() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public SWIGTYPE_p_switch_sockaddr_t local_addr {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_local_addr_set(swigCPtr, SWIGTYPE_p_switch_sockaddr_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_local_addr_get(swigCPtr);
+      SWIGTYPE_p_switch_sockaddr_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_sockaddr_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_frame obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_sockaddr_t remote_addr {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_remote_addr_set(swigCPtr, SWIGTYPE_p_switch_sockaddr_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_remote_addr_get(swigCPtr);
+      SWIGTYPE_p_switch_sockaddr_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_sockaddr_t(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_switch_mutex_t flag_mutex {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_flag_mutex_set(swigCPtr, SWIGTYPE_p_switch_mutex_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_flag_mutex_get(swigCPtr);
+      SWIGTYPE_p_switch_mutex_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_mutex_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public int flags {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_flags_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_unicast_conninfo_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_hash {
-  private HandleRef swigCPtr;
+  public int type {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_type_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_unicast_conninfo_type_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_hash(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int transport {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_transport_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_unicast_conninfo_transport_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_hash() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public int stream_id {
+    set {
+      freeswitchPINVOKE.switch_unicast_conninfo_stream_id_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_unicast_conninfo_stream_id_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_hash obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_unicast_conninfo() : this(freeswitchPINVOKE.new_switch_unicast_conninfo(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12842,29 +14229,16 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_ivr_digit_stream {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_ivr_digit_stream(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_p_switch_ivr_digit_stream() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_digit_stream obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+public enum switch_ivr_menu_flags {
+  SWITCH_IVR_MENU_FLAG_FALLTOMAIN = (1 << 0),
+  SWITCH_IVR_MENU_FLAG_FREEPOOL = (1 << 1),
+  SWITCH_IVR_MENU_FLAG_STACK = (1 << 2)
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12872,29 +14246,20 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_ivr_digit_stream_parser {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_ivr_digit_stream_parser(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_p_switch_ivr_digit_stream_parser() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_digit_stream_parser obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+public enum switch_ivr_action_t {
+  SWITCH_IVR_ACTION_DIE,
+  SWITCH_IVR_ACTION_EXECMENU,
+  SWITCH_IVR_ACTION_EXECAPP,
+  SWITCH_IVR_ACTION_PLAYSOUND,
+  SWITCH_IVR_ACTION_BACK,
+  SWITCH_IVR_ACTION_TOMAIN,
+  SWITCH_IVR_ACTION_NOOP
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12902,29 +14267,16 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_ivr_menu {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_ivr_menu(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_p_switch_ivr_menu() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_menu obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+public enum switch_rtp_crypto_direction_t {
+  SWITCH_RTP_CRYPTO_SEND,
+  SWITCH_RTP_CRYPTO_RECV,
+  SWITCH_RTP_CRYPTO_MAX
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12932,29 +14284,17 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_ivr_menu_xml_ctx {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_ivr_menu_xml_ctx(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_p_switch_ivr_menu_xml_ctx() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+public enum switch_rtp_crypto_key_type_t {
+  NO_CRYPTO,
+  AES_CM_128_HMAC_SHA1_80,
+  AES_CM_128_HMAC_SHA1_32,
+  AES_CM_128_NULL_AUTH
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -12965,56 +14305,97 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_media_bug {
+public class switch_rtp_crypto_key : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_switch_media_bug(IntPtr cPtr, bool futureUse) {
+  internal switch_rtp_crypto_key(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_switch_media_bug() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_rtp_crypto_key obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_media_bug obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_rtp_crypto_key() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_rtp_crypto_key(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public uint index {
+    set {
+      freeswitchPINVOKE.switch_rtp_crypto_key_index_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_rtp_crypto_key_index_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_rtp_crypto_key_type_t type {
+    set {
+      freeswitchPINVOKE.switch_rtp_crypto_key_type_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_rtp_crypto_key_type_t ret = (switch_rtp_crypto_key_type_t)freeswitchPINVOKE.switch_rtp_crypto_key_type_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_network_list {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_unsigned_char key {
+    set {
+      freeswitchPINVOKE.switch_rtp_crypto_key_key_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_rtp_crypto_key_key_get(swigCPtr);
+      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_network_list(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_switch_size_t keylen {
+    set {
+      freeswitchPINVOKE.switch_rtp_crypto_key_keylen_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_crypto_key_keylen_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_network_list() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_rtp_crypto_key next {
+    set {
+      freeswitchPINVOKE.switch_rtp_crypto_key_next_set(swigCPtr, switch_rtp_crypto_key.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_rtp_crypto_key_next_get(swigCPtr);
+      switch_rtp_crypto_key ret = (cPtr == IntPtr.Zero) ? null : new switch_rtp_crypto_key(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_network_list obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_rtp_crypto_key() : this(freeswitchPINVOKE.new_switch_rtp_crypto_key(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13025,56 +14406,125 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_switch_rtp {
+public class switch_log_node_t : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_switch_rtp(IntPtr cPtr, bool futureUse) {
+  internal switch_log_node_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_switch_rtp() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_log_node_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_rtp obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_log_node_t() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_log_node_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public string data {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_data_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_log_node_t_data_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string file {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_file_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_log_node_t_file_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_p_switch_xml {
-  private HandleRef swigCPtr;
+  public uint line {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_line_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_log_node_t_line_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_p_switch_xml(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string func {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_func_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_log_node_t_func_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_p_switch_xml() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_log_level_t level {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_level_set(swigCPtr, (int)value);
+    } 
+    get {
+      switch_log_level_t ret = (switch_log_level_t)freeswitchPINVOKE.switch_log_node_t_level_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_xml obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_switch_time_t timestamp {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_timestamp_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_log_node_t_timestamp_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public string content {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_content_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_log_node_t_content_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public string userdata {
+    set {
+      freeswitchPINVOKE.switch_log_node_t_userdata_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_log_node_t_userdata_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public switch_log_node_t() : this(freeswitchPINVOKE.new_switch_log_node_t(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13082,29 +14532,17 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_p_switch_xml_binding {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_p_switch_xml_binding(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_p_switch_xml_binding() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_xml_binding obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+[System.Flags] public enum switch_xml_flag_t {
+  SWITCH_XML_ROOT = (1 << 0),
+  SWITCH_XML_NAMEM = (1 << 1),
+  SWITCH_XML_TXTM = (1 << 2),
+  SWITCH_XML_DUP = (1 << 3)
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13115,56 +14553,159 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_p_void {
+public class switch_xml : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_p_void(IntPtr cPtr, bool futureUse) {
+  internal switch_xml(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_p_void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_xml obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_p_void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_xml() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_xml(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public string name {
+    set {
+      freeswitchPINVOKE.switch_xml_name_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_xml_name_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public string attr {
+  set { freeswitchPINVOKE.switch_xml_attr_set(swigCPtr, ref value); }
 
-public class SWIGTYPE_p_real_pcre {
-  private HandleRef swigCPtr;
+  get {
+    return freeswitchPINVOKE.switch_xml_attr_get(swigCPtr);
+  }
 
-  internal SWIGTYPE_p_real_pcre(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_real_pcre() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string txt {
+    set {
+      freeswitchPINVOKE.switch_xml_txt_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_xml_txt_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_real_pcre obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string free_path {
+    set {
+      freeswitchPINVOKE.switch_xml_free_path_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_xml_free_path_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public SWIGTYPE_p_switch_size_t off {
+    set {
+      freeswitchPINVOKE.switch_xml_off_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    } 
+    get {
+      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_xml_off_get(swigCPtr), true);
+      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+      return ret;
+    } 
+  }
+
+  public switch_xml next {
+    set {
+      freeswitchPINVOKE.switch_xml_next_set(swigCPtr, switch_xml.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_xml_next_get(swigCPtr);
+      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_xml sibling {
+    set {
+      freeswitchPINVOKE.switch_xml_sibling_set(swigCPtr, switch_xml.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_xml_sibling_get(swigCPtr);
+      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_xml ordered {
+    set {
+      freeswitchPINVOKE.switch_xml_ordered_set(swigCPtr, switch_xml.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_xml_ordered_get(swigCPtr);
+      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_xml child {
+    set {
+      freeswitchPINVOKE.switch_xml_child_set(swigCPtr, switch_xml.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_xml_child_get(swigCPtr);
+      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_xml parent {
+    set {
+      freeswitchPINVOKE.switch_xml_parent_set(swigCPtr, switch_xml.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_xml_parent_get(swigCPtr);
+      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public uint flags {
+    set {
+      freeswitchPINVOKE.switch_xml_flags_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_xml_flags_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public switch_xml() : this(freeswitchPINVOKE.new_switch_xml(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13175,26 +14716,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_short {
+public class switch_io_event_hook_outgoing_channel : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_short(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_outgoing_channel(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_short() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hook_outgoing_channel obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_short obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hook_outgoing_channel() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_outgoing_channel(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_outgoing_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_outgoing_channel_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_outgoing_channel next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_next_set(swigCPtr, switch_io_event_hook_outgoing_channel.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_next_get(swigCPtr);
+      switch_io_event_hook_outgoing_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_outgoing_channel(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_outgoing_channel() : this(freeswitchPINVOKE.new_switch_io_event_hook_outgoing_channel(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13205,26 +14785,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_sockaddr {
+public class switch_io_event_hook_receive_message : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_sockaddr(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_receive_message(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_sockaddr() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hook_receive_message obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_sockaddr obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hook_receive_message() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_receive_message(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_receive_message_receive_message_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_message_receive_message_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_receive_message next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_receive_message_next_set(swigCPtr, switch_io_event_hook_receive_message.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_message_next_get(swigCPtr);
+      switch_io_event_hook_receive_message ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_message(cPtr, false);
+      return ret;
+    } 
   }
+
+  public switch_io_event_hook_receive_message() : this(freeswitchPINVOKE.new_switch_io_event_hook_receive_message(), true) {
+  }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13235,56 +14854,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_socklen_t {
+public class switch_io_event_hook_receive_event : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_socklen_t(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_receive_event(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_socklen_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_socklen_t obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_receive_event obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_receive_event() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_sqlite3 {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_receive_event(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_sqlite3(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_receive_event_receive_event_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_event_receive_event_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_sqlite3() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_receive_event next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_receive_event_next_set(swigCPtr, switch_io_event_hook_receive_event.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_event_next_get(swigCPtr);
+      switch_io_event_hook_receive_event ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_event(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_sqlite3 obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_receive_event() : this(freeswitchPINVOKE.new_switch_io_event_hook_receive_event(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13295,56 +14923,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_sqlite3_stmt {
+public class switch_io_event_hook_read_frame : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_sqlite3_stmt(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_read_frame(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_sqlite3_stmt() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_sqlite3_stmt obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_read_frame obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_read_frame() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_buffer {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_read_frame(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_buffer(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_read_frame_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_read_frame_read_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_buffer() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_read_frame next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_read_frame_next_set(swigCPtr, switch_io_event_hook_read_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_read_frame_next_get(swigCPtr);
+      switch_io_event_hook_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_read_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_buffer obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_read_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_read_frame(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13355,56 +14992,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_call_cause_t {
+public class switch_io_event_hook_video_read_frame : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_video_read_frame(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_call_cause_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_call_cause_t obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_video_read_frame obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_video_read_frame() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_channel {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_video_read_frame(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_channel(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_video_read_frame_video_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_read_frame_video_read_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_channel() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_video_read_frame next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_video_read_frame_next_set(swigCPtr, switch_io_event_hook_video_read_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_read_frame_next_get(swigCPtr);
+      switch_io_event_hook_video_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_read_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_channel obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_video_read_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_video_read_frame(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13415,56 +15061,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_core_port_allocator {
+public class switch_io_event_hook_write_frame : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_core_port_allocator(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_write_frame(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_core_port_allocator() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_core_port_allocator obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_write_frame obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
+  ~switch_io_event_hook_write_frame() {
+    Dispose();
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_write_frame(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-public class SWIGTYPE_p_switch_core_session {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_write_frame_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_write_frame_write_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_switch_core_session(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_io_event_hook_write_frame next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_write_frame_next_set(swigCPtr, switch_io_event_hook_write_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_write_frame_next_get(swigCPtr);
+      switch_io_event_hook_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_write_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_core_session() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_write_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_write_frame(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_core_session obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13475,56 +15130,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_event_node {
+public class switch_io_event_hook_video_write_frame : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_event_node(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_video_write_frame(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_event_node() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_event_node obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_video_write_frame obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_video_write_frame() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_event_types_t {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_video_write_frame(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_event_types_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_video_write_frame_video_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_write_frame_video_write_frame_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_event_types_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_video_write_frame next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_video_write_frame_next_set(swigCPtr, switch_io_event_hook_video_write_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_write_frame_next_get(swigCPtr);
+      switch_io_event_hook_video_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_write_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_event_types_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_video_write_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_video_write_frame(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13535,56 +15199,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_file_t {
+public class switch_io_event_hook_kill_channel : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_file_t(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_kill_channel(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_file_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_file_t obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_kill_channel obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_kill_channel() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_hash {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_kill_channel(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_hash(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_kill_channel_kill_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_kill_channel_kill_channel_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_hash() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_kill_channel next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_kill_channel_next_set(swigCPtr, switch_io_event_hook_kill_channel.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_kill_channel_next_get(swigCPtr);
+      switch_io_event_hook_kill_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_kill_channel(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_hash obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_kill_channel() : this(freeswitchPINVOKE.new_switch_io_event_hook_kill_channel(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13595,56 +15268,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ivr_action_t {
+public class switch_io_event_hook_send_dtmf : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ivr_action_t(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_send_dtmf(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ivr_action_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_action_t obj) {
+  internal static HandleRef getCPtr(switch_io_event_hook_send_dtmf obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~switch_io_event_hook_send_dtmf() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_ivr_digit_stream {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_send_dtmf(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_ivr_digit_stream(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_send_dtmf_send_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_send_dtmf_send_dtmf_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_ivr_digit_stream() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_send_dtmf next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_send_dtmf_next_set(swigCPtr, switch_io_event_hook_send_dtmf.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_send_dtmf_next_get(swigCPtr);
+      switch_io_event_hook_send_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_send_dtmf(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_digit_stream obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_send_dtmf() : this(freeswitchPINVOKE.new_switch_io_event_hook_send_dtmf(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13655,26 +15337,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ivr_digit_stream_parser {
+public class switch_io_event_hook_recv_dtmf : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ivr_digit_stream_parser(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_recv_dtmf(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ivr_digit_stream_parser() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hook_recv_dtmf obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_digit_stream_parser obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hook_recv_dtmf() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_recv_dtmf(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_recv_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_recv_dtmf_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_recv_dtmf next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_next_set(swigCPtr, switch_io_event_hook_recv_dtmf.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_next_get(swigCPtr);
+      switch_io_event_hook_recv_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_recv_dtmf(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_recv_dtmf() : this(freeswitchPINVOKE.new_switch_io_event_hook_recv_dtmf(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13685,26 +15406,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ivr_menu {
+public class switch_io_event_hook_state_change : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ivr_menu(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_state_change(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ivr_menu() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hook_state_change obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hook_state_change() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_state_change(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_state_change_state_change_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_state_change_state_change_get(swigCPtr);
+      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_state_change next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_state_change_next_set(swigCPtr, switch_io_event_hook_state_change.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_state_change_next_get(swigCPtr);
+      switch_io_event_hook_state_change ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_state_change(cPtr, false);
+      return ret;
+    } 
   }
+
+  public switch_io_event_hook_state_change() : this(freeswitchPINVOKE.new_switch_io_event_hook_state_change(), true) {
+  }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13715,26 +15475,65 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ivr_menu_action_function_t {
+public class switch_io_event_hook_resurrect_session : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ivr_menu_action_function_t(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hook_resurrect_session(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ivr_menu_action_function_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hook_resurrect_session obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu_action_function_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hook_resurrect_session() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hook_resurrect_session(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_resurrect_session_resurrect_session_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_resurrect_session_resurrect_session_get(swigCPtr);
+      SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_resurrect_session next {
+    set {
+      freeswitchPINVOKE.switch_io_event_hook_resurrect_session_next_set(swigCPtr, switch_io_event_hook_resurrect_session.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_resurrect_session_next_get(swigCPtr);
+      switch_io_event_hook_resurrect_session ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_resurrect_session(cPtr, false);
+      return ret;
+    } 
+  }
+
+  public switch_io_event_hook_resurrect_session() : this(freeswitchPINVOKE.new_switch_io_event_hook_resurrect_session(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13745,86 +15544,175 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ivr_menu_xml_ctx {
+public class switch_io_event_hooks : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ivr_menu_xml_ctx(IntPtr cPtr, bool futureUse) {
+  internal switch_io_event_hooks(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ivr_menu_xml_ctx() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(switch_io_event_hooks obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu_xml_ctx obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~switch_io_event_hooks() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_io_event_hooks(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public switch_io_event_hook_outgoing_channel outgoing_channel {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_outgoing_channel_set(swigCPtr, switch_io_event_hook_outgoing_channel.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_outgoing_channel_get(swigCPtr);
+      switch_io_event_hook_outgoing_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_outgoing_channel(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_io_event_hook_receive_message receive_message {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_receive_message_set(swigCPtr, switch_io_event_hook_receive_message.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_receive_message_get(swigCPtr);
+      switch_io_event_hook_receive_message ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_message(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_switch_loadable_module_interface {
-  private HandleRef swigCPtr;
+  public switch_io_event_hook_receive_event receive_event {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_receive_event_set(swigCPtr, switch_io_event_hook_receive_event.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_receive_event_get(swigCPtr);
+      switch_io_event_hook_receive_event ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_event(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_switch_loadable_module_interface(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_io_event_hook_read_frame read_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_read_frame_set(swigCPtr, switch_io_event_hook_read_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_read_frame_get(swigCPtr);
+      switch_io_event_hook_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_read_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_loadable_module_interface() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_video_read_frame video_read_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_video_read_frame_set(swigCPtr, switch_io_event_hook_video_read_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_video_read_frame_get(swigCPtr);
+      switch_io_event_hook_video_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_read_frame(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_loadable_module_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hook_write_frame write_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_write_frame_set(swigCPtr, switch_io_event_hook_write_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_write_frame_get(swigCPtr);
+      switch_io_event_hook_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_write_frame(cPtr, false);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public switch_io_event_hook_video_write_frame video_write_frame {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_video_write_frame_set(swigCPtr, switch_io_event_hook_video_write_frame.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_video_write_frame_get(swigCPtr);
+      switch_io_event_hook_video_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_write_frame(cPtr, false);
+      return ret;
+    } 
+  }
 
-namespace FreeSWITCH.Native {
+  public switch_io_event_hook_kill_channel kill_channel {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_kill_channel_set(swigCPtr, switch_io_event_hook_kill_channel.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_kill_channel_get(swigCPtr);
+      switch_io_event_hook_kill_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_kill_channel(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public switch_io_event_hook_send_dtmf send_dtmf {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_send_dtmf_set(swigCPtr, switch_io_event_hook_send_dtmf.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_send_dtmf_get(swigCPtr);
+      switch_io_event_hook_send_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_send_dtmf(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_switch_media_bug {
-  private HandleRef swigCPtr;
+  public switch_io_event_hook_recv_dtmf recv_dtmf {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_recv_dtmf_set(swigCPtr, switch_io_event_hook_recv_dtmf.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_recv_dtmf_get(swigCPtr);
+      switch_io_event_hook_recv_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_recv_dtmf(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_switch_media_bug(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public switch_io_event_hook_state_change state_change {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_state_change_set(swigCPtr, switch_io_event_hook_state_change.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_state_change_get(swigCPtr);
+      switch_io_event_hook_state_change ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_state_change(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_media_bug() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public switch_io_event_hook_resurrect_session resurrect_session {
+    set {
+      freeswitchPINVOKE.switch_io_event_hooks_resurrect_session_set(swigCPtr, switch_io_event_hook_resurrect_session.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_resurrect_session_get(swigCPtr);
+      switch_io_event_hook_resurrect_session ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_resurrect_session(cPtr, false);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_media_bug obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_io_event_hooks() : this(freeswitchPINVOKE.new_switch_io_event_hooks(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13835,116 +15723,104 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_mutex_t {
+public class switch_scheduler_task : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_mutex_t(IntPtr cPtr, bool futureUse) {
+  internal switch_scheduler_task(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_mutex_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_mutex_t obj) {
+  internal static HandleRef getCPtr(switch_scheduler_task obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_network_list {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_switch_network_list(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_scheduler_task() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_switch_network_list() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_scheduler_task(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_network_list obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public long created {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_created_set(swigCPtr, value);
+    } 
+    get {
+      long ret = freeswitchPINVOKE.switch_scheduler_task_created_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_switch_pollfd_t {
-  private HandleRef swigCPtr;
 
-  internal SWIGTYPE_p_switch_pollfd_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public long runtime {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_runtime_set(swigCPtr, value);
+    } 
+    get {
+      long ret = freeswitchPINVOKE.switch_scheduler_task_runtime_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_pollfd_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint cmd_id {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_cmd_id_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_scheduler_task_cmd_id_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_pollfd_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string group {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_group_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_scheduler_task_group_get(swigCPtr);
+      return ret;
+    } 
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_switch_queue_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_switch_queue_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public SWIGTYPE_p_void cmd_arg {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_cmd_arg_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_scheduler_task_cmd_arg_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_queue_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public uint task_id {
+    set {
+      freeswitchPINVOKE.switch_scheduler_task_task_id_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.switch_scheduler_task_task_id_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_queue_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_scheduler_task() : this(freeswitchPINVOKE.new_switch_scheduler_task(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -13955,116 +15831,134 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_rtp {
+public class switch_config : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_rtp(IntPtr cPtr, bool futureUse) {
+  internal switch_config(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_rtp() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_rtp obj) {
+  internal static HandleRef getCPtr(switch_config obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_switch_size_t {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_switch_size_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  ~switch_config() {
+    Dispose();
   }
 
-  protected SWIGTYPE_p_switch_size_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_switch_config(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_size_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public SWIGTYPE_p_FILE file {
+    set {
+      freeswitchPINVOKE.switch_config_file_set(swigCPtr, SWIGTYPE_p_FILE.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.switch_config_file_get(swigCPtr);
+      SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_sockaddr_t {
-  private HandleRef swigCPtr;
+  public string path {
+    set {
+      freeswitchPINVOKE.switch_config_path_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_config_path_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_switch_sockaddr_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string category {
+    set {
+      freeswitchPINVOKE.switch_config_category_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_config_category_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_sockaddr_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string section {
+    set {
+      freeswitchPINVOKE.switch_config_section_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_config_section_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_sockaddr_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string buf {
+    set {
+      freeswitchPINVOKE.switch_config_buf_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.switch_config_buf_get(swigCPtr);
+      return ret;
+    } 
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
 
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
+  public int lineno {
+    set {
+      freeswitchPINVOKE.switch_config_lineno_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_config_lineno_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_switch_socket_t {
-  private HandleRef swigCPtr;
+  public int catno {
+    set {
+      freeswitchPINVOKE.switch_config_catno_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_config_catno_get(swigCPtr);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_switch_socket_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public int sectno {
+    set {
+      freeswitchPINVOKE.switch_config_sectno_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_config_sectno_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_switch_socket_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public int lockto {
+    set {
+      freeswitchPINVOKE.switch_config_lockto_set(swigCPtr, value);
+    } 
+    get {
+      int ret = freeswitchPINVOKE.switch_config_lockto_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_socket_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public switch_config() : this(freeswitchPINVOKE.new_switch_config(), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14075,56 +15969,51 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_ssize_t {
+public class IvrMenu : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_ssize_t(IntPtr cPtr, bool futureUse) {
+  internal IvrMenu(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_ssize_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ssize_t obj) {
+  internal static HandleRef getCPtr(IvrMenu obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
+  ~IvrMenu() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_switch_thread_rwlock_t {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_IvrMenu(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_switch_thread_rwlock_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public IvrMenu(IvrMenu main, string name, string greeting_sound, string short_greeting_sound, string invalid_sound, string exit_sound, string confirm_macro, string confirm_key, int confirm_attempts, int inter_timeout, int digit_len, int timeout, int max_failures, int max_timeouts) : this(freeswitchPINVOKE.new_IvrMenu(IvrMenu.getCPtr(main), name, greeting_sound, short_greeting_sound, invalid_sound, exit_sound, confirm_macro, confirm_key, confirm_attempts, inter_timeout, digit_len, timeout, max_failures, max_timeouts), true) {
   }
 
-  protected SWIGTYPE_p_switch_thread_rwlock_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public void bindAction(string action, string arg, string bind) {
+    freeswitchPINVOKE.IvrMenu_bindAction(swigCPtr, action, arg, bind);
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_thread_rwlock_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public void Execute(CoreSession session, string name) {
+    freeswitchPINVOKE.IvrMenu_Execute(swigCPtr, CoreSession.getCPtr(session), name);
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14135,56 +16024,53 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_switch_time_t {
+public class Api : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_switch_time_t(IntPtr cPtr, bool futureUse) {
+  internal Api(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_switch_time_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_switch_time_t obj) {
+  internal static HandleRef getCPtr(Api obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
+  ~Api() {
+    Dispose();
+  }
 
-public class SWIGTYPE_p_time_t {
-  private HandleRef swigCPtr;
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_Api(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-  internal SWIGTYPE_p_time_t(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public Api() : this(freeswitchPINVOKE.new_Api(), true) {
   }
 
-  protected SWIGTYPE_p_time_t() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public string Execute(string command, string data) {
+    string ret = freeswitchPINVOKE.Api_Execute(swigCPtr, command, data);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_time_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public string ExecuteString(string command) {
+    string ret = freeswitchPINVOKE.Api_ExecuteString(swigCPtr, command);
+    return ret;
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14195,56 +16081,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_unsigned_char {
+public class input_callback_state_t : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_unsigned_char(IntPtr cPtr, bool futureUse) {
+  internal input_callback_state_t(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_unsigned_char() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(input_callback_state_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_char obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~input_callback_state_t() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_input_callback_state_t(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public SWIGTYPE_p_void function {
+    set {
+      freeswitchPINVOKE.input_callback_state_t_function_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_function_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public SWIGTYPE_p_void threadState {
+    set {
+      freeswitchPINVOKE.input_callback_state_t_threadState_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_threadState_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-public class SWIGTYPE_p_unsigned_int {
-  private HandleRef swigCPtr;
+  public SWIGTYPE_p_void extra {
+    set {
+      freeswitchPINVOKE.input_callback_state_t_extra_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.input_callback_state_t_extra_get(swigCPtr);
+      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal SWIGTYPE_p_unsigned_int(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
+  public string funcargs {
+    set {
+      freeswitchPINVOKE.input_callback_state_t_funcargs_set(swigCPtr, value);
+    } 
+    get {
+      string ret = freeswitchPINVOKE.input_callback_state_t_funcargs_get(swigCPtr);
+      return ret;
+    } 
   }
 
-  protected SWIGTYPE_p_unsigned_int() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  public input_callback_state_t() : this(freeswitchPINVOKE.new_input_callback_state_t(), true) {
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_int obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14252,29 +16168,16 @@
 
 namespace FreeSWITCH.Native {
 
-using System;
-using System.Runtime.InteropServices;
-
-public class SWIGTYPE_p_unsigned_long {
-  private HandleRef swigCPtr;
-
-  internal SWIGTYPE_p_unsigned_long(IntPtr cPtr, bool futureUse) {
-    swigCPtr = new HandleRef(this, cPtr);
-  }
-
-  protected SWIGTYPE_p_unsigned_long() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
-  }
-
-  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_long obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
+[System.Flags] public enum session_flag_t {
+  S_HUP = (1 << 0),
+  S_FREE = (1 << 1),
+  S_RDLOCK = (1 << 2)
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14285,26 +16188,63 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_unsigned_short {
+public class DTMF : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_unsigned_short(IntPtr cPtr, bool futureUse) {
+  internal DTMF(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_unsigned_short() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(DTMF obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_short obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~DTMF() {
+    Dispose();
+  }
+
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_DTMF(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
+
+  public char digit {
+    set {
+      freeswitchPINVOKE.DTMF_digit_set(swigCPtr, value);
+    } 
+    get {
+      char ret = freeswitchPINVOKE.DTMF_digit_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public uint duration {
+    set {
+      freeswitchPINVOKE.DTMF_duration_set(swigCPtr, value);
+    } 
+    get {
+      uint ret = freeswitchPINVOKE.DTMF_duration_get(swigCPtr);
+      return ret;
+    } 
+  }
+
+  public DTMF(char idigit, uint iduration) : this(freeswitchPINVOKE.new_DTMF(idigit, iduration), true) {
   }
+
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14315,47 +16255,55 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class SWIGTYPE_p_void {
+public partial class Stream : IDisposable {
   private HandleRef swigCPtr;
+  protected bool swigCMemOwn;
 
-  internal SWIGTYPE_p_void(IntPtr cPtr, bool futureUse) {
+  internal Stream(IntPtr cPtr, bool cMemoryOwn) {
+    swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  protected SWIGTYPE_p_void() {
-    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  internal static HandleRef getCPtr(Stream obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  internal static HandleRef getCPtr(SWIGTYPE_p_void obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  ~Stream() {
+    Dispose();
   }
-}
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public virtual void Dispose() {
+    lock(this) {
+      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
+        swigCMemOwn = false;
+        freeswitchPINVOKE.delete_Stream(swigCPtr);
+      }
+      swigCPtr = new HandleRef(null, IntPtr.Zero);
+      GC.SuppressFinalize(this);
+    }
+  }
 
-namespace FreeSWITCH.Native {
+  public Stream() : this(freeswitchPINVOKE.new_Stream__SWIG_0(), true) {
+  }
+
+  public Stream(switch_stream_handle arg0) : this(freeswitchPINVOKE.new_Stream__SWIG_1(switch_stream_handle.getCPtr(arg0)), true) {
+  }
+
+  public void Write(string data) {
+    freeswitchPINVOKE.Stream_Write(swigCPtr, data);
+  }
+
+  public string get_data() {
+    string ret = freeswitchPINVOKE.Stream_get_data(swigCPtr);
+    return ret;
+  }
 
-public enum switch_abc_type_t {
-  SWITCH_ABC_TYPE_INIT,
-  SWITCH_ABC_TYPE_READ,
-  SWITCH_ABC_TYPE_WRITE,
-  SWITCH_ABC_TYPE_WRITE_REPLACE,
-  SWITCH_ABC_TYPE_READ_REPLACE,
-  SWITCH_ABC_TYPE_READ_PING,
-  SWITCH_ABC_TYPE_CLOSE
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14366,20 +16314,20 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_api_interface : IDisposable {
+public partial class Event : IDisposable {
   private HandleRef swigCPtr;
   protected bool swigCMemOwn;
 
-  internal switch_api_interface(IntPtr cPtr, bool cMemoryOwn) {
+  internal Event(IntPtr cPtr, bool cMemoryOwn) {
     swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_api_interface obj) {
+  internal static HandleRef getCPtr(Event obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~switch_api_interface() {
+  ~Event() {
     Dispose();
   }
 
@@ -14387,101 +16335,101 @@
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_api_interface(swigCPtr);
+        freeswitchPINVOKE.delete_Event(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
     }
   }
 
-  public string interface_name {
+  public switch_event InternalEvent {
     set {
-      freeswitchPINVOKE.switch_api_interface_interface_name_set(swigCPtr, value);
+      freeswitchPINVOKE.Event_InternalEvent_set(swigCPtr, switch_event.getCPtr(value));
     } 
     get {
-      string ret = freeswitchPINVOKE.switch_api_interface_interface_name_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.Event_InternalEvent_get(swigCPtr);
+      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
       return ret;
     } 
   }
 
-  public string desc {
+  public string serialized_string {
     set {
-      freeswitchPINVOKE.switch_api_interface_desc_set(swigCPtr, value);
+      freeswitchPINVOKE.Event_serialized_string_set(swigCPtr, value);
     } 
     get {
-      string ret = freeswitchPINVOKE.switch_api_interface_desc_get(swigCPtr);
+      string ret = freeswitchPINVOKE.Event_serialized_string_get(swigCPtr);
       return ret;
     } 
   }
 
-  public SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t function {
+  public int mine {
     set {
-      freeswitchPINVOKE.switch_api_interface_function_set(swigCPtr, SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t.getCPtr(value));
+      freeswitchPINVOKE.Event_mine_set(swigCPtr, value);
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t(cPtr, false);
+      int ret = freeswitchPINVOKE.Event_mine_get(swigCPtr);
       return ret;
     } 
   }
 
-  public string syntax {
-    set {
-      freeswitchPINVOKE.switch_api_interface_syntax_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_api_interface_syntax_get(swigCPtr);
-      return ret;
-    } 
+  public Event(string type, string subclass_name) : this(freeswitchPINVOKE.new_Event__SWIG_0(type, subclass_name), true) {
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_api_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public Event(switch_event wrap_me, int free_me) : this(freeswitchPINVOKE.new_Event__SWIG_1(switch_event.getCPtr(wrap_me), free_me), true) {
   }
 
-  public switch_api_interface next {
-    set {
-      freeswitchPINVOKE.switch_api_interface_next_set(swigCPtr, switch_api_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_api_interface_next_get(swigCPtr);
-      switch_api_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_api_interface(cPtr, false);
-      return ret;
-    } 
+  public string Serialize(string format) {
+    string ret = freeswitchPINVOKE.Event_Serialize(swigCPtr, format);
+    return ret;
   }
 
-  public switch_api_interface() : this(freeswitchPINVOKE.new_switch_api_interface(), true) {
+  public bool SetPriority(switch_priority_t priority) {
+    bool ret = freeswitchPINVOKE.Event_SetPriority(swigCPtr, (int)priority);
+    return ret;
   }
 
-}
+  public string GetHeader(string header_name) {
+    string ret = freeswitchPINVOKE.Event_GetHeader(swigCPtr, header_name);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public string GetBody() {
+    string ret = freeswitchPINVOKE.Event_GetBody(swigCPtr);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public string GetEventType() {
+    string ret = freeswitchPINVOKE.Event_GetEventType(swigCPtr);
+    return ret;
+  }
+
+  public bool AddBody(string value) {
+    bool ret = freeswitchPINVOKE.Event_AddBody(swigCPtr, value);
+    return ret;
+  }
+
+  public bool AddHeader(string header_name, string value) {
+    bool ret = freeswitchPINVOKE.Event_AddHeader(swigCPtr, header_name, value);
+    return ret;
+  }
+
+  public bool DeleteHeader(string header_name) {
+    bool ret = freeswitchPINVOKE.Event_DeleteHeader(swigCPtr, header_name);
+    return ret;
+  }
+
+  public bool Fire() {
+    bool ret = freeswitchPINVOKE.Event_Fire(swigCPtr);
+    return ret;
+  }
 
-[System.Flags] public enum switch_application_flag_enum_t {
-  SAF_NONE = 0,
-  SAF_SUPPORT_NOMEDIA = (1 << 0)
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14492,20 +16440,20 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_application_interface : IDisposable {
+public class EventConsumer : IDisposable {
   private HandleRef swigCPtr;
   protected bool swigCMemOwn;
 
-  internal switch_application_interface(IntPtr cPtr, bool cMemoryOwn) {
+  internal EventConsumer(IntPtr cPtr, bool cMemoryOwn) {
     swigCMemOwn = cMemoryOwn;
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_application_interface obj) {
+  internal static HandleRef getCPtr(EventConsumer obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
 
-  ~switch_application_interface() {
+  ~EventConsumer() {
     Dispose();
   }
 
@@ -14513,97 +16461,82 @@
     lock(this) {
       if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
         swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_application_interface(swigCPtr);
+        freeswitchPINVOKE.delete_EventConsumer(swigCPtr);
       }
       swigCPtr = new HandleRef(null, IntPtr.Zero);
       GC.SuppressFinalize(this);
     }
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_application_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_application_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
-  }
-
-  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void application_function {
+  public SWIGTYPE_p_switch_queue_t events {
     set {
-      freeswitchPINVOKE.switch_application_interface_application_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void.getCPtr(value));
+      freeswitchPINVOKE.EventConsumer_events_set(swigCPtr, SWIGTYPE_p_switch_queue_t.getCPtr(value));
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_application_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(cPtr, false);
+      IntPtr cPtr = freeswitchPINVOKE.EventConsumer_events_get(swigCPtr);
+      SWIGTYPE_p_switch_queue_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_queue_t(cPtr, false);
       return ret;
     } 
   }
 
-  public string long_desc {
+  public switch_event_types_t e_event_id {
     set {
-      freeswitchPINVOKE.switch_application_interface_long_desc_set(swigCPtr, value);
+      freeswitchPINVOKE.EventConsumer_e_event_id_set(swigCPtr, (int)value);
     } 
     get {
-      string ret = freeswitchPINVOKE.switch_application_interface_long_desc_get(swigCPtr);
+      switch_event_types_t ret = (switch_event_types_t)freeswitchPINVOKE.EventConsumer_e_event_id_get(swigCPtr);
       return ret;
     } 
   }
 
-  public string short_desc {
+  public SWIGTYPE_p_switch_event_node node {
     set {
-      freeswitchPINVOKE.switch_application_interface_short_desc_set(swigCPtr, value);
+      freeswitchPINVOKE.EventConsumer_node_set(swigCPtr, SWIGTYPE_p_switch_event_node.getCPtr(value));
     } 
     get {
-      string ret = freeswitchPINVOKE.switch_application_interface_short_desc_get(swigCPtr);
+      IntPtr cPtr = freeswitchPINVOKE.EventConsumer_node_get(swigCPtr);
+      SWIGTYPE_p_switch_event_node ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_event_node(cPtr, false);
       return ret;
     } 
   }
 
-  public string syntax {
+  public string e_callback {
     set {
-      freeswitchPINVOKE.switch_application_interface_syntax_set(swigCPtr, value);
+      freeswitchPINVOKE.EventConsumer_e_callback_set(swigCPtr, value);
     } 
     get {
-      string ret = freeswitchPINVOKE.switch_application_interface_syntax_get(swigCPtr);
+      string ret = freeswitchPINVOKE.EventConsumer_e_callback_get(swigCPtr);
       return ret;
     } 
   }
 
-  public uint flags {
+  public string e_subclass_name {
     set {
-      freeswitchPINVOKE.switch_application_interface_flags_set(swigCPtr, value);
+      freeswitchPINVOKE.EventConsumer_e_subclass_name_set(swigCPtr, value);
     } 
     get {
-      uint ret = freeswitchPINVOKE.switch_application_interface_flags_get(swigCPtr);
+      string ret = freeswitchPINVOKE.EventConsumer_e_subclass_name_get(swigCPtr);
       return ret;
     } 
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
+  public string e_cb_arg {
     set {
-      freeswitchPINVOKE.switch_application_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
+      freeswitchPINVOKE.EventConsumer_e_cb_arg_set(swigCPtr, value);
     } 
     get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
+      string ret = freeswitchPINVOKE.EventConsumer_e_cb_arg_get(swigCPtr);
       return ret;
     } 
   }
 
-  public switch_application_interface next {
-    set {
-      freeswitchPINVOKE.switch_application_interface_next_set(swigCPtr, switch_application_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_application_interface_next_get(swigCPtr);
-      switch_application_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_application_interface(cPtr, false);
-      return ret;
-    } 
+  public EventConsumer(string event_name, string subclass_name) : this(freeswitchPINVOKE.new_EventConsumer(event_name, subclass_name), true) {
   }
 
-  public switch_application_interface() : this(freeswitchPINVOKE.new_switch_application_interface(), true) {
+  public Event pop(int block) {
+    IntPtr cPtr = freeswitchPINVOKE.EventConsumer_pop(swigCPtr, block);
+    Event ret = (cPtr == IntPtr.Zero) ? null : new Event(cPtr, false);
+    return ret;
   }
 
 }
@@ -14611,7 +16544,7 @@
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -14622,4531 +16555,3244 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_app_log : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+public class freeswitch {
+  public static switch_directories SWITCH_GLOBAL_dirs {
+    set {
+      freeswitchPINVOKE.SWITCH_GLOBAL_dirs_set(switch_directories.getCPtr(value));
+    } 
+    get {
+      IntPtr cPtr = freeswitchPINVOKE.SWITCH_GLOBAL_dirs_get();
+      switch_directories ret = (cPtr == IntPtr.Zero) ? null : new switch_directories(cPtr, false);
+      return ret;
+    } 
+  }
 
-  internal switch_app_log(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static int switch_core_db_close(SWIGTYPE_p_sqlite3 db) {
+    int ret = freeswitchPINVOKE.switch_core_db_close(SWIGTYPE_p_sqlite3.getCPtr(db));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_app_log obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static int switch_core_db_open(string filename, SWIGTYPE_p_p_sqlite3 ppDb) {
+    int ret = freeswitchPINVOKE.switch_core_db_open(filename, SWIGTYPE_p_p_sqlite3.getCPtr(ppDb));
+    return ret;
   }
 
-  ~switch_app_log() {
-    Dispose();
+  public static SWIGTYPE_p_unsigned_char switch_core_db_column_text(SWIGTYPE_p_sqlite3_stmt stmt, int iCol) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_db_column_text(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt), iCol);
+    SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_app_log(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static string switch_core_db_column_name(SWIGTYPE_p_sqlite3_stmt stmt, int N) {
+    string ret = freeswitchPINVOKE.switch_core_db_column_name(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt), N);
+    return ret;
   }
 
-  public string app {
-    set {
-      freeswitchPINVOKE.switch_app_log_app_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_app_log_app_get(swigCPtr);
-      return ret;
-    } 
+  public static int switch_core_db_column_count(SWIGTYPE_p_sqlite3_stmt pStmt) {
+    int ret = freeswitchPINVOKE.switch_core_db_column_count(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
+    return ret;
   }
 
-  public string arg {
-    set {
-      freeswitchPINVOKE.switch_app_log_arg_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_app_log_arg_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_core_db_errmsg(SWIGTYPE_p_sqlite3 db) {
+    string ret = freeswitchPINVOKE.switch_core_db_errmsg(SWIGTYPE_p_sqlite3.getCPtr(db));
+    return ret;
   }
 
-  public switch_app_log next {
-    set {
-      freeswitchPINVOKE.switch_app_log_next_set(swigCPtr, switch_app_log.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_app_log_next_get(swigCPtr);
-      switch_app_log ret = (cPtr == IntPtr.Zero) ? null : new switch_app_log(cPtr, false);
-      return ret;
-    } 
+  public static int switch_core_db_exec(SWIGTYPE_p_sqlite3 db, string sql, SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int callback, SWIGTYPE_p_void data, ref string errmsg) {
+    int ret = freeswitchPINVOKE.switch_core_db_exec(SWIGTYPE_p_sqlite3.getCPtr(db), sql, SWIGTYPE_p_f_p_void_int_p_p_char_p_p_char__int.getCPtr(callback), SWIGTYPE_p_void.getCPtr(data), ref errmsg);
+    return ret;
   }
 
-  public switch_app_log() : this(freeswitchPINVOKE.new_switch_app_log(), true) {
+  public static int switch_core_db_finalize(SWIGTYPE_p_sqlite3_stmt pStmt) {
+    int ret = freeswitchPINVOKE.switch_core_db_finalize(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
+    return ret;
   }
 
-}
+  public static int switch_core_db_prepare(SWIGTYPE_p_sqlite3 db, string zSql, int nBytes, SWIGTYPE_p_p_sqlite3_stmt ppStmt, ref string pzTail) {
+    int ret = freeswitchPINVOKE.switch_core_db_prepare(SWIGTYPE_p_sqlite3.getCPtr(db), zSql, nBytes, SWIGTYPE_p_p_sqlite3_stmt.getCPtr(ppStmt), ref pzTail);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static int switch_core_db_step(SWIGTYPE_p_sqlite3_stmt stmt) {
+    int ret = freeswitchPINVOKE.switch_core_db_step(SWIGTYPE_p_sqlite3_stmt.getCPtr(stmt));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static int switch_core_db_reset(SWIGTYPE_p_sqlite3_stmt pStmt) {
+    int ret = freeswitchPINVOKE.switch_core_db_reset(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt));
+    return ret;
+  }
+
+  public static int switch_core_db_bind_int(SWIGTYPE_p_sqlite3_stmt pStmt, int i, int iValue) {
+    int ret = freeswitchPINVOKE.switch_core_db_bind_int(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, iValue);
+    return ret;
+  }
+
+  public static int switch_core_db_bind_int64(SWIGTYPE_p_sqlite3_stmt pStmt, int i, long iValue) {
+    int ret = freeswitchPINVOKE.switch_core_db_bind_int64(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, iValue);
+    return ret;
+  }
+
+  public static int switch_core_db_bind_text(SWIGTYPE_p_sqlite3_stmt pStmt, int i, string zData, int nData, SWIGTYPE_p_f_p_void__void xDel) {
+    int ret = freeswitchPINVOKE.switch_core_db_bind_text(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, zData, nData, SWIGTYPE_p_f_p_void__void.getCPtr(xDel));
+    return ret;
+  }
+
+  public static int switch_core_db_bind_double(SWIGTYPE_p_sqlite3_stmt pStmt, int i, double dValue) {
+    int ret = freeswitchPINVOKE.switch_core_db_bind_double(SWIGTYPE_p_sqlite3_stmt.getCPtr(pStmt), i, dValue);
+    return ret;
+  }
+
+  public static long switch_core_db_last_insert_rowid(SWIGTYPE_p_sqlite3 db) {
+    long ret = freeswitchPINVOKE.switch_core_db_last_insert_rowid(SWIGTYPE_p_sqlite3.getCPtr(db));
+    return ret;
+  }
+
+  public static int switch_core_db_get_table(SWIGTYPE_p_sqlite3 db, string sql, SWIGTYPE_p_p_p_char resultp, SWIGTYPE_p_int nrow, SWIGTYPE_p_int ncolumn, ref string errmsg) {
+    int ret = freeswitchPINVOKE.switch_core_db_get_table(SWIGTYPE_p_sqlite3.getCPtr(db), sql, SWIGTYPE_p_p_p_char.getCPtr(resultp), SWIGTYPE_p_int.getCPtr(nrow), SWIGTYPE_p_int.getCPtr(ncolumn), ref errmsg);
+    return ret;
+  }
+
+  public static void switch_core_db_free_table(ref string result) {
+    freeswitchPINVOKE.switch_core_db_free_table(ref result);
+  }
+
+  public static void switch_core_db_free(string z) {
+    freeswitchPINVOKE.switch_core_db_free(z);
+  }
+
+  public static int switch_core_db_changes(SWIGTYPE_p_sqlite3 db) {
+    int ret = freeswitchPINVOKE.switch_core_db_changes(SWIGTYPE_p_sqlite3.getCPtr(db));
+    return ret;
+  }
+
+  public static string switch_mprintf(string zFormat) {
+    string ret = freeswitchPINVOKE.switch_mprintf(zFormat);
+    return ret;
+  }
+
+  public static SWIGTYPE_p_real_pcre switch_regex_compile(string pattern, int options, ref string errorptr, SWIGTYPE_p_int erroroffset, SWIGTYPE_p_unsigned_char tables) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_regex_compile(pattern, options, ref errorptr, SWIGTYPE_p_int.getCPtr(erroroffset), SWIGTYPE_p_unsigned_char.getCPtr(tables));
+    SWIGTYPE_p_real_pcre ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_real_pcre(cPtr, false);
+    return ret;
+  }
+
+  public static int switch_regex_copy_substring(string subject, SWIGTYPE_p_int ovector, int stringcount, int stringnumber, string buffer, int size) {
+    int ret = freeswitchPINVOKE.switch_regex_copy_substring(subject, SWIGTYPE_p_int.getCPtr(ovector), stringcount, stringnumber, buffer, size);
+    return ret;
+  }
+
+  public static void switch_regex_free(SWIGTYPE_p_void data) {
+    freeswitchPINVOKE.switch_regex_free(SWIGTYPE_p_void.getCPtr(data));
+  }
+
+  public static int switch_regex_perform(string field, string expression, SWIGTYPE_p_p_real_pcre new_re, SWIGTYPE_p_int ovector, uint olen) {
+    int ret = freeswitchPINVOKE.switch_regex_perform(field, expression, SWIGTYPE_p_p_real_pcre.getCPtr(new_re), SWIGTYPE_p_int.getCPtr(ovector), olen);
+    return ret;
+  }
+
+  public static void switch_perform_substitution(SWIGTYPE_p_real_pcre re, int match_count, string data, string field_data, string substituted, SWIGTYPE_p_switch_size_t len, SWIGTYPE_p_int ovector) {
+    freeswitchPINVOKE.switch_perform_substitution(SWIGTYPE_p_real_pcre.getCPtr(re), match_count, data, field_data, substituted, SWIGTYPE_p_switch_size_t.getCPtr(len), SWIGTYPE_p_int.getCPtr(ovector));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+  }
+
+  public static switch_status_t switch_regex_match(string target, string expression) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_regex_match(target, expression);
+    return ret;
+  }
+
+  public static switch_status_t switch_regex_match_partial(string target, string expression, SWIGTYPE_p_int partial_match) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_regex_match_partial(target, expression, SWIGTYPE_p_int.getCPtr(partial_match));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_media_bug_add(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t callback, SWIGTYPE_p_void user_data, SWIGTYPE_p_time_t stop_time, uint flags, SWIGTYPE_p_p_switch_media_bug new_bug) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_add(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data), SWIGTYPE_p_time_t.getCPtr(stop_time), flags, SWIGTYPE_p_p_switch_media_bug.getCPtr(new_bug));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-[System.Flags] public enum switch_asr_flag_enum_t {
-  SWITCH_ASR_FLAG_NONE = 0,
-  SWITCH_ASR_FLAG_DATA = (1 << 0),
-  SWITCH_ASR_FLAG_FREE_POOL = (1 << 1),
-  SWITCH_ASR_FLAG_CLOSED = (1 << 2),
-  SWITCH_ASR_FLAG_FIRE_EVENTS = (1 << 3),
-  SWITCH_ASR_FLAG_AUTO_RESUME = (1 << 4)
-}
+  public static SWIGTYPE_p_void switch_core_media_bug_get_user_data(SWIGTYPE_p_switch_media_bug bug) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_user_data(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_frame switch_core_media_bug_get_write_replace_frame(SWIGTYPE_p_switch_media_bug bug) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_write_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
+    switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_core_media_bug_set_write_replace_frame(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
+    freeswitchPINVOKE.switch_core_media_bug_set_write_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_frame switch_core_media_bug_get_read_replace_frame(SWIGTYPE_p_switch_media_bug bug) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_read_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
+    switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
+    return ret;
+  }
 
-public class switch_asr_handle : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static SWIGTYPE_p_switch_core_session switch_core_media_bug_get_session(SWIGTYPE_p_switch_media_bug bug) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_media_bug_get_session(SWIGTYPE_p_switch_media_bug.getCPtr(bug));
+    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
+    return ret;
+  }
 
-  internal switch_asr_handle(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static uint switch_core_media_bug_test_flag(SWIGTYPE_p_switch_media_bug bug, uint flag) {
+    uint ret = freeswitchPINVOKE.switch_core_media_bug_test_flag(SWIGTYPE_p_switch_media_bug.getCPtr(bug), flag);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_asr_handle obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_core_media_bug_set_read_replace_frame(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
+    freeswitchPINVOKE.switch_core_media_bug_set_read_replace_frame(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
   }
 
-  ~switch_asr_handle() {
-    Dispose();
+  public static switch_status_t switch_core_media_bug_remove(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_media_bug bug) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_remove(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_media_bug.getCPtr(bug));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_asr_handle(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_core_media_bug_close(SWIGTYPE_p_p_switch_media_bug bug) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_close(SWIGTYPE_p_p_switch_media_bug.getCPtr(bug));
+    return ret;
   }
 
-  public switch_asr_interface asr_interface {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_asr_interface_set(swigCPtr, switch_asr_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_asr_interface_get(swigCPtr);
-      switch_asr_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_asr_interface(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_media_bug_remove_all(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_remove_all(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_asr_handle_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_media_bug_read(SWIGTYPE_p_switch_media_bug bug, switch_frame frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_media_bug_read(SWIGTYPE_p_switch_media_bug.getCPtr(bug), switch_frame.getCPtr(frame));
+    return ret;
   }
 
-  public string name {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_asr_handle_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_port_allocator_new(ushort start, ushort end, uint flags, SWIGTYPE_p_p_switch_core_port_allocator new_allocator) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_new(start, end, flags, SWIGTYPE_p_p_switch_core_port_allocator.getCPtr(new_allocator));
+    return ret;
   }
 
-  public string codec {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_codec_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_asr_handle_codec_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_port_allocator_request_port(SWIGTYPE_p_switch_core_port_allocator alloc, SWIGTYPE_p_unsigned_short port_ptr) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_request_port(SWIGTYPE_p_switch_core_port_allocator.getCPtr(alloc), SWIGTYPE_p_unsigned_short.getCPtr(port_ptr));
+    return ret;
   }
 
-  public uint rate {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_rate_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_asr_handle_rate_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_port_allocator_free_port(SWIGTYPE_p_switch_core_port_allocator alloc, ushort port) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_port_allocator_free_port(SWIGTYPE_p_switch_core_port_allocator.getCPtr(alloc), port);
+    return ret;
   }
 
-  public string grammar {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_grammar_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_asr_handle_grammar_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_port_allocator_destroy(SWIGTYPE_p_p_switch_core_port_allocator alloc) {
+    freeswitchPINVOKE.switch_core_port_allocator_destroy(SWIGTYPE_p_p_switch_core_port_allocator.getCPtr(alloc));
   }
 
-  public string param {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_param_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_asr_handle_param_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_init(uint flags, switch_bool_t console, ref string err) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_init(flags, (int)console, ref err);
+    return ret;
   }
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_init_and_modload(uint flags, switch_bool_t console, ref string err) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_init_and_modload(flags, (int)console, ref err);
+    return ret;
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_asr_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_handle_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_core_session_limit(uint new_limit) {
+    uint ret = freeswitchPINVOKE.switch_core_session_limit(new_limit);
+    return ret;
   }
 
-  public switch_asr_handle() : this(freeswitchPINVOKE.new_switch_asr_handle(), true) {
+  public static uint switch_core_sessions_per_second(uint new_limit) {
+    uint ret = freeswitchPINVOKE.switch_core_sessions_per_second(new_limit);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_core_destroy() {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_destroy();
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_session_signal_lock(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_signal_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_session_signal_unlock(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_signal_unlock(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_core_session_read_lock(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
 
-public class switch_asr_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_core_session_write_lock(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_core_session_write_lock(SWIGTYPE_p_switch_core_session.getCPtr(session));
+  }
 
-  internal switch_asr_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_core_session_rwunlock(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_core_session_rwunlock(SWIGTYPE_p_switch_core_session.getCPtr(session));
   }
 
-  internal static HandleRef getCPtr(switch_asr_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static int switch_core_add_state_handler(switch_state_handler_table state_handler) {
+    int ret = freeswitchPINVOKE.switch_core_add_state_handler(switch_state_handler_table.getCPtr(state_handler));
+    return ret;
   }
 
-  ~switch_asr_interface() {
-    Dispose();
+  public static void switch_core_remove_state_handler(switch_state_handler_table state_handler) {
+    freeswitchPINVOKE.switch_core_remove_state_handler(switch_state_handler_table.getCPtr(state_handler));
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_asr_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_state_handler_table switch_core_get_state_handler(int index) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_get_state_handler(index);
+    switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
+    return ret;
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_asr_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_memory_pool_tag(SWIGTYPE_p_apr_pool_t pool, string tag) {
+    freeswitchPINVOKE.switch_core_memory_pool_tag(SWIGTYPE_p_apr_pool_t.getCPtr(pool), tag);
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t asr_open {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_open_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_perform_new_memory_pool(SWIGTYPE_p_p_apr_pool_t pool, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_new_memory_pool(SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), file, func, line);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t asr_load_grammar {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_load_grammar_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_load_grammar_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_perform_destroy_memory_pool(SWIGTYPE_p_p_apr_pool_t pool, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_destroy_memory_pool(SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), file, func, line);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t asr_unload_grammar {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_unload_grammar_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_unload_grammar_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static void switch_core_session_run(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_core_session_run(SWIGTYPE_p_switch_core_session.getCPtr(session));
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t asr_close {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_close_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_core_session_running(SWIGTYPE_p_switch_core_session session) {
+    uint ret = freeswitchPINVOKE.switch_core_session_running(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t asr_feed {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_feed_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_feed_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static SWIGTYPE_p_void switch_core_perform_permanent_alloc(SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_permanent_alloc(SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t asr_resume {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_resume_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_resume_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static SWIGTYPE_p_void switch_core_perform_alloc(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_alloc(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t asr_pause {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_pause_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_pause_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static SWIGTYPE_p_void switch_core_perform_session_alloc(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_size_t memory, string file, string func, int line) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_perform_session_alloc(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_size_t.getCPtr(memory), file, func, line);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t asr_check_results {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_check_results_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_check_results_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_core_perform_permanent_strdup(string todup, string file, string func, int line) {
+    string ret = freeswitchPINVOKE.switch_core_perform_permanent_strdup(todup, file, func, line);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t asr_get_results {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_asr_get_results_set(swigCPtr, SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_asr_get_results_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_core_perform_session_strdup(SWIGTYPE_p_switch_core_session session, string todup, string file, string func, int line) {
+    string ret = freeswitchPINVOKE.switch_core_perform_session_strdup(SWIGTYPE_p_switch_core_session.getCPtr(session), todup, file, func, line);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_core_perform_strdup(SWIGTYPE_p_apr_pool_t pool, string todup, string file, string func, int line) {
+    string ret = freeswitchPINVOKE.switch_core_perform_strdup(SWIGTYPE_p_apr_pool_t.getCPtr(pool), todup, file, func, line);
+    return ret;
   }
 
-  public switch_asr_interface next {
-    set {
-      freeswitchPINVOKE.switch_asr_interface_next_set(swigCPtr, switch_asr_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_asr_interface_next_get(swigCPtr);
-      switch_asr_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_asr_interface(cPtr, false);
-      return ret;
-    } 
+  public static string switch_core_session_sprintf(SWIGTYPE_p_switch_core_session session, string fmt) {
+    string ret = freeswitchPINVOKE.switch_core_session_sprintf(SWIGTYPE_p_switch_core_session.getCPtr(session), fmt);
+    return ret;
   }
 
-  public switch_asr_interface() : this(freeswitchPINVOKE.new_switch_asr_interface(), true) {
+  public static string switch_core_sprintf(SWIGTYPE_p_apr_pool_t pool, string fmt) {
+    string ret = freeswitchPINVOKE.switch_core_sprintf(SWIGTYPE_p_apr_pool_t.getCPtr(pool), fmt);
+    return ret;
   }
 
-}
+  public static SWIGTYPE_p_apr_pool_t switch_core_session_get_pool(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_pool(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static SWIGTYPE_p_switch_core_session switch_core_session_request(switch_endpoint_interface endpoint_interface, SWIGTYPE_p_p_apr_pool_t pool) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_request(switch_endpoint_interface.getCPtr(endpoint_interface), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool));
+    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_core_session_perform_destroy(SWIGTYPE_p_p_switch_core_session session, string file, string func, int line) {
+    freeswitchPINVOKE.switch_core_session_perform_destroy(SWIGTYPE_p_p_switch_core_session.getCPtr(session), file, func, line);
+  }
 
-public enum switch_audio_col_t {
-  SWITCH_AUDIO_COL_STR_TITLE = 0x01,
-  SWITCH_AUDIO_COL_STR_COPYRIGHT = 0x02,
-  SWITCH_AUDIO_COL_STR_SOFTWARE = 0x03,
-  SWITCH_AUDIO_COL_STR_ARTIST = 0x04,
-  SWITCH_AUDIO_COL_STR_COMMENT = 0x05,
-  SWITCH_AUDIO_COL_STR_DATE = 0x06
-}
+  public static uint switch_core_session_count() {
+    uint ret = freeswitchPINVOKE.switch_core_session_count();
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static SWIGTYPE_p_switch_size_t switch_core_session_id() {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_id(), true);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static SWIGTYPE_p_switch_core_session switch_core_session_request_by_name(string endpoint_name, SWIGTYPE_p_p_apr_pool_t pool) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_request_by_name(endpoint_name, SWIGTYPE_p_p_apr_pool_t.getCPtr(pool));
+    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_core_session_thread_launch(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_thread_launch(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
 
-public class switch_audio_resampler_t : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static SWIGTYPE_p_switch_channel switch_core_session_get_channel(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_channel(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    SWIGTYPE_p_switch_channel ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_channel(cPtr, false);
+    return ret;
+  }
 
-  internal switch_audio_resampler_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_core_session_signal_state_change(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_core_session_signal_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session));
   }
 
-  internal static HandleRef getCPtr(switch_audio_resampler_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static string switch_core_session_get_uuid(SWIGTYPE_p_switch_core_session session) {
+    string ret = freeswitchPINVOKE.switch_core_session_get_uuid(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  ~switch_audio_resampler_t() {
-    Dispose();
+  public static string switch_core_get_uuid() {
+    string ret = freeswitchPINVOKE.switch_core_get_uuid();
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_audio_resampler_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static SWIGTYPE_p_switch_core_session switch_core_session_locate(string uuid_str) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_locate(uuid_str);
+    SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
+    return ret;
   }
 
-  public SWIGTYPE_p_void resampler {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_resampler_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_resampler_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static string switch_core_get_variable(string varname) {
+    string ret = freeswitchPINVOKE.switch_core_get_variable(varname);
+    return ret;
   }
 
-  public int from_rate {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_from_rate_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_audio_resampler_t_from_rate_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_set_variable(string varname, string value) {
+    freeswitchPINVOKE.switch_core_set_variable(varname, value);
   }
 
-  public int to_rate {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_to_rate_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_audio_resampler_t_to_rate_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_dump_variables(switch_stream_handle stream) {
+    freeswitchPINVOKE.switch_core_dump_variables(switch_stream_handle.getCPtr(stream));
   }
 
-  public double factor {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_factor_set(swigCPtr, value);
-    } 
-    get {
-      double ret = freeswitchPINVOKE.switch_audio_resampler_t_factor_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_session_hupall(switch_call_cause_t cause) {
+    freeswitchPINVOKE.switch_core_session_hupall((int)cause);
   }
 
-  public double rfactor {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_rfactor_set(swigCPtr, value);
-    } 
-    get {
-      double ret = freeswitchPINVOKE.switch_audio_resampler_t_rfactor_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_session_hupall_matching_var(string var_name, string var_val, switch_call_cause_t cause) {
+    freeswitchPINVOKE.switch_core_session_hupall_matching_var(var_name, var_val, (int)cause);
   }
 
-  public SWIGTYPE_p_float from {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_from_set(swigCPtr, SWIGTYPE_p_float.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_from_get(swigCPtr);
-      SWIGTYPE_p_float ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_float(cPtr, false);
-      return ret;
-    } 
+  public static void switch_core_session_hupall_endpoint(switch_endpoint_interface endpoint_interface, switch_call_cause_t cause) {
+    freeswitchPINVOKE.switch_core_session_hupall_endpoint(switch_endpoint_interface.getCPtr(endpoint_interface), (int)cause);
   }
 
-  public int from_len {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_from_len_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_audio_resampler_t_from_len_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_message_send(string uuid_str, switch_core_session_message message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_message_send(uuid_str, switch_core_session_message.getCPtr(message));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t from_size {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_from_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_audio_resampler_t_from_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_queue_message(SWIGTYPE_p_switch_core_session session, switch_core_session_message message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_message(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_session_message.getCPtr(message));
+    return ret;
   }
 
-  public SWIGTYPE_p_float to {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_to_set(swigCPtr, SWIGTYPE_p_float.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_audio_resampler_t_to_get(swigCPtr);
-      SWIGTYPE_p_float ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_float(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_pass_indication(SWIGTYPE_p_switch_core_session session, switch_core_session_message_types_t indication) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_pass_indication(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)indication);
+    return ret;
   }
 
-  public uint to_len {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_to_len_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_audio_resampler_t_to_len_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_queue_indication(SWIGTYPE_p_switch_core_session session, switch_core_session_message_types_t indication) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_indication(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)indication);
+    return ret;
   }
 
-  public uint to_size {
-    set {
-      freeswitchPINVOKE.switch_audio_resampler_t_to_size_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_audio_resampler_t_to_size_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_dequeue_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_core_session_message message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_core_session_message.getCPtr(message));
+    return ret;
   }
 
-  public switch_audio_resampler_t() : this(freeswitchPINVOKE.new_switch_audio_resampler_t(), true) {
+  public static switch_status_t switch_core_session_flush_message(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_flush_message(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-}
+  public static switch_status_t switch_core_session_event_send(string uuid_str, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_event_send(uuid_str, SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_app_log switch_core_session_get_app_log(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_app_log(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_app_log ret = (cPtr == IntPtr.Zero) ? null : new switch_app_log(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_session_exec(SWIGTYPE_p_switch_core_session session, switch_application_interface application_interface, string arg) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_exec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_application_interface.getCPtr(application_interface), arg);
+    return ret;
+  }
 
-[System.Flags] public enum switch_bind_flag_enum_t {
-  SBF_DIAL_ALEG = (1 << 0),
-  SBF_EXEC_ALEG = (1 << 1),
-  SBF_DIAL_BLEG = (1 << 2),
-  SBF_EXEC_BLEG = (1 << 3),
-  SBF_EXEC_OPPOSITE = (1 << 4),
-  SBF_EXEC_SAME = (1 << 5)
-}
+  public static switch_status_t switch_core_session_execute_application(SWIGTYPE_p_switch_core_session session, string app, string arg) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_execute_application(SWIGTYPE_p_switch_core_session.getCPtr(session), app, arg);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_session_execute_exten(SWIGTYPE_p_switch_core_session session, string exten, string dialplan, string context) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_execute_exten(SWIGTYPE_p_switch_core_session.getCPtr(session), exten, dialplan, context);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_session_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
+  }
 
-public enum switch_bitpack_mode_t {
-  SWITCH_BITPACK_MODE_RFC3551,
-  SWITCH_BITPACK_MODE_AAL2
-}
+  public static SWIGTYPE_p_void switch_core_session_get_private(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_private(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_session_set_private(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void private_info) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_private(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(private_info));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static int switch_core_session_add_stream(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void private_info) {
+    int ret = freeswitchPINVOKE.switch_core_session_add_stream(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(private_info));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static SWIGTYPE_p_void switch_core_session_get_stream(SWIGTYPE_p_switch_core_session session, int index) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_stream(SWIGTYPE_p_switch_core_session.getCPtr(session), index);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
+  }
 
-public class switch_bitpack_t : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static int switch_core_session_get_stream_count(SWIGTYPE_p_switch_core_session session) {
+    int ret = freeswitchPINVOKE.switch_core_session_get_stream_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
 
-  internal switch_bitpack_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_core_session_launch_thread(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void func, SWIGTYPE_p_void obj) {
+    freeswitchPINVOKE.switch_core_session_launch_thread(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void.getCPtr(func), SWIGTYPE_p_void.getCPtr(obj));
   }
 
-  internal static HandleRef getCPtr(switch_bitpack_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_core_thread_session_end(switch_core_thread_session thread_session) {
+    freeswitchPINVOKE.switch_core_thread_session_end(switch_core_thread_session.getCPtr(thread_session));
   }
 
-  ~switch_bitpack_t() {
-    Dispose();
+  public static void switch_core_service_session(SWIGTYPE_p_switch_core_session session, switch_core_thread_session thread_session, int stream_id) {
+    freeswitchPINVOKE.switch_core_service_session(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_thread_session.getCPtr(thread_session), stream_id);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_bitpack_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_call_cause_t switch_core_session_outgoing_channel(SWIGTYPE_p_switch_core_session session, switch_event var_event, string endpoint_name, switch_caller_profile caller_profile, SWIGTYPE_p_p_switch_core_session new_session, SWIGTYPE_p_p_apr_pool_t pool, uint flags) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_core_session_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_event.getCPtr(var_event), endpoint_name, switch_caller_profile.getCPtr(caller_profile), SWIGTYPE_p_p_switch_core_session.getCPtr(new_session), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), flags);
+    return ret;
   }
 
-  public SWIGTYPE_p_unsigned_char buf {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_buf_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_bitpack_t_buf_get(swigCPtr);
-      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-      return ret;
-    } 
+  public static switch_call_cause_t switch_core_session_resurrect_channel(string endpoint_name, SWIGTYPE_p_p_switch_core_session new_session, SWIGTYPE_p_p_apr_pool_t pool, SWIGTYPE_p_void data) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_core_session_resurrect_channel(endpoint_name, SWIGTYPE_p_p_switch_core_session.getCPtr(new_session), SWIGTYPE_p_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_void.getCPtr(data));
+    return ret;
   }
 
-  public uint buflen {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_buflen_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_bitpack_t_buflen_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_receive_message(SWIGTYPE_p_switch_core_session session, switch_core_session_message message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_core_session_message.getCPtr(message));
+    return ret;
   }
 
-  public SWIGTYPE_p_unsigned_char cur {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_cur_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_bitpack_t_cur_get(swigCPtr);
-      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_queue_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
   }
 
-  public uint bytes {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_bytes_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_bitpack_t_bytes_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_core_session_event_count(SWIGTYPE_p_switch_core_session session) {
+    uint ret = freeswitchPINVOKE.switch_core_session_event_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_session_dequeue_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
   }
 
-  public uint bits_tot {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_bits_tot_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_bitpack_t_bits_tot_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_queue_private_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_queue_private_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
   }
 
-  public byte bits_cur {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_bits_cur_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_bits_cur_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_core_session_private_event_count(SWIGTYPE_p_switch_core_session session) {
+    uint ret = freeswitchPINVOKE.switch_core_session_private_event_count(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public byte bits_rem {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_bits_rem_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_bits_rem_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_dequeue_private_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_dequeue_private_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
   }
 
-  public byte frame_bits {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_frame_bits_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_frame_bits_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_core_session_flush_private_events(SWIGTYPE_p_switch_core_session session) {
+    uint ret = freeswitchPINVOKE.switch_core_session_flush_private_events(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public byte shiftby {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_shiftby_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_shiftby_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_frame frame, uint flags, int stream_id) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_frame.getCPtr(frame), flags, stream_id);
+    return ret;
   }
 
-  public byte this_byte {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_this_byte_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_this_byte_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_read_video_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_frame frame, uint flags, int stream_id) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_read_video_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_frame.getCPtr(frame), flags, stream_id);
+    return ret;
   }
 
-  public byte under {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_under_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_under_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_write_video_frame(SWIGTYPE_p_switch_core_session session, switch_frame frame, uint flags, int stream_id) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_write_video_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_frame.getCPtr(frame), flags, stream_id);
+    return ret;
   }
 
-  public byte over {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_over_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_bitpack_t_over_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_session_reset(SWIGTYPE_p_switch_core_session session, switch_bool_t flush_dtmf) {
+    freeswitchPINVOKE.switch_core_session_reset(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)flush_dtmf);
   }
 
-  public switch_bitpack_mode_t mode {
-    set {
-      freeswitchPINVOKE.switch_bitpack_t_mode_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_bitpack_mode_t ret = (switch_bitpack_mode_t)freeswitchPINVOKE.switch_bitpack_t_mode_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_write_frame(SWIGTYPE_p_switch_core_session session, switch_frame frame, uint flags, int stream_id) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_frame.getCPtr(frame), flags, stream_id);
+    return ret;
   }
 
-  public switch_bitpack_t() : this(freeswitchPINVOKE.new_switch_bitpack_t(), true) {
+  public static switch_status_t switch_core_session_perform_kill_channel(SWIGTYPE_p_switch_core_session session, string file, string func, int line, switch_signal_t sig) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_perform_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), file, func, line, (int)sig);
+    return ret;
   }
 
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_session_send_dtmf(SWIGTYPE_p_switch_core_session session, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_session_send_dtmf_string(SWIGTYPE_p_switch_core_session session, string dtmf_string) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_send_dtmf_string(SWIGTYPE_p_switch_core_session.getCPtr(session), dtmf_string);
+    return ret;
+  }
 
-public enum switch_bool_t {
-  SWITCH_FALSE = 0,
-  SWITCH_TRUE = 1
-}
+  public static switch_status_t switch_core_session_recv_dtmf(SWIGTYPE_p_switch_core_session session, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_hash_init(SWIGTYPE_p_p_switch_hash hash, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_init(SWIGTYPE_p_p_switch_hash.getCPtr(hash), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_hash_destroy(SWIGTYPE_p_p_switch_hash hash) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_destroy(SWIGTYPE_p_p_switch_hash.getCPtr(hash));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_core_hash_insert(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_void data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_insert(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_void.getCPtr(data));
+    return ret;
+  }
 
-public class switch_caller_application : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_core_hash_insert_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_void data, SWIGTYPE_p_switch_mutex_t mutex) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_insert_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
+    return ret;
+  }
 
-  internal switch_caller_application(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_core_hash_delete(SWIGTYPE_p_switch_hash hash, string key) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_delete(SWIGTYPE_p_switch_hash.getCPtr(hash), key);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_caller_application obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_core_hash_delete_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_switch_mutex_t mutex) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_hash_delete_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
+    return ret;
   }
 
-  ~switch_caller_application() {
-    Dispose();
+  public static SWIGTYPE_p_void switch_core_hash_find(SWIGTYPE_p_switch_hash hash, string key) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_hash_find(SWIGTYPE_p_switch_hash.getCPtr(hash), key);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_caller_application(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static SWIGTYPE_p_void switch_core_hash_find_locked(SWIGTYPE_p_switch_hash hash, string key, SWIGTYPE_p_switch_mutex_t mutex) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_hash_find_locked(SWIGTYPE_p_switch_hash.getCPtr(hash), key, SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
   }
 
-  public string application_name {
-    set {
-      freeswitchPINVOKE.switch_caller_application_application_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_application_application_name_get(swigCPtr);
-      return ret;
-    } 
+  public static SWIGTYPE_p_HashElem switch_hash_first(string depricate_me, SWIGTYPE_p_switch_hash hash) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_hash_first(depricate_me, SWIGTYPE_p_switch_hash.getCPtr(hash));
+    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
+    return ret;
   }
 
-  public string application_data {
-    set {
-      freeswitchPINVOKE.switch_caller_application_application_data_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_application_application_data_get(swigCPtr);
-      return ret;
-    } 
+  public static SWIGTYPE_p_HashElem switch_hash_next(SWIGTYPE_p_HashElem hi) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_hash_next(SWIGTYPE_p_HashElem.getCPtr(hi));
+    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void application_function {
-    set {
-      freeswitchPINVOKE.switch_caller_application_application_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_application_application_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(cPtr, false);
-      return ret;
-    } 
+  public static void switch_hash_this(SWIGTYPE_p_HashElem hi, SWIGTYPE_p_p_void key, SWIGTYPE_p_switch_ssize_t klen, SWIGTYPE_p_p_void val) {
+    freeswitchPINVOKE.switch_hash_this(SWIGTYPE_p_HashElem.getCPtr(hi), SWIGTYPE_p_p_void.getCPtr(key), SWIGTYPE_p_switch_ssize_t.getCPtr(klen), SWIGTYPE_p_p_void.getCPtr(val));
   }
 
-  public switch_caller_application next {
-    set {
-      freeswitchPINVOKE.switch_caller_application_next_set(swigCPtr, switch_caller_application.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_application_next_get(swigCPtr);
-      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_timer_init(switch_timer timer, string timer_name, int interval, int samples, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_init(switch_timer.getCPtr(timer), timer_name, interval, samples, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public switch_caller_application() : this(freeswitchPINVOKE.new_switch_caller_application(), true) {
+  public static switch_status_t switch_core_timer_next(switch_timer timer) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_next(switch_timer.getCPtr(timer));
+    return ret;
   }
 
-}
+  public static switch_status_t switch_core_timer_step(switch_timer timer) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_step(switch_timer.getCPtr(timer));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_timer_sync(switch_timer timer) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_sync(switch_timer.getCPtr(timer));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_timer_check(switch_timer timer, switch_bool_t step) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_check(switch_timer.getCPtr(timer), (int)step);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_core_timer_destroy(switch_timer timer) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_timer_destroy(switch_timer.getCPtr(timer));
+    return ret;
+  }
 
-public class switch_caller_extension : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_core_codec_init(switch_codec codec, string codec_name, string fmtp, uint rate, int ms, int channels, uint flags, switch_codec_settings codec_settings, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_init(switch_codec.getCPtr(codec), codec_name, fmtp, rate, ms, channels, flags, switch_codec_settings.getCPtr(codec_settings), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
 
-  internal switch_caller_extension(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_core_codec_copy(switch_codec codec, switch_codec new_codec, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_copy(switch_codec.getCPtr(codec), switch_codec.getCPtr(new_codec), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_caller_extension obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_core_codec_encode(switch_codec codec, switch_codec other_codec, SWIGTYPE_p_void decoded_data, uint decoded_data_len, uint decoded_rate, SWIGTYPE_p_void encoded_data, SWIGTYPE_p_unsigned_long encoded_data_len, SWIGTYPE_p_unsigned_long encoded_rate, SWIGTYPE_p_unsigned_int flag) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_encode(switch_codec.getCPtr(codec), switch_codec.getCPtr(other_codec), SWIGTYPE_p_void.getCPtr(decoded_data), decoded_data_len, decoded_rate, SWIGTYPE_p_void.getCPtr(encoded_data), SWIGTYPE_p_unsigned_long.getCPtr(encoded_data_len), SWIGTYPE_p_unsigned_long.getCPtr(encoded_rate), SWIGTYPE_p_unsigned_int.getCPtr(flag));
+    return ret;
   }
 
-  ~switch_caller_extension() {
-    Dispose();
+  public static switch_status_t switch_core_codec_decode(switch_codec codec, switch_codec other_codec, SWIGTYPE_p_void encoded_data, uint encoded_data_len, uint encoded_rate, SWIGTYPE_p_void decoded_data, SWIGTYPE_p_unsigned_long decoded_data_len, SWIGTYPE_p_unsigned_long decoded_rate, SWIGTYPE_p_unsigned_int flag) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_decode(switch_codec.getCPtr(codec), switch_codec.getCPtr(other_codec), SWIGTYPE_p_void.getCPtr(encoded_data), encoded_data_len, encoded_rate, SWIGTYPE_p_void.getCPtr(decoded_data), SWIGTYPE_p_unsigned_long.getCPtr(decoded_data_len), SWIGTYPE_p_unsigned_long.getCPtr(decoded_rate), SWIGTYPE_p_unsigned_int.getCPtr(flag));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_caller_extension(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_core_codec_destroy(switch_codec codec) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_codec_destroy(switch_codec.getCPtr(codec));
+    return ret;
   }
 
-  public string extension_name {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_extension_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_extension_extension_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_set_read_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
+    return ret;
   }
 
-  public string extension_number {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_extension_number_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_extension_extension_number_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_session_unset_read_codec(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_core_session_unset_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
   }
 
-  public switch_caller_application current_application {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_current_application_set(swigCPtr, switch_caller_application.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_current_application_get(swigCPtr);
-      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
-      return ret;
-    } 
+  public static switch_codec switch_core_session_get_read_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
   }
 
-  public switch_caller_application last_application {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_last_application_set(swigCPtr, switch_caller_application.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_last_application_get(swigCPtr);
-      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
-      return ret;
-    } 
+  public static switch_codec switch_core_session_get_effective_read_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_effective_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
   }
 
-  public switch_caller_application applications {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_applications_set(swigCPtr, switch_caller_application.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_applications_get(swigCPtr);
-      switch_caller_application ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_application(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_session_set_write_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
+    return ret;
   }
 
-  public switch_caller_profile children {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_children_set(swigCPtr, switch_caller_profile.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_children_get(swigCPtr);
-      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-      return ret;
-    } 
+  public static switch_codec switch_core_session_get_write_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
   }
 
-  public switch_caller_extension next {
-    set {
-      freeswitchPINVOKE.switch_caller_extension_next_set(swigCPtr, switch_caller_extension.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_next_get(swigCPtr);
-      switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
-      return ret;
-    } 
+  public static switch_codec switch_core_session_get_effective_write_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_effective_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
   }
 
-  public switch_caller_extension() : this(freeswitchPINVOKE.new_switch_caller_extension(), true) {
+  public static switch_status_t switch_core_session_set_video_read_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_video_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
+    return ret;
   }
 
-}
+  public static switch_codec switch_core_session_get_video_read_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_video_read_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_session_set_video_write_codec(SWIGTYPE_p_switch_core_session session, switch_codec codec) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_session_set_video_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_codec switch_core_session_get_video_write_codec(SWIGTYPE_p_switch_core_session session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_session_get_video_write_codec(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static SWIGTYPE_p_sqlite3 switch_core_db_open_file(string filename) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_db_open_file(filename);
+    SWIGTYPE_p_sqlite3 ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_sqlite3(cPtr, false);
+    return ret;
+  }
 
-public class switch_caller_profile : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_core_db_persistant_execute(SWIGTYPE_p_sqlite3 db, string sql, uint retries) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_db_persistant_execute(SWIGTYPE_p_sqlite3.getCPtr(db), sql, retries);
+    return ret;
+  }
 
-  internal switch_caller_profile(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_core_db_test_reactive(SWIGTYPE_p_sqlite3 db, string test_sql, string drop_sql, string reactive_sql) {
+    freeswitchPINVOKE.switch_core_db_test_reactive(SWIGTYPE_p_sqlite3.getCPtr(db), test_sql, drop_sql, reactive_sql);
   }
 
-  internal static HandleRef getCPtr(switch_caller_profile obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_core_perform_file_open(string file, string func, int line, switch_file_handle fh, string file_path, byte channels, uint rate, uint flags, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_perform_file_open(file, func, line, switch_file_handle.getCPtr(fh), file_path, channels, rate, flags, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  ~switch_caller_profile() {
-    Dispose();
+  public static switch_status_t switch_core_file_read(switch_file_handle fh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_read(switch_file_handle.getCPtr(fh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(len));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_caller_profile(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_core_file_write(switch_file_handle fh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_write(switch_file_handle.getCPtr(fh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(len));
+    return ret;
   }
 
-  public string username {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_username_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_username_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_file_seek(switch_file_handle fh, SWIGTYPE_p_unsigned_int cur_pos, long samples, int whence) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_seek(switch_file_handle.getCPtr(fh), SWIGTYPE_p_unsigned_int.getCPtr(cur_pos), samples, whence);
+    return ret;
   }
 
-  public string dialplan {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_dialplan_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_dialplan_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_file_set_string(switch_file_handle fh, switch_audio_col_t col, string arg2) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_set_string(switch_file_handle.getCPtr(fh), (int)col, arg2);
+    return ret;
   }
 
-  public string caller_id_name {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_caller_id_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_caller_id_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_file_get_string(switch_file_handle fh, switch_audio_col_t col, ref string arg2) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_get_string(switch_file_handle.getCPtr(fh), (int)col, ref arg2);
+    return ret;
   }
 
-  public string caller_id_number {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_caller_id_number_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_caller_id_number_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_file_close(switch_file_handle fh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_file_close(switch_file_handle.getCPtr(fh));
+    return ret;
   }
 
-  public byte caller_ton {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_caller_ton_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_caller_ton_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_speech_open(switch_speech_handle sh, string module_name, string voice_name, uint rate, uint interval, SWIGTYPE_p_unsigned_long flags, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_open(switch_speech_handle.getCPtr(sh), module_name, voice_name, rate, interval, SWIGTYPE_p_unsigned_long.getCPtr(flags), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_speech_feed_tts(switch_speech_handle sh, string text, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_feed_tts(switch_speech_handle.getCPtr(sh), text, SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public byte caller_numplan {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_caller_numplan_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_caller_numplan_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_speech_flush_tts(switch_speech_handle sh) {
+    freeswitchPINVOKE.switch_core_speech_flush_tts(switch_speech_handle.getCPtr(sh));
   }
 
-  public string network_addr {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_network_addr_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_network_addr_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_speech_text_param_tts(switch_speech_handle sh, string param, string val) {
+    freeswitchPINVOKE.switch_core_speech_text_param_tts(switch_speech_handle.getCPtr(sh), param, val);
   }
 
-  public string ani {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_ani_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_ani_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_speech_numeric_param_tts(switch_speech_handle sh, string param, int val) {
+    freeswitchPINVOKE.switch_core_speech_numeric_param_tts(switch_speech_handle.getCPtr(sh), param, val);
   }
 
-  public byte ani_ton {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_ani_ton_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_ani_ton_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_core_speech_float_param_tts(switch_speech_handle sh, string param, double val) {
+    freeswitchPINVOKE.switch_core_speech_float_param_tts(switch_speech_handle.getCPtr(sh), param, val);
   }
 
-  public byte ani_numplan {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_ani_numplan_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_ani_numplan_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_speech_read_tts(switch_speech_handle sh, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen, SWIGTYPE_p_unsigned_long rate, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_read_tts(switch_speech_handle.getCPtr(sh), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen), SWIGTYPE_p_unsigned_long.getCPtr(rate), SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public string aniii {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_aniii_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_aniii_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_speech_close(switch_speech_handle sh, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_speech_close(switch_speech_handle.getCPtr(sh), SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public string rdnis {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_rdnis_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_rdnis_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_open(switch_asr_handle ah, string module_name, string codec, int rate, string dest, SWIGTYPE_p_unsigned_long flags, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_open(switch_asr_handle.getCPtr(ah), module_name, codec, rate, dest, SWIGTYPE_p_unsigned_long.getCPtr(flags), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public byte rdnis_ton {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_rdnis_ton_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_rdnis_ton_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_close(switch_asr_handle ah, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_close(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public byte rdnis_numplan {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_rdnis_numplan_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_rdnis_numplan_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_feed(switch_asr_handle ah, SWIGTYPE_p_void data, uint len, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_feed(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_void.getCPtr(data), len, SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public string destination_number {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_destination_number_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_destination_number_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_check_results(switch_asr_handle ah, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_check_results(switch_asr_handle.getCPtr(ah), SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public byte destination_number_ton {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_destination_number_ton_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_destination_number_ton_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_get_results(switch_asr_handle ah, ref string xmlstr, SWIGTYPE_p_unsigned_long flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_get_results(switch_asr_handle.getCPtr(ah), ref xmlstr, SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  public byte destination_number_numplan {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_destination_number_numplan_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_caller_profile_destination_number_numplan_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_load_grammar(switch_asr_handle ah, string grammar, string path) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_load_grammar(switch_asr_handle.getCPtr(ah), grammar, path);
+    return ret;
   }
 
-  public string source {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_source_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_source_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_unload_grammar(switch_asr_handle ah, string grammar) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_unload_grammar(switch_asr_handle.getCPtr(ah), grammar);
+    return ret;
   }
 
-  public string chan_name {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_chan_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_chan_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_pause(switch_asr_handle ah) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_pause(switch_asr_handle.getCPtr(ah));
+    return ret;
   }
 
-  public string uuid {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_uuid_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_uuid_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_asr_resume(switch_asr_handle ah) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_asr_resume(switch_asr_handle.getCPtr(ah));
+    return ret;
   }
 
-  public string context {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_context_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_context_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_directory_open(switch_directory_handle dh, string module_name, string source, string dsn, string passwd, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_open(switch_directory_handle.getCPtr(dh), module_name, source, dsn, passwd, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public string profile_index {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_profile_index_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_caller_profile_profile_index_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_directory_query(switch_directory_handle dh, string arg1, string query) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_query(switch_directory_handle.getCPtr(dh), arg1, query);
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_caller_profile_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_directory_next(switch_directory_handle dh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_next(switch_directory_handle.getCPtr(dh));
+    return ret;
   }
 
-  public switch_caller_profile originator_caller_profile {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_originator_caller_profile_set(swigCPtr, switch_caller_profile.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_originator_caller_profile_get(swigCPtr);
-      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_directory_next_pair(switch_directory_handle dh, ref string var, ref string val) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_next_pair(switch_directory_handle.getCPtr(dh), ref var, ref val);
+    return ret;
   }
 
-  public switch_caller_profile originatee_caller_profile {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_originatee_caller_profile_set(swigCPtr, switch_caller_profile.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_originatee_caller_profile_get(swigCPtr);
-      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_directory_close(switch_directory_handle dh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_directory_close(switch_directory_handle.getCPtr(dh));
+    return ret;
   }
 
-  public switch_channel_timetable times {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_times_set(swigCPtr, switch_channel_timetable.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_times_get(swigCPtr);
-      switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
-      return ret;
-    } 
+  public static SWIGTYPE_p_FILE switch_core_data_channel(switch_text_channel_t channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_data_channel((int)channel);
+    SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
+    return ret;
   }
 
-  public switch_caller_extension caller_extension {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_caller_extension_set(swigCPtr, switch_caller_extension.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_caller_extension_get(swigCPtr);
-      switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
-      return ret;
-    } 
+  public static switch_bool_t switch_core_ready() {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_core_ready();
+    return ret;
   }
 
-  public SWIGTYPE_p_apr_pool_t pool {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_core_flags() {
+    uint ret = freeswitchPINVOKE.switch_core_flags();
+    return ret;
   }
 
-  public switch_caller_profile next {
-    set {
-      freeswitchPINVOKE.switch_caller_profile_next_set(swigCPtr, switch_caller_profile.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_next_get(swigCPtr);
-      switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_management_exec(string relative_oid, switch_management_action_t action, string data, SWIGTYPE_p_switch_size_t datalen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_management_exec(relative_oid, (int)action, data, SWIGTYPE_p_switch_size_t.getCPtr(datalen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public switch_caller_profile() : this(freeswitchPINVOKE.new_switch_caller_profile(), true) {
+  public static int set_high_priority() {
+    int ret = freeswitchPINVOKE.set_high_priority();
+    return ret;
   }
 
-}
+  public static int change_user_group(string user, string group) {
+    int ret = freeswitchPINVOKE.change_user_group(user, group);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_core_runtime_loop(int bg) {
+    freeswitchPINVOKE.switch_core_runtime_loop(bg);
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_core_set_console(string console) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_set_console(console);
+    return ret;
+  }
 
-[System.Flags] public enum switch_caller_profile_flag_enum_t {
-  SWITCH_CPF_SCREEN = (1 << 0),
-  SWITCH_CPF_HIDE_NAME = (1 << 1),
-  SWITCH_CPF_HIDE_NUMBER = (1 << 2)
-}
+  public static void switch_core_measure_time(SWIGTYPE_p_switch_time_t total_ms, switch_core_time_duration duration) {
+    freeswitchPINVOKE.switch_core_measure_time(SWIGTYPE_p_switch_time_t.getCPtr(total_ms), switch_core_time_duration.getCPtr(duration));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static SWIGTYPE_p_switch_time_t switch_core_uptime() {
+    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_core_uptime(), true);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static int switch_core_session_ctl(switch_session_ctl_t cmd, SWIGTYPE_p_int val) {
+    int ret = freeswitchPINVOKE.switch_core_session_ctl((int)cmd, SWIGTYPE_p_int.getCPtr(val));
+    return ret;
+  }
 
-public enum switch_call_cause_t {
-  SWITCH_CAUSE_NONE = 0,
-  SWITCH_CAUSE_UNALLOCATED_NUMBER = 1,
-  SWITCH_CAUSE_NO_ROUTE_TRANSIT_NET = 2,
-  SWITCH_CAUSE_NO_ROUTE_DESTINATION = 3,
-  SWITCH_CAUSE_CHANNEL_UNACCEPTABLE = 6,
-  SWITCH_CAUSE_CALL_AWARDED_DELIVERED = 7,
-  SWITCH_CAUSE_NORMAL_CLEARING = 16,
-  SWITCH_CAUSE_USER_BUSY = 17,
-  SWITCH_CAUSE_NO_USER_RESPONSE = 18,
-  SWITCH_CAUSE_NO_ANSWER = 19,
-  SWITCH_CAUSE_SUBSCRIBER_ABSENT = 20,
-  SWITCH_CAUSE_CALL_REJECTED = 21,
-  SWITCH_CAUSE_NUMBER_CHANGED = 22,
-  SWITCH_CAUSE_REDIRECTION_TO_NEW_DESTINATION = 23,
-  SWITCH_CAUSE_EXCHANGE_ROUTING_ERROR = 25,
-  SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER = 27,
-  SWITCH_CAUSE_INVALID_NUMBER_FORMAT = 28,
-  SWITCH_CAUSE_FACILITY_REJECTED = 29,
-  SWITCH_CAUSE_RESPONSE_TO_STATUS_ENQUIRY = 30,
-  SWITCH_CAUSE_NORMAL_UNSPECIFIED = 31,
-  SWITCH_CAUSE_NORMAL_CIRCUIT_CONGESTION = 34,
-  SWITCH_CAUSE_NETWORK_OUT_OF_ORDER = 38,
-  SWITCH_CAUSE_NORMAL_TEMPORARY_FAILURE = 41,
-  SWITCH_CAUSE_SWITCH_CONGESTION = 42,
-  SWITCH_CAUSE_ACCESS_INFO_DISCARDED = 43,
-  SWITCH_CAUSE_REQUESTED_CHAN_UNAVAIL = 44,
-  SWITCH_CAUSE_PRE_EMPTED = 45,
-  SWITCH_CAUSE_FACILITY_NOT_SUBSCRIBED = 50,
-  SWITCH_CAUSE_OUTGOING_CALL_BARRED = 52,
-  SWITCH_CAUSE_INCOMING_CALL_BARRED = 54,
-  SWITCH_CAUSE_BEARERCAPABILITY_NOTAUTH = 57,
-  SWITCH_CAUSE_BEARERCAPABILITY_NOTAVAIL = 58,
-  SWITCH_CAUSE_SERVICE_UNAVAILABLE = 63,
-  SWITCH_CAUSE_BEARERCAPABILITY_NOTIMPL = 65,
-  SWITCH_CAUSE_CHAN_NOT_IMPLEMENTED = 66,
-  SWITCH_CAUSE_FACILITY_NOT_IMPLEMENTED = 69,
-  SWITCH_CAUSE_SERVICE_NOT_IMPLEMENTED = 79,
-  SWITCH_CAUSE_INVALID_CALL_REFERENCE = 81,
-  SWITCH_CAUSE_INCOMPATIBLE_DESTINATION = 88,
-  SWITCH_CAUSE_INVALID_MSG_UNSPECIFIED = 95,
-  SWITCH_CAUSE_MANDATORY_IE_MISSING = 96,
-  SWITCH_CAUSE_MESSAGE_TYPE_NONEXIST = 97,
-  SWITCH_CAUSE_WRONG_MESSAGE = 98,
-  SWITCH_CAUSE_IE_NONEXIST = 99,
-  SWITCH_CAUSE_INVALID_IE_CONTENTS = 100,
-  SWITCH_CAUSE_WRONG_CALL_STATE = 101,
-  SWITCH_CAUSE_RECOVERY_ON_TIMER_EXPIRE = 102,
-  SWITCH_CAUSE_MANDATORY_IE_LENGTH_ERROR = 103,
-  SWITCH_CAUSE_PROTOCOL_ERROR = 111,
-  SWITCH_CAUSE_INTERWORKING = 127,
-  SWITCH_CAUSE_SUCCESS = 142,
-  SWITCH_CAUSE_ORIGINATOR_CANCEL = 487,
-  SWITCH_CAUSE_CRASH = 500,
-  SWITCH_CAUSE_SYSTEM_SHUTDOWN = 501,
-  SWITCH_CAUSE_LOSE_RACE = 502,
-  SWITCH_CAUSE_MANAGER_REQUEST = 503,
-  SWITCH_CAUSE_BLIND_TRANSFER = 600,
-  SWITCH_CAUSE_ATTENDED_TRANSFER = 601,
-  SWITCH_CAUSE_ALLOTTED_TIMEOUT = 602,
-  SWITCH_CAUSE_USER_CHALLENGE = 603,
-  SWITCH_CAUSE_MEDIA_TIMEOUT = 604,
-  SWITCH_CAUSE_PICKED_OFF = 605,
-  SWITCH_CAUSE_USER_NOT_REGISTERED = 606
-}
+  public static SWIGTYPE_p_FILE switch_core_get_console() {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_get_console();
+    SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_core_launch_thread(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void func, SWIGTYPE_p_void obj, SWIGTYPE_p_apr_pool_t pool) {
+    freeswitchPINVOKE.switch_core_launch_thread(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void.getCPtr(func), SWIGTYPE_p_void.getCPtr(obj), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_core_set_globals() {
+    freeswitchPINVOKE.switch_core_set_globals();
+  }
 
-[System.Flags] public enum switch_channel_flag_enum_t {
-  CF_ANSWERED = (1 << 0),
-  CF_OUTBOUND = (1 << 1),
-  CF_EARLY_MEDIA = (1 << 2),
-  CF_ORIGINATOR = (1 << 3),
-  CF_TRANSFER = (1 << 4),
-  CF_ACCEPT_CNG = (1 << 5),
-  CF_WAIT_FOR_ME = (1 << 6),
-  CF_BRIDGED = (1 << 7),
-  CF_HOLD = (1 << 8),
-  CF_SERVICE = (1 << 9),
-  CF_TAGGED = (1 << 10),
-  CF_WINNER = (1 << 11),
-  CF_CONTROLLED = (1 << 12),
-  CF_PROXY_MODE = (1 << 13),
-  CF_SUSPEND = (1 << 14),
-  CF_EVENT_PARSE = (1 << 15),
-  CF_REPEAT_STATE = (1 << 16),
-  CF_GEN_RINGBACK = (1 << 17),
-  CF_RING_READY = (1 << 18),
-  CF_BREAK = (1 << 19),
-  CF_BROADCAST = (1 << 20),
-  CF_UNICAST = (1 << 21),
-  CF_VIDEO = (1 << 22),
-  CF_EVENT_LOCK = (1 << 23),
-  CF_RESET = (1 << 24),
-  CF_ORIGINATING = (1 << 25),
-  CF_STOP_BROADCAST = (1 << 26),
-  CF_PROXY_MEDIA = (1 << 27),
-  CF_INNER_BRIDGE = (1 << 28),
-  CF_REQ_MEDIA = (1 << 29)
-}
+  public static byte switch_core_session_compare(SWIGTYPE_p_switch_core_session a, SWIGTYPE_p_switch_core_session b) {
+    byte ret = freeswitchPINVOKE.switch_core_session_compare(SWIGTYPE_p_switch_core_session.getCPtr(a), SWIGTYPE_p_switch_core_session.getCPtr(b));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static byte switch_core_session_check_interface(SWIGTYPE_p_switch_core_session session, switch_endpoint_interface endpoint_interface) {
+    byte ret = freeswitchPINVOKE.switch_core_session_check_interface(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_endpoint_interface.getCPtr(endpoint_interface));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static SWIGTYPE_p_HashElem switch_core_mime_index() {
+    IntPtr cPtr = freeswitchPINVOKE.switch_core_mime_index();
+    SWIGTYPE_p_HashElem ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_HashElem(cPtr, false);
+    return ret;
+  }
 
-public enum switch_channel_state_t {
-  CS_NEW,
-  CS_INIT,
-  CS_ROUTING,
-  CS_SOFT_EXECUTE,
-  CS_EXECUTE,
-  CS_EXCHANGE_MEDIA,
-  CS_PARK,
-  CS_CONSUME_MEDIA,
-  CS_HIBERNATE,
-  CS_RESET,
-  CS_HANGUP,
-  CS_DONE,
-  CS_NONE
-}
+  public static string switch_core_mime_ext2type(string ext) {
+    string ret = freeswitchPINVOKE.switch_core_mime_ext2type(ext);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_core_mime_add_type(string type, string ext) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_mime_add_type(type, ext);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static SWIGTYPE_p_switch_loadable_module_interface switch_loadable_module_create_module_interface(SWIGTYPE_p_apr_pool_t pool, string name) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_create_module_interface(SWIGTYPE_p_apr_pool_t.getCPtr(pool), name);
+    SWIGTYPE_p_switch_loadable_module_interface ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_loadable_module_interface(cPtr, false);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static SWIGTYPE_p_void switch_loadable_module_create_interface(SWIGTYPE_p_switch_loadable_module_interface mod, switch_module_interface_name_t iname) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_create_interface(SWIGTYPE_p_switch_loadable_module_interface.getCPtr(mod), (int)iname);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
+  }
 
-public class switch_channel_timetable : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static SWIGTYPE_p_switch_time_t switch_timestamp_now() {
+    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_timestamp_now(), true);
+    return ret;
+  }
 
-  internal switch_channel_timetable(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_core_memory_reclaim() {
+    freeswitchPINVOKE.switch_core_memory_reclaim();
+  }
+
+  public static void switch_core_memory_reclaim_events() {
+    freeswitchPINVOKE.switch_core_memory_reclaim_events();
   }
 
-  internal static HandleRef getCPtr(switch_channel_timetable obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_core_memory_reclaim_logger() {
+    freeswitchPINVOKE.switch_core_memory_reclaim_logger();
   }
 
-  ~switch_channel_timetable() {
-    Dispose();
+  public static void switch_core_memory_reclaim_all() {
+    freeswitchPINVOKE.switch_core_memory_reclaim_all();
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_channel_timetable(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static void switch_core_setrlimits() {
+    freeswitchPINVOKE.switch_core_setrlimits();
   }
 
-  public SWIGTYPE_p_switch_time_t profile_created {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_profile_created_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_profile_created_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static void switch_time_sync() {
+    freeswitchPINVOKE.switch_time_sync();
   }
 
-  public SWIGTYPE_p_switch_time_t created {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_created_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_created_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static SWIGTYPE_p_time_t switch_timestamp(SWIGTYPE_p_time_t t) {
+    SWIGTYPE_p_time_t ret = new SWIGTYPE_p_time_t(freeswitchPINVOKE.switch_timestamp(SWIGTYPE_p_time_t.getCPtr(t)), true);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_time_t answered {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_answered_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_answered_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_strftime_tz(string tz, string format, string date, uint len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_strftime_tz(tz, format, date, len);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_time_t progress {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_progress_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_progress_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static void switch_load_network_lists(switch_bool_t reload) {
+    freeswitchPINVOKE.switch_load_network_lists((int)reload);
   }
 
-  public SWIGTYPE_p_switch_time_t progress_media {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_progress_media_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_progress_media_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_bool_t switch_check_network_list_ip_token(string ip_str, string list_name, ref string token) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_check_network_list_ip_token(ip_str, list_name, ref token);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_time_t hungup {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_hungup_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_hungup_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static void switch_time_set_monotonic(switch_bool_t enable) {
+    freeswitchPINVOKE.switch_time_set_monotonic((int)enable);
   }
 
-  public SWIGTYPE_p_switch_time_t transferred {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_transferred_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_channel_timetable_transferred_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static uint switch_core_max_dtmf_duration(uint duration) {
+    uint ret = freeswitchPINVOKE.switch_core_max_dtmf_duration(duration);
+    return ret;
   }
 
-  public switch_channel_timetable next {
-    set {
-      freeswitchPINVOKE.switch_channel_timetable_next_set(swigCPtr, switch_channel_timetable.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_channel_timetable_next_get(swigCPtr);
-      switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_core_default_dtmf_duration(uint duration) {
+    uint ret = freeswitchPINVOKE.switch_core_default_dtmf_duration(duration);
+    return ret;
   }
 
-  public switch_channel_timetable() : this(freeswitchPINVOKE.new_switch_channel_timetable(), true) {
+  public static switch_status_t switch_console_set_complete(string arg0) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_set_complete(arg0);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_console_set_alias(string arg0) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_set_alias(arg0);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static int switch_system(string cmd, switch_bool_t wait) {
+    int ret = freeswitchPINVOKE.switch_system(cmd, (int)wait);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_console_loop() {
+    freeswitchPINVOKE.switch_console_loop();
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_console_stream_raw_write(switch_stream_handle handle, SWIGTYPE_p_unsigned_char data, SWIGTYPE_p_switch_size_t datalen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_console_stream_raw_write(switch_stream_handle.getCPtr(handle), SWIGTYPE_p_unsigned_char.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-public class switch_chat_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_bool_t switch_is_moh(string s) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_moh(s);
+    return ret;
+  }
 
-  internal switch_chat_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_b64_encode(SWIGTYPE_p_unsigned_char arg0, SWIGTYPE_p_switch_size_t ilen, SWIGTYPE_p_unsigned_char arg2, SWIGTYPE_p_switch_size_t olen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_b64_encode(SWIGTYPE_p_unsigned_char.getCPtr(arg0), SWIGTYPE_p_switch_size_t.getCPtr(ilen), SWIGTYPE_p_unsigned_char.getCPtr(arg2), SWIGTYPE_p_switch_size_t.getCPtr(olen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_chat_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static SWIGTYPE_p_switch_size_t switch_b64_decode(string arg0, string arg1, SWIGTYPE_p_switch_size_t olen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_b64_decode(arg0, arg1, SWIGTYPE_p_switch_size_t.getCPtr(olen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  ~switch_chat_interface() {
-    Dispose();
+  public static string switch_amp_encode(string s, string buf, SWIGTYPE_p_switch_size_t len) {
+    string ret = freeswitchPINVOKE.switch_amp_encode(s, buf, SWIGTYPE_p_switch_size_t.getCPtr(len));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_chat_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_bool_t switch_is_digit_string(string s) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_digit_string(s);
+    return ret;
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_chat_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_chat_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static SWIGTYPE_p_switch_size_t switch_fd_read_line(int fd, string buf, SWIGTYPE_p_switch_size_t len) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_fd_read_line(fd, buf, SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t chat_send {
-    set {
-      freeswitchPINVOKE.switch_chat_interface_chat_send_set(swigCPtr, SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_chat_send_get(swigCPtr);
-      SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_find_local_ip(string buf, int len, int family) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_find_local_ip(buf, len, family);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_chat_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static string get_addr(string buf, SWIGTYPE_p_switch_size_t len, SWIGTYPE_p_sockaddr sa, SWIGTYPE_p_socklen_t salen) {
+    string ret = freeswitchPINVOKE.get_addr(buf, SWIGTYPE_p_switch_size_t.getCPtr(len), SWIGTYPE_p_sockaddr.getCPtr(sa), SWIGTYPE_p_socklen_t.getCPtr(salen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public switch_chat_interface next {
-    set {
-      freeswitchPINVOKE.switch_chat_interface_next_set(swigCPtr, switch_chat_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_chat_interface_next_get(swigCPtr);
-      switch_chat_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_chat_interface(cPtr, false);
-      return ret;
-    } 
+  public static ushort get_port(SWIGTYPE_p_sockaddr sa) {
+    ushort ret = freeswitchPINVOKE.get_port(SWIGTYPE_p_sockaddr.getCPtr(sa));
+    return ret;
   }
 
-  public switch_chat_interface() : this(freeswitchPINVOKE.new_switch_chat_interface(), true) {
+  public static int switch_build_uri(string uri, SWIGTYPE_p_switch_size_t size, string scheme, string user, SWIGTYPE_p_switch_sockaddr_t sa, int flags) {
+    int ret = freeswitchPINVOKE.switch_build_uri(uri, SWIGTYPE_p_switch_size_t.getCPtr(size), scheme, user, SWIGTYPE_p_switch_sockaddr_t.getCPtr(sa), flags);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-}
+  public static string switch_priority_name(switch_priority_t priority) {
+    string ret = freeswitchPINVOKE.switch_priority_name((int)priority);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static char switch_rfc2833_to_char(int arg0) {
+    char ret = freeswitchPINVOKE.switch_rfc2833_to_char(arg0);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static byte switch_char_to_rfc2833(char key) {
+    byte ret = freeswitchPINVOKE.switch_char_to_rfc2833(key);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static string switch_clean_string(string s) {
+    string ret = freeswitchPINVOKE.switch_clean_string(s);
+    return ret;
+  }
 
-public class switch_codec : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static string switch_safe_strdup(string it) {
+    string ret = freeswitchPINVOKE.switch_safe_strdup(it);
+    return ret;
+  }
 
-  internal switch_codec(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_bool_t switch_strstr(string s, string q) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_strstr(s, q);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_codec obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static SWIGTYPE_p_switch_time_t switch_str_time(string arg0) {
+    SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_str_time(arg0), true);
+    return ret;
   }
 
-  ~switch_codec() {
-    Dispose();
+  public static uint switch_separate_string(string buf, char delim, ref string array, uint arraylen) {
+    uint ret = freeswitchPINVOKE.switch_separate_string(buf, delim, ref array, arraylen);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_codec(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_bool_t switch_is_number(string str) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_number(str);
+    return ret;
   }
 
-  public switch_codec_interface codec_interface {
-    set {
-      freeswitchPINVOKE.switch_codec_codec_interface_set(swigCPtr, switch_codec_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_codec_interface_get(swigCPtr);
-      switch_codec_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_interface(cPtr, false);
-      return ret;
-    } 
+  public static string switch_strip_spaces(string str) {
+    string ret = freeswitchPINVOKE.switch_strip_spaces(str);
+    return ret;
   }
 
-  public switch_codec_implementation implementation {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_set(swigCPtr, switch_codec_implementation.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_get(swigCPtr);
-      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
-      return ret;
-    } 
+  public static string switch_separate_paren_args(string str) {
+    string ret = freeswitchPINVOKE.switch_separate_paren_args(str);
+    return ret;
   }
 
-  public string fmtp_in {
-    set {
-      freeswitchPINVOKE.switch_codec_fmtp_in_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_codec_fmtp_in_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_stristr(string instr, string str) {
+    string ret = freeswitchPINVOKE.switch_stristr(instr, str);
+    return ret;
   }
 
-  public string fmtp_out {
-    set {
-      freeswitchPINVOKE.switch_codec_fmtp_out_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_codec_fmtp_out_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_bool_t switch_is_lan_addr(string ip) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_is_lan_addr(ip);
+    return ret;
   }
 
-  public switch_codec_settings codec_settings {
-    set {
-      freeswitchPINVOKE.switch_codec_codec_settings_set(swigCPtr, switch_codec_settings.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_codec_settings_get(swigCPtr);
-      switch_codec_settings ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_settings(cPtr, false);
-      return ret;
-    } 
+  public static string switch_replace_char(string str, char from, char to, switch_bool_t dup) {
+    string ret = freeswitchPINVOKE.switch_replace_char(str, from, to, (int)dup);
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_codec_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_bool_t switch_ast2regex(string pat, string rbuf, uint len) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_ast2regex(pat, rbuf, len);
+    return ret;
   }
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_codec_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_escape_char(SWIGTYPE_p_apr_pool_t pool, string arg1, string delim, char esc) {
+    string ret = freeswitchPINVOKE.switch_escape_char(SWIGTYPE_p_apr_pool_t.getCPtr(pool), arg1, delim, esc);
+    return ret;
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_codec_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static int switch_socket_waitfor(SWIGTYPE_p_switch_pollfd_t poll, int ms) {
+    int ret = freeswitchPINVOKE.switch_socket_waitfor(SWIGTYPE_p_switch_pollfd_t.getCPtr(poll), ms);
+    return ret;
   }
 
-  public byte agreed_pt {
-    set {
-      freeswitchPINVOKE.switch_codec_agreed_pt_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_codec_agreed_pt_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_cut_path(string arg0) {
+    string ret = freeswitchPINVOKE.switch_cut_path(arg0);
+    return ret;
   }
 
-  public switch_codec() : this(freeswitchPINVOKE.new_switch_codec(), true) {
+  public static string switch_string_replace(string arg0, string search, string replace) {
+    string ret = freeswitchPINVOKE.switch_string_replace(arg0, search, replace);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_string_match(string arg0, uint string_len, string search, uint search_len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_string_match(arg0, string_len, search, search_len);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static uint switch_url_encode(string url, string buf, uint len) {
+    uint ret = freeswitchPINVOKE.switch_url_encode(url, buf, len);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static string switch_url_decode(string s) {
+    string ret = freeswitchPINVOKE.switch_url_decode(s);
+    return ret;
+  }
 
-[System.Flags] public enum switch_codec_flag_enum_t {
-  SWITCH_CODEC_FLAG_ENCODE = (1 << 0),
-  SWITCH_CODEC_FLAG_DECODE = (1 << 1),
-  SWITCH_CODEC_FLAG_SILENCE_START = (1 << 2),
-  SWITCH_CODEC_FLAG_SILENCE_STOP = (1 << 3),
-  SWITCH_CODEC_FLAG_SILENCE = (1 << 4),
-  SWITCH_CODEC_FLAG_FREE_POOL = (1 << 5),
-  SWITCH_CODEC_FLAG_AAL2 = (1 << 6),
-  SWITCH_CODEC_FLAG_PASSTHROUGH = (1 << 7)
-}
+  public static switch_bool_t switch_simple_email(string to, string from, string headers, string body, string file) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_simple_email(to, from, headers, body, file);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static string switch_find_end_paren(string s, char open, char close) {
+    string ret = freeswitchPINVOKE.switch_find_end_paren(s, open, close);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static int switch_parse_cidr(string arg0, SWIGTYPE_p_unsigned_long ip, SWIGTYPE_p_unsigned_long mask, SWIGTYPE_p_unsigned_long bitp) {
+    int ret = freeswitchPINVOKE.switch_parse_cidr(arg0, SWIGTYPE_p_unsigned_long.getCPtr(ip), SWIGTYPE_p_unsigned_long.getCPtr(mask), SWIGTYPE_p_unsigned_long.getCPtr(bitp));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_network_list_create(SWIGTYPE_p_p_switch_network_list list, switch_bool_t default_type, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_create(SWIGTYPE_p_p_switch_network_list.getCPtr(list), (int)default_type, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
 
-public class switch_codec_implementation : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_network_list_add_cidr_token(SWIGTYPE_p_switch_network_list list, string cidr_str, switch_bool_t ok, string token) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_add_cidr_token(SWIGTYPE_p_switch_network_list.getCPtr(list), cidr_str, (int)ok, token);
+    return ret;
+  }
 
-  internal switch_codec_implementation(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_network_list_add_host_mask(SWIGTYPE_p_switch_network_list list, string host, string mask_str, switch_bool_t ok) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_network_list_add_host_mask(SWIGTYPE_p_switch_network_list.getCPtr(list), host, mask_str, (int)ok);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_codec_implementation obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_bool_t switch_network_list_validate_ip_token(SWIGTYPE_p_switch_network_list list, uint ip, ref string token) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_network_list_validate_ip_token(SWIGTYPE_p_switch_network_list.getCPtr(list), ip, ref token);
+    return ret;
   }
 
-  ~switch_codec_implementation() {
-    Dispose();
+  public static switch_caller_extension switch_caller_extension_new(SWIGTYPE_p_switch_core_session session, string extension_name, string extension_number) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_caller_extension_new(SWIGTYPE_p_switch_core_session.getCPtr(session), extension_name, extension_number);
+    switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_codec_implementation(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_caller_extension_clone(SWIGTYPE_p_p_switch_caller_extension new_ext, switch_caller_extension orig, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_caller_extension_clone(SWIGTYPE_p_p_switch_caller_extension.getCPtr(new_ext), switch_caller_extension.getCPtr(orig), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public switch_codec_type_t codec_type {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_codec_type_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_codec_type_t ret = (switch_codec_type_t)freeswitchPINVOKE.switch_codec_implementation_codec_type_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_caller_extension_add_application(SWIGTYPE_p_switch_core_session session, switch_caller_extension caller_extension, string application_name, string extra_data) {
+    freeswitchPINVOKE.switch_caller_extension_add_application(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_caller_extension.getCPtr(caller_extension), application_name, extra_data);
   }
 
-  public byte ianacode {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_ianacode_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_codec_implementation_ianacode_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_caller_get_field_by_name(switch_caller_profile caller_profile, string name) {
+    string ret = freeswitchPINVOKE.switch_caller_get_field_by_name(switch_caller_profile.getCPtr(caller_profile), name);
+    return ret;
   }
 
-  public string iananame {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_iananame_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_codec_implementation_iananame_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_caller_profile switch_caller_profile_new(SWIGTYPE_p_apr_pool_t pool, string username, string dialplan, string caller_id_name, string caller_id_number, string network_addr, string ani, string aniii, string rdnis, string source, string context, string destination_number) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_new(SWIGTYPE_p_apr_pool_t.getCPtr(pool), username, dialplan, caller_id_name, caller_id_number, network_addr, ani, aniii, rdnis, source, context, destination_number);
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
   }
 
-  public string fmtp {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_fmtp_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_codec_implementation_fmtp_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_caller_profile switch_caller_profile_clone(SWIGTYPE_p_switch_core_session session, switch_caller_profile tocopy) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_clone(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_caller_profile.getCPtr(tocopy));
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
   }
 
-  public uint samples_per_second {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_samples_per_second_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_samples_per_second_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_caller_profile switch_caller_profile_dup(SWIGTYPE_p_apr_pool_t pool, switch_caller_profile tocopy) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_caller_profile_dup(SWIGTYPE_p_apr_pool_t.getCPtr(pool), switch_caller_profile.getCPtr(tocopy));
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
   }
 
-  public uint actual_samples_per_second {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_actual_samples_per_second_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_actual_samples_per_second_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_caller_profile_event_set_data(switch_caller_profile caller_profile, string prefix, switch_event arg2) {
+    freeswitchPINVOKE.switch_caller_profile_event_set_data(switch_caller_profile.getCPtr(caller_profile), prefix, switch_event.getCPtr(arg2));
   }
 
-  public int bits_per_second {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_bits_per_second_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_implementation_bits_per_second_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_channel_state_t switch_channel_get_state(SWIGTYPE_p_switch_channel channel) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_get_state(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public int microseconds_per_frame {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_microseconds_per_frame_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_implementation_microseconds_per_frame_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_channel_state_t switch_channel_get_running_state(SWIGTYPE_p_switch_channel channel) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_get_running_state(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public uint samples_per_frame {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_samples_per_frame_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_samples_per_frame_get(swigCPtr);
-      return ret;
-    } 
+  public static byte switch_channel_ready(SWIGTYPE_p_switch_channel channel) {
+    byte ret = freeswitchPINVOKE.switch_channel_ready(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public uint bytes_per_frame {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_bytes_per_frame_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_bytes_per_frame_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_channel_wait_for_state(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_switch_channel other_channel, switch_channel_state_t want_state) {
+    freeswitchPINVOKE.switch_channel_wait_for_state(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_switch_channel.getCPtr(other_channel), (int)want_state);
   }
 
-  public uint encoded_bytes_per_frame {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_encoded_bytes_per_frame_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_encoded_bytes_per_frame_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_wait_for_flag(SWIGTYPE_p_switch_channel channel, uint want_flag, switch_bool_t pres, uint to, SWIGTYPE_p_switch_channel super_channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_wait_for_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), want_flag, (int)pres, to, SWIGTYPE_p_switch_channel.getCPtr(super_channel));
+    return ret;
   }
 
-  public byte number_of_channels {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_number_of_channels_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_codec_implementation_number_of_channels_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_channel_state_t switch_channel_perform_set_state(SWIGTYPE_p_switch_channel channel, string file, string func, int line, switch_channel_state_t state) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_set_state(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line, (int)state);
+    return ret;
   }
 
-  public int pref_frames_per_packet {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_pref_frames_per_packet_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_implementation_pref_frames_per_packet_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_channel_state_t switch_channel_perform_set_running_state(SWIGTYPE_p_switch_channel channel, switch_channel_state_t state, string file, string func, int line) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_set_running_state(SWIGTYPE_p_switch_channel.getCPtr(channel), (int)state, file, func, line);
+    return ret;
   }
 
-  public int max_frames_per_packet {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_max_frames_per_packet_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_implementation_max_frames_per_packet_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_call_cause_t switch_channel_str2cause(string str) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_str2cause(str);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t init {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_init_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_call_cause_t switch_channel_get_cause(SWIGTYPE_p_switch_channel channel) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_get_cause(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t encode {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_encode_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_encode_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_call_cause_t switch_channel_cause_q850(switch_call_cause_t cause) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_cause_q850((int)cause);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t decode {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_decode_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_decode_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_call_cause_t switch_channel_get_cause_q850(SWIGTYPE_p_switch_channel channel) {
+    switch_call_cause_t ret = (switch_call_cause_t)freeswitchPINVOKE.switch_channel_get_cause_q850(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_codec__switch_status_t destroy {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_destroy_set(swigCPtr, SWIGTYPE_p_f_p_switch_codec__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_destroy_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_codec__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_codec__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_channel_cause2str(switch_call_cause_t cause) {
+    string ret = freeswitchPINVOKE.switch_channel_cause2str((int)cause);
+    return ret;
   }
 
-  public uint codec_id {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_codec_id_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_implementation_codec_id_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_channel_timetable switch_channel_get_timetable(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_timetable(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_channel_timetable ret = (cPtr == IntPtr.Zero) ? null : new switch_channel_timetable(cPtr, false);
+    return ret;
   }
 
-  public switch_codec_implementation next {
-    set {
-      freeswitchPINVOKE.switch_codec_implementation_next_set(swigCPtr, switch_codec_implementation.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_implementation_next_get(swigCPtr);
-      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_alloc(SWIGTYPE_p_p_switch_channel channel, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_alloc(SWIGTYPE_p_p_switch_channel.getCPtr(channel), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public switch_codec_implementation() : this(freeswitchPINVOKE.new_switch_codec_implementation(), true) {
+  public static switch_status_t switch_channel_init(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_switch_core_session session, switch_channel_state_t state, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_init(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_switch_core_session.getCPtr(session), (int)state, flags);
+    return ret;
   }
 
-}
+  public static void switch_channel_presence(SWIGTYPE_p_switch_channel channel, string rpid, string status, string id) {
+    freeswitchPINVOKE.switch_channel_presence(SWIGTYPE_p_switch_channel.getCPtr(channel), rpid, status, id);
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_channel_uninit(SWIGTYPE_p_switch_channel channel) {
+    freeswitchPINVOKE.switch_channel_uninit(SWIGTYPE_p_switch_channel.getCPtr(channel));
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_channel_set_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
+    freeswitchPINVOKE.switch_channel_set_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_caller_profile switch_channel_get_caller_profile(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
+  }
 
-public class switch_codec_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_channel_set_originator_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
+    freeswitchPINVOKE.switch_channel_set_originator_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
+  }
 
-  internal switch_codec_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_caller_profile switch_channel_get_originator_caller_profile(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_originator_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_codec_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_channel_set_originatee_caller_profile(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile) {
+    freeswitchPINVOKE.switch_channel_set_originatee_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile));
   }
 
-  ~switch_codec_interface() {
-    Dispose();
+  public static switch_caller_profile switch_channel_get_originatee_caller_profile(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_originatee_caller_profile(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_caller_profile ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_profile(cPtr, false);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_codec_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static string switch_channel_get_uuid(SWIGTYPE_p_switch_channel channel) {
+    string ret = freeswitchPINVOKE.switch_channel_get_uuid(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_codec_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_codec_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_set_variable(SWIGTYPE_p_switch_channel channel, string varname, string value) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_variable(SWIGTYPE_p_switch_channel.getCPtr(channel), varname, value);
+    return ret;
   }
 
-  public switch_codec_implementation implementations {
-    set {
-      freeswitchPINVOKE.switch_codec_interface_implementations_set(swigCPtr, switch_codec_implementation.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_implementations_get(swigCPtr);
-      switch_codec_implementation ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_implementation(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_set_variable_printf(SWIGTYPE_p_switch_channel channel, string varname, string fmt) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_variable_printf(SWIGTYPE_p_switch_channel.getCPtr(channel), varname, fmt);
+    return ret;
   }
 
-  public uint codec_id {
-    set {
-      freeswitchPINVOKE.switch_codec_interface_codec_id_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_codec_interface_codec_id_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_set_variable_partner(SWIGTYPE_p_switch_channel channel, string varname, string value) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_variable_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), varname, value);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_codec_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static string switch_channel_get_variable_partner(SWIGTYPE_p_switch_channel channel, string varname) {
+    string ret = freeswitchPINVOKE.switch_channel_get_variable_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), varname);
+    return ret;
   }
 
-  public switch_codec_interface next {
-    set {
-      freeswitchPINVOKE.switch_codec_interface_next_set(swigCPtr, switch_codec_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_codec_interface_next_get(swigCPtr);
-      switch_codec_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_codec_interface(cPtr, false);
-      return ret;
-    } 
+  public static string switch_channel_get_variable(SWIGTYPE_p_switch_channel channel, string varname) {
+    string ret = freeswitchPINVOKE.switch_channel_get_variable(SWIGTYPE_p_switch_channel.getCPtr(channel), varname);
+    return ret;
   }
 
-  public switch_codec_interface() : this(freeswitchPINVOKE.new_switch_codec_interface(), true) {
+  public static switch_status_t switch_channel_get_variables(SWIGTYPE_p_switch_channel channel, SWIGTYPE_p_p_switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_get_variables(SWIGTYPE_p_switch_channel.getCPtr(channel), SWIGTYPE_p_p_switch_event.getCPtr(arg1));
+    return ret;
   }
 
-}
-
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
-
-namespace FreeSWITCH.Native {
-
-using System;
-using System.Runtime.InteropServices;
-
-public class switch_codec_settings : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
-
-  internal switch_codec_settings(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_event_header switch_channel_variable_first(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_variable_first(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_codec_settings obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_channel_variable_last(SWIGTYPE_p_switch_channel channel) {
+    freeswitchPINVOKE.switch_channel_variable_last(SWIGTYPE_p_switch_channel.getCPtr(channel));
   }
 
-  ~switch_codec_settings() {
-    Dispose();
+  public static void switch_channel_set_caller_extension(SWIGTYPE_p_switch_channel channel, switch_caller_extension caller_extension) {
+    freeswitchPINVOKE.switch_channel_set_caller_extension(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_extension.getCPtr(caller_extension));
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_codec_settings(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_caller_extension switch_channel_get_caller_extension(SWIGTYPE_p_switch_channel channel) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_caller_extension(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new switch_caller_extension(cPtr, false);
+    return ret;
   }
 
-  public int quality {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_quality_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_quality_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_channel_test_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
+    uint ret = freeswitchPINVOKE.switch_channel_test_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
+    return ret;
   }
 
-  public int complexity {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_complexity_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_complexity_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_channel_set_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
+    freeswitchPINVOKE.switch_channel_set_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
   }
 
-  public int enhancement {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_enhancement_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_enhancement_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_bool_t switch_channel_set_flag_partner(SWIGTYPE_p_switch_channel channel, uint flags) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_channel_set_flag_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
+    return ret;
   }
 
-  public int vad {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_vad_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_vad_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_bool_t switch_channel_clear_flag_partner(SWIGTYPE_p_switch_channel channel, uint flags) {
+    switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_channel_clear_flag_partner(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
+    return ret;
   }
 
-  public int vbr {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_vbr_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_vbr_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_channel_set_state_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
+    freeswitchPINVOKE.switch_channel_set_state_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
   }
 
-  public float vbr_quality {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_vbr_quality_set(swigCPtr, value);
-    } 
-    get {
-      float ret = freeswitchPINVOKE.switch_codec_settings_vbr_quality_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_channel_clear_flag(SWIGTYPE_p_switch_channel channel, uint flags) {
+    freeswitchPINVOKE.switch_channel_clear_flag(SWIGTYPE_p_switch_channel.getCPtr(channel), flags);
   }
 
-  public int abr {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_abr_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_abr_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_answer(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_answer(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public int dtx {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_dtx_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_dtx_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_mark_answered(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_answered(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public int preproc {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_preproc_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_preproc_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_ring_ready(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_ring_ready(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public int pp_vad {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_vad_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_pp_vad_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_pre_answer(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_pre_answer(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public int pp_agc {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_agc_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_pp_agc_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_mark_pre_answered(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_pre_answered(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public float pp_agc_level {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_agc_level_set(swigCPtr, value);
-    } 
-    get {
-      float ret = freeswitchPINVOKE.switch_codec_settings_pp_agc_level_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_perform_mark_ring_ready(SWIGTYPE_p_switch_channel channel, string file, string func, int line) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_perform_mark_ring_ready(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line);
+    return ret;
   }
 
-  public int pp_denoise {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_denoise_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_pp_denoise_get(swigCPtr);
-      return ret;
-    } 
+  public static int switch_channel_add_state_handler(SWIGTYPE_p_switch_channel channel, switch_state_handler_table state_handler) {
+    int ret = freeswitchPINVOKE.switch_channel_add_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_state_handler_table.getCPtr(state_handler));
+    return ret;
   }
 
-  public int pp_dereverb {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_channel_clear_state_handler(SWIGTYPE_p_switch_channel channel, switch_state_handler_table state_handler) {
+    freeswitchPINVOKE.switch_channel_clear_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_state_handler_table.getCPtr(state_handler));
   }
 
-  public float pp_dereverb_decay {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_decay_set(swigCPtr, value);
-    } 
-    get {
-      float ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_decay_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_state_handler_table switch_channel_get_state_handler(SWIGTYPE_p_switch_channel channel, int index) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_state_handler(SWIGTYPE_p_switch_channel.getCPtr(channel), index);
+    switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
+    return ret;
   }
 
-  public float pp_dereverb_level {
-    set {
-      freeswitchPINVOKE.switch_codec_settings_pp_dereverb_level_set(swigCPtr, value);
-    } 
-    get {
-      float ret = freeswitchPINVOKE.switch_codec_settings_pp_dereverb_level_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_set_private(SWIGTYPE_p_switch_channel channel, string key, SWIGTYPE_p_void private_info) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_private(SWIGTYPE_p_switch_channel.getCPtr(channel), key, SWIGTYPE_p_void.getCPtr(private_info));
+    return ret;
   }
 
-  public switch_codec_settings() : this(freeswitchPINVOKE.new_switch_codec_settings(), true) {
+  public static SWIGTYPE_p_void switch_channel_get_private(SWIGTYPE_p_switch_channel channel, string key) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_channel_get_private(SWIGTYPE_p_switch_channel.getCPtr(channel), key);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_channel_set_name(SWIGTYPE_p_switch_channel channel, string name) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_name(SWIGTYPE_p_switch_channel.getCPtr(channel), name);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static string switch_channel_get_name(SWIGTYPE_p_switch_channel channel) {
+    string ret = freeswitchPINVOKE.switch_channel_get_name(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_channel_state_t switch_channel_perform_hangup(SWIGTYPE_p_switch_channel channel, string file, string func, int line, switch_call_cause_t hangup_cause) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_perform_hangup(SWIGTYPE_p_switch_channel.getCPtr(channel), file, func, line, (int)hangup_cause);
+    return ret;
+  }
 
-public enum switch_codec_type_t {
-  SWITCH_CODEC_TYPE_AUDIO,
-  SWITCH_CODEC_TYPE_VIDEO,
-  SWITCH_CODEC_TYPE_T38,
-  SWITCH_CODEC_TYPE_APP
-}
+  public static SWIGTYPE_p_switch_size_t switch_channel_has_dtmf(SWIGTYPE_p_switch_channel channel) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_channel_has_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel)), true);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_channel_queue_dtmf(SWIGTYPE_p_switch_channel channel, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_queue_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_channel_queue_dtmf_string(SWIGTYPE_p_switch_channel channel, string dtmf_string) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_queue_dtmf_string(SWIGTYPE_p_switch_channel.getCPtr(channel), dtmf_string);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_channel_dequeue_dtmf(SWIGTYPE_p_switch_channel channel, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_dequeue_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
+  }
 
-public class switch_config : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_channel_flush_dtmf(SWIGTYPE_p_switch_channel channel) {
+    freeswitchPINVOKE.switch_channel_flush_dtmf(SWIGTYPE_p_switch_channel.getCPtr(channel));
+  }
 
-  internal switch_config(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static SWIGTYPE_p_switch_size_t switch_channel_dequeue_dtmf_string(SWIGTYPE_p_switch_channel channel, string dtmf_str, SWIGTYPE_p_switch_size_t len) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_channel_dequeue_dtmf_string(SWIGTYPE_p_switch_channel.getCPtr(channel), dtmf_str, SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_config obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static string switch_channel_state_name(switch_channel_state_t state) {
+    string ret = freeswitchPINVOKE.switch_channel_state_name((int)state);
+    return ret;
   }
 
-  ~switch_config() {
-    Dispose();
+  public static switch_channel_state_t switch_channel_name_state(string name) {
+    switch_channel_state_t ret = (switch_channel_state_t)freeswitchPINVOKE.switch_channel_name_state(name);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_config(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static void switch_channel_event_set_data(SWIGTYPE_p_switch_channel channel, switch_event arg1) {
+    freeswitchPINVOKE.switch_channel_event_set_data(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_event.getCPtr(arg1));
   }
 
-  public SWIGTYPE_p_FILE file {
-    set {
-      freeswitchPINVOKE.switch_config_file_set(swigCPtr, SWIGTYPE_p_FILE.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_config_file_get(swigCPtr);
-      SWIGTYPE_p_FILE ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_FILE(cPtr, false);
-      return ret;
-    } 
+  public static string switch_channel_expand_variables(SWIGTYPE_p_switch_channel channel, string arg1) {
+    string ret = freeswitchPINVOKE.switch_channel_expand_variables(SWIGTYPE_p_switch_channel.getCPtr(channel), arg1);
+    return ret;
   }
 
-  public string path {
-    set {
-      freeswitchPINVOKE.switch_config_path_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_config_path_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_channel_build_param_string(SWIGTYPE_p_switch_channel channel, switch_caller_profile caller_profile, string prefix) {
+    string ret = freeswitchPINVOKE.switch_channel_build_param_string(SWIGTYPE_p_switch_channel.getCPtr(channel), switch_caller_profile.getCPtr(caller_profile), prefix);
+    return ret;
   }
 
-  public string category {
-    set {
-      freeswitchPINVOKE.switch_config_category_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_config_category_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_channel_set_timestamps(SWIGTYPE_p_switch_channel channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_channel_set_timestamps(SWIGTYPE_p_switch_channel.getCPtr(channel));
+    return ret;
   }
 
-  public string section {
-    set {
-      freeswitchPINVOKE.switch_config_section_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_config_section_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_buffer_create(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t max_len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_create(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(max_len));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public string buf {
-    set {
-      freeswitchPINVOKE.switch_config_buf_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_config_buf_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_buffer_create_dynamic(SWIGTYPE_p_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t blocksize, SWIGTYPE_p_switch_size_t start_len, SWIGTYPE_p_switch_size_t max_len) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_create_dynamic(SWIGTYPE_p_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(blocksize), SWIGTYPE_p_switch_size_t.getCPtr(start_len), SWIGTYPE_p_switch_size_t.getCPtr(max_len));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public int lineno {
-    set {
-      freeswitchPINVOKE.switch_config_lineno_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_config_lineno_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_buffer_add_mutex(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_switch_mutex_t mutex) {
+    freeswitchPINVOKE.switch_buffer_add_mutex(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_mutex_t.getCPtr(mutex));
   }
 
-  public int catno {
-    set {
-      freeswitchPINVOKE.switch_config_catno_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_config_catno_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_buffer_lock(SWIGTYPE_p_switch_buffer buffer) {
+    freeswitchPINVOKE.switch_buffer_lock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
   }
 
-  public int sectno {
-    set {
-      freeswitchPINVOKE.switch_config_sectno_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_config_sectno_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_buffer_trylock(SWIGTYPE_p_switch_buffer buffer) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_buffer_trylock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
+    return ret;
   }
 
-  public int lockto {
-    set {
-      freeswitchPINVOKE.switch_config_lockto_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_config_lockto_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_buffer_unlock(SWIGTYPE_p_switch_buffer buffer) {
+    freeswitchPINVOKE.switch_buffer_unlock(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
   }
 
-  public switch_config() : this(freeswitchPINVOKE.new_switch_config(), true) {
+  public static SWIGTYPE_p_switch_size_t switch_buffer_len(SWIGTYPE_p_switch_buffer buffer) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_len(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
+    return ret;
   }
 
-}
+  public static SWIGTYPE_p_switch_size_t switch_buffer_freespace(SWIGTYPE_p_switch_buffer buffer) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_freespace(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static SWIGTYPE_p_switch_size_t switch_buffer_inuse(SWIGTYPE_p_switch_buffer buffer) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_inuse(SWIGTYPE_p_switch_buffer.getCPtr(buffer)), true);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static SWIGTYPE_p_switch_size_t switch_buffer_read(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_read(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-[System.Flags] public enum switch_core_flag_enum_t {
-  SCF_NONE = 0,
-  SCF_USE_SQL = (1 << 0),
-  SCF_NO_NEW_SESSIONS = (1 << 1),
-  SCF_SHUTTING_DOWN = (1 << 2),
-  SCF_CRASH_PROT = (1 << 3),
-  SCF_VG = (1 << 4)
-}
+  public static SWIGTYPE_p_switch_size_t switch_buffer_read_loop(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_read_loop(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_buffer_set_loops(SWIGTYPE_p_switch_buffer buffer, int loops) {
+    freeswitchPINVOKE.switch_buffer_set_loops(SWIGTYPE_p_switch_buffer.getCPtr(buffer), loops);
+  }
 
-namespace FreeSWITCH.Native {
+  public static SWIGTYPE_p_switch_size_t switch_buffer_write(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_write(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static SWIGTYPE_p_switch_size_t switch_buffer_toss(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_switch_size_t datalen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_toss(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-public class switch_core_session_message : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_buffer_zero(SWIGTYPE_p_switch_buffer buffer) {
+    freeswitchPINVOKE.switch_buffer_zero(SWIGTYPE_p_switch_buffer.getCPtr(buffer));
+  }
 
-  internal switch_core_session_message(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static void switch_buffer_destroy(SWIGTYPE_p_p_switch_buffer buffer) {
+    freeswitchPINVOKE.switch_buffer_destroy(SWIGTYPE_p_p_switch_buffer.getCPtr(buffer));
   }
 
-  internal static HandleRef getCPtr(switch_core_session_message obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static SWIGTYPE_p_switch_size_t switch_buffer_zwrite(SWIGTYPE_p_switch_buffer buffer, SWIGTYPE_p_void data, SWIGTYPE_p_switch_size_t datalen) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_buffer_zwrite(SWIGTYPE_p_switch_buffer.getCPtr(buffer), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_switch_size_t.getCPtr(datalen)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  ~switch_core_session_message() {
-    Dispose();
+  public static switch_status_t switch_event_init(SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_core_session_message(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_event_shutdown() {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_shutdown();
+    return ret;
   }
 
-  public string from {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_from_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_core_session_message_from_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_event_create_subclass(SWIGTYPE_p_p_switch_event arg0, switch_event_types_t event_id, string subclass_name) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_create_subclass(SWIGTYPE_p_p_switch_event.getCPtr(arg0), (int)event_id, subclass_name);
+    return ret;
   }
 
-  public switch_core_session_message_types_t message_id {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_message_id_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_core_session_message_types_t ret = (switch_core_session_message_types_t)freeswitchPINVOKE.switch_core_session_message_message_id_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_event_set_priority(switch_event arg0, switch_priority_t priority) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_set_priority(switch_event.getCPtr(arg0), (int)priority);
+    return ret;
   }
 
-  public int numeric_arg {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_numeric_arg_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_core_session_message_numeric_arg_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_event_get_header(switch_event arg0, string header_name) {
+    string ret = freeswitchPINVOKE.switch_event_get_header(switch_event.getCPtr(arg0), header_name);
+    return ret;
   }
 
-  public string string_arg {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_string_arg_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_core_session_message_string_arg_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_event_get_body(switch_event arg0) {
+    string ret = freeswitchPINVOKE.switch_event_get_body(switch_event.getCPtr(arg0));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t string_arg_size {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_string_arg_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_string_arg_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_event_add_header_string(switch_event arg0, switch_stack_t stack, string header_name, string data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_add_header_string(switch_event.getCPtr(arg0), (int)stack, header_name, data);
+    return ret;
   }
 
-  public SWIGTYPE_p_void pointer_arg {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_pointer_arg_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_session_message_pointer_arg_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_event_del_header(switch_event arg0, string header_name) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_del_header(switch_event.getCPtr(arg0), header_name);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t pointer_arg_size {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_pointer_arg_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_pointer_arg_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static void switch_event_destroy(SWIGTYPE_p_p_switch_event arg0) {
+    freeswitchPINVOKE.switch_event_destroy(SWIGTYPE_p_p_switch_event.getCPtr(arg0));
   }
 
-  public int numeric_reply {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_numeric_reply_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_core_session_message_numeric_reply_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_event_dup(SWIGTYPE_p_p_switch_event arg0, switch_event todup) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_dup(SWIGTYPE_p_p_switch_event.getCPtr(arg0), switch_event.getCPtr(todup));
+    return ret;
   }
 
-  public string string_reply {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_string_reply_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_core_session_message_string_reply_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_event_fire_detailed(string file, string func, int line, SWIGTYPE_p_p_switch_event arg3, SWIGTYPE_p_void user_data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_fire_detailed(file, func, line, SWIGTYPE_p_p_switch_event.getCPtr(arg3), SWIGTYPE_p_void.getCPtr(user_data));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t string_reply_size {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_string_reply_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_string_reply_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_event_bind(string id, switch_event_types_t arg1, string subclass_name, SWIGTYPE_p_f_p_switch_event__void callback, SWIGTYPE_p_void user_data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_bind(id, (int)arg1, subclass_name, SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data));
+    return ret;
   }
 
-  public SWIGTYPE_p_void pointer_reply {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_pointer_reply_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_session_message_pointer_reply_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_event_bind_removable(string id, switch_event_types_t arg1, string subclass_name, SWIGTYPE_p_f_p_switch_event__void callback, SWIGTYPE_p_void user_data, SWIGTYPE_p_p_switch_event_node node) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_bind_removable(id, (int)arg1, subclass_name, SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback), SWIGTYPE_p_void.getCPtr(user_data), SWIGTYPE_p_p_switch_event_node.getCPtr(node));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t pointer_reply_size {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_pointer_reply_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_core_session_message_pointer_reply_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_event_unbind(SWIGTYPE_p_p_switch_event_node node) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_unbind(SWIGTYPE_p_p_switch_event_node.getCPtr(node));
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_core_session_message_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_session_message_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_event_unbind_callback(SWIGTYPE_p_f_p_switch_event__void callback) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_unbind_callback(SWIGTYPE_p_f_p_switch_event__void.getCPtr(callback));
+    return ret;
   }
 
-  public switch_core_session_message() : this(freeswitchPINVOKE.new_switch_core_session_message(), true) {
+  public static string switch_event_name(switch_event_types_t arg0) {
+    string ret = freeswitchPINVOKE.switch_event_name((int)arg0);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_name_event(string name, SWIGTYPE_p_switch_event_types_t type) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_name_event(name, SWIGTYPE_p_switch_event_types_t.getCPtr(type));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_event_reserve_subclass_detailed(string owner, string subclass_name) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_reserve_subclass_detailed(owner, subclass_name);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_event_free_subclass_detailed(string owner, string subclass_name) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_free_subclass_detailed(owner, subclass_name);
+    return ret;
+  }
 
-[System.Flags] public enum switch_core_session_message_flag_enum_t {
-  SCSMF_DYNAMIC = (1 << 0)
-}
+  public static switch_status_t switch_event_serialize(switch_event arg0, ref string str, switch_bool_t encode) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_serialize(switch_event.getCPtr(arg0), ref str, (int)encode);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_event_running() {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_running();
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static string switch_event_expand_headers(switch_event arg0, string arg1) {
+    string ret = freeswitchPINVOKE.switch_event_expand_headers(switch_event.getCPtr(arg0), arg1);
+    return ret;
+  }
 
-public enum switch_core_session_message_types_t {
-  SWITCH_MESSAGE_REDIRECT_AUDIO,
-  SWITCH_MESSAGE_TRANSMIT_TEXT,
-  SWITCH_MESSAGE_INDICATE_ANSWER,
-  SWITCH_MESSAGE_INDICATE_PROGRESS,
-  SWITCH_MESSAGE_INDICATE_BRIDGE,
-  SWITCH_MESSAGE_INDICATE_UNBRIDGE,
-  SWITCH_MESSAGE_INDICATE_TRANSFER,
-  SWITCH_MESSAGE_INDICATE_RINGING,
-  SWITCH_MESSAGE_INDICATE_MEDIA,
-  SWITCH_MESSAGE_INDICATE_NOMEDIA,
-  SWITCH_MESSAGE_INDICATE_HOLD,
-  SWITCH_MESSAGE_INDICATE_UNHOLD,
-  SWITCH_MESSAGE_INDICATE_REDIRECT,
-  SWITCH_MESSAGE_INDICATE_RESPOND,
-  SWITCH_MESSAGE_INDICATE_BROADCAST,
-  SWITCH_MESSAGE_INDICATE_MEDIA_REDIRECT,
-  SWITCH_MESSAGE_INDICATE_DEFLECT,
-  SWITCH_MESSAGE_INDICATE_VIDEO_REFRESH_REQ,
-  SWITCH_MESSAGE_INDICATE_DISPLAY,
-  SWITCH_MESSAGE_INDICATE_TRANSCODING_NECESSARY
-}
+  public static switch_status_t switch_event_create_pres_in_detailed(string file, string func, int line, string proto, string login, string from, string from_domain, string status, string event_type, string alt_event_type, int event_count, string unique_id, string channel_state, string answer_state, string call_direction) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_event_create_pres_in_detailed(file, func, line, proto, login, from, from_domain, status, event_type, alt_event_type, event_count, unique_id, channel_state, answer_state, call_direction);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_event_deliver(SWIGTYPE_p_p_switch_event arg0) {
+    freeswitchPINVOKE.switch_event_deliver(SWIGTYPE_p_p_switch_event.getCPtr(arg0));
+  }
 
-namespace FreeSWITCH.Native {
+  public static string switch_event_build_param_string(switch_event arg0, string prefix, SWIGTYPE_p_switch_hash vars_map) {
+    string ret = freeswitchPINVOKE.switch_event_build_param_string(switch_event.getCPtr(arg0), prefix, SWIGTYPE_p_switch_hash.getCPtr(vars_map));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_resample_create(SWIGTYPE_p_p_switch_audio_resampler_t new_resampler, int from_rate, SWIGTYPE_p_switch_size_t from_size, int to_rate, uint to_size, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_resample_create(SWIGTYPE_p_p_switch_audio_resampler_t.getCPtr(new_resampler), from_rate, SWIGTYPE_p_switch_size_t.getCPtr(from_size), to_rate, to_size, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-public class switch_core_thread_session : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_resample_destroy(SWIGTYPE_p_p_switch_audio_resampler_t resampler) {
+    freeswitchPINVOKE.switch_resample_destroy(SWIGTYPE_p_p_switch_audio_resampler_t.getCPtr(resampler));
+  }
 
-  internal switch_core_thread_session(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static uint switch_resample_process(switch_audio_resampler_t resampler, SWIGTYPE_p_float src, int srclen, SWIGTYPE_p_float dst, uint dstlen, int last) {
+    uint ret = freeswitchPINVOKE.switch_resample_process(switch_audio_resampler_t.getCPtr(resampler), SWIGTYPE_p_float.getCPtr(src), srclen, SWIGTYPE_p_float.getCPtr(dst), dstlen, last);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_core_thread_session obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static SWIGTYPE_p_switch_size_t switch_float_to_short(SWIGTYPE_p_float f, SWIGTYPE_p_short s, SWIGTYPE_p_switch_size_t len) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_float_to_short(SWIGTYPE_p_float.getCPtr(f), SWIGTYPE_p_short.getCPtr(s), SWIGTYPE_p_switch_size_t.getCPtr(len)), true);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  ~switch_core_thread_session() {
-    Dispose();
+  public static int switch_char_to_float(string c, SWIGTYPE_p_float f, int len) {
+    int ret = freeswitchPINVOKE.switch_char_to_float(c, SWIGTYPE_p_float.getCPtr(f), len);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_core_thread_session(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static int switch_float_to_char(SWIGTYPE_p_float f, string c, int len) {
+    int ret = freeswitchPINVOKE.switch_float_to_char(SWIGTYPE_p_float.getCPtr(f), c, len);
+    return ret;
   }
 
-  public int running {
-    set {
-      freeswitchPINVOKE.switch_core_thread_session_running_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_core_thread_session_running_get(swigCPtr);
-      return ret;
-    } 
+  public static int switch_short_to_float(SWIGTYPE_p_short s, SWIGTYPE_p_float f, int len) {
+    int ret = freeswitchPINVOKE.switch_short_to_float(SWIGTYPE_p_short.getCPtr(s), SWIGTYPE_p_float.getCPtr(f), len);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_mutex_t mutex {
-    set {
-      freeswitchPINVOKE.switch_core_thread_session_mutex_set(swigCPtr, SWIGTYPE_p_switch_mutex_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_mutex_get(swigCPtr);
-      SWIGTYPE_p_switch_mutex_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_mutex_t(cPtr, false);
-      return ret;
-    } 
+  public static void switch_swap_linear(SWIGTYPE_p_short buf, int len) {
+    freeswitchPINVOKE.switch_swap_linear(SWIGTYPE_p_short.getCPtr(buf), len);
   }
 
-  public SWIGTYPE_p_p_void objs {
-    set {
-      freeswitchPINVOKE.switch_core_thread_session_objs_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_objs_get(swigCPtr);
-      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
-      return ret;
-    } 
+  public static void switch_generate_sln_silence(SWIGTYPE_p_short data, uint samples, uint divisor) {
+    freeswitchPINVOKE.switch_generate_sln_silence(SWIGTYPE_p_short.getCPtr(data), samples, divisor);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t input_callback {
-    set {
-      freeswitchPINVOKE.switch_core_thread_session_input_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_input_callback_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static void switch_change_sln_volume(SWIGTYPE_p_short data, uint samples, int vol) {
+    freeswitchPINVOKE.switch_change_sln_volume(SWIGTYPE_p_short.getCPtr(data), samples, vol);
   }
 
-  public SWIGTYPE_p_apr_pool_t pool {
-    set {
-      freeswitchPINVOKE.switch_core_thread_session_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_core_thread_session_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_merge_sln(SWIGTYPE_p_short data, uint samples, SWIGTYPE_p_short other_data, uint other_samples) {
+    uint ret = freeswitchPINVOKE.switch_merge_sln(SWIGTYPE_p_short.getCPtr(data), samples, SWIGTYPE_p_short.getCPtr(other_data), other_samples);
+    return ret;
   }
 
-  public switch_core_thread_session() : this(freeswitchPINVOKE.new_switch_core_thread_session(), true) {
+  public static switch_status_t switch_ivr_deactivate_unicast(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_deactivate_unicast(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-}
+  public static switch_status_t switch_ivr_activate_unicast(SWIGTYPE_p_switch_core_session session, string local_ip, ushort local_port, string remote_ip, ushort remote_port, string transport, string flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_activate_unicast(SWIGTYPE_p_switch_core_session.getCPtr(session), local_ip, local_port, remote_ip, remote_port, transport, flags);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_generate_xml_cdr(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_xml xml_cdr) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_generate_xml_cdr(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_xml.getCPtr(xml_cdr));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static int switch_ivr_set_xml_profile_data(switch_xml xml, switch_caller_profile caller_profile, int off) {
+    int ret = freeswitchPINVOKE.switch_ivr_set_xml_profile_data(switch_xml.getCPtr(xml), switch_caller_profile.getCPtr(caller_profile), off);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static int switch_ivr_set_xml_chan_vars(switch_xml xml, SWIGTYPE_p_switch_channel channel, int off) {
+    int ret = freeswitchPINVOKE.switch_ivr_set_xml_chan_vars(switch_xml.getCPtr(xml), SWIGTYPE_p_switch_channel.getCPtr(channel), off);
+    return ret;
+  }
 
-public class switch_core_time_duration : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_ivr_parse_event(SWIGTYPE_p_switch_core_session session, switch_event arg1) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_event(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_event.getCPtr(arg1));
+    return ret;
+  }
 
-  internal switch_core_time_duration(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_ivr_parse_all_events(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_all_events(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_core_time_duration obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_ivr_parse_next_event(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_parse_next_event(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  ~switch_core_time_duration() {
-    Dispose();
+  public static switch_status_t switch_ivr_sleep(SWIGTYPE_p_switch_core_session session, uint ms, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_sleep(SWIGTYPE_p_switch_core_session.getCPtr(session), ms, switch_input_args_t.getCPtr(args));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_core_time_duration(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_ivr_park(SWIGTYPE_p_switch_core_session session, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_park(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_input_args_t.getCPtr(args));
+    return ret;
   }
 
-  public uint mms {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_mms_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_mms_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_collect_digits_callback(SWIGTYPE_p_switch_core_session session, switch_input_args_t args, uint timeout) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_collect_digits_callback(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_input_args_t.getCPtr(args), timeout);
+    return ret;
   }
 
-  public uint ms {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_ms_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_ms_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_collect_digits_count(SWIGTYPE_p_switch_core_session session, string buf, SWIGTYPE_p_switch_size_t buflen, SWIGTYPE_p_switch_size_t maxdigits, string terminators, string terminator, uint first_timeout, uint digit_timeout, uint abs_timeout) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_collect_digits_count(SWIGTYPE_p_switch_core_session.getCPtr(session), buf, SWIGTYPE_p_switch_size_t.getCPtr(buflen), SWIGTYPE_p_switch_size_t.getCPtr(maxdigits), terminators, terminator, first_timeout, digit_timeout, abs_timeout);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public uint sec {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_sec_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_sec_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_detect_speech(SWIGTYPE_p_switch_core_session session, string mod_name, string grammar, string path, string dest, switch_asr_handle ah) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session), mod_name, grammar, path, dest, switch_asr_handle.getCPtr(ah));
+    return ret;
   }
 
-  public uint min {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_min_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_min_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_stop_detect_speech(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public uint hr {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_hr_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_hr_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_pause_detect_speech(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_pause_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public uint day {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_day_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_day_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_resume_detect_speech(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_resume_detect_speech(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public uint yr {
-    set {
-      freeswitchPINVOKE.switch_core_time_duration_yr_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_core_time_duration_yr_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_detect_speech_load_grammar(SWIGTYPE_p_switch_core_session session, string grammar, string path) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech_load_grammar(SWIGTYPE_p_switch_core_session.getCPtr(session), grammar, path);
+    return ret;
   }
 
-  public switch_core_time_duration() : this(freeswitchPINVOKE.new_switch_core_time_duration(), true) {
+  public static switch_status_t switch_ivr_detect_speech_unload_grammar(SWIGTYPE_p_switch_core_session session, string grammar) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_detect_speech_unload_grammar(SWIGTYPE_p_switch_core_session.getCPtr(session), grammar);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_ivr_record_session(SWIGTYPE_p_switch_core_session session, string file, uint limit, switch_file_handle fh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_record_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file, limit, switch_file_handle.getCPtr(fh));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_eavesdrop_session(SWIGTYPE_p_switch_core_session session, string uuid, string require_group, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_eavesdrop_session(SWIGTYPE_p_switch_core_session.getCPtr(session), uuid, require_group, flags);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_ivr_displace_session(SWIGTYPE_p_switch_core_session session, string file, uint limit, string flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_displace_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file, limit, flags);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_ivr_stop_displace_session(SWIGTYPE_p_switch_core_session session, string file) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_displace_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file);
+    return ret;
+  }
 
-public class switch_dialplan_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_ivr_stop_record_session(SWIGTYPE_p_switch_core_session session, string file) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_record_session(SWIGTYPE_p_switch_core_session.getCPtr(session), file);
+    return ret;
+  }
 
-  internal switch_dialplan_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_ivr_inband_dtmf_session(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_inband_dtmf_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_dialplan_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_ivr_stop_inband_dtmf_session(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_inband_dtmf_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  ~switch_dialplan_interface() {
-    Dispose();
+  public static switch_status_t switch_ivr_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session session, switch_bool_t read_stream) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session.getCPtr(session), (int)read_stream);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_dialplan_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_ivr_stop_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_inband_dtmf_generate_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_dialplan_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_dialplan_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_ivr_session_echo(SWIGTYPE_p_switch_core_session session, switch_input_args_t args) {
+    freeswitchPINVOKE.switch_ivr_session_echo(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_input_args_t.getCPtr(args));
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension hunt_function {
-    set {
-      freeswitchPINVOKE.switch_dialplan_interface_hunt_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_hunt_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_stop_tone_detect_session(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_stop_tone_detect_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_dialplan_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_tone_detect_session(SWIGTYPE_p_switch_core_session session, string key, string tone_spec, string flags, SWIGTYPE_p_time_t timeout, string app, string data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_tone_detect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), key, tone_spec, flags, SWIGTYPE_p_time_t.getCPtr(timeout), app, data);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public switch_dialplan_interface next {
-    set {
-      freeswitchPINVOKE.switch_dialplan_interface_next_set(swigCPtr, switch_dialplan_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_dialplan_interface_next_get(swigCPtr);
-      switch_dialplan_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_dialplan_interface(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_play_file(SWIGTYPE_p_switch_core_session session, switch_file_handle fh, string file, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_play_file(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_file_handle.getCPtr(fh), file, switch_input_args_t.getCPtr(args));
+    return ret;
   }
 
-  public switch_dialplan_interface() : this(freeswitchPINVOKE.new_switch_dialplan_interface(), true) {
+  public static switch_status_t switch_ivr_wait_for_silence(SWIGTYPE_p_switch_core_session session, uint thresh, uint silence_hits, uint listen_hits, uint timeout_ms, string file) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_wait_for_silence(SWIGTYPE_p_switch_core_session.getCPtr(session), thresh, silence_hits, listen_hits, timeout_ms, file);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_ivr_gentones(SWIGTYPE_p_switch_core_session session, string script, int loops, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_gentones(SWIGTYPE_p_switch_core_session.getCPtr(session), script, loops, switch_input_args_t.getCPtr(args));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_record_file(SWIGTYPE_p_switch_core_session session, switch_file_handle fh, string file, switch_input_args_t args, uint limit) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_record_file(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_file_handle.getCPtr(fh), file, switch_input_args_t.getCPtr(args), limit);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_play_and_get_digits(SWIGTYPE_p_switch_core_session session, uint min_digits, uint max_digits, uint max_tries, uint timeout, string valid_terminators, string audio_file, string bad_input_audio_file, SWIGTYPE_p_void digit_buffer, uint digit_buffer_length, string digits_regex) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_play_and_get_digits(SWIGTYPE_p_switch_core_session.getCPtr(session), min_digits, max_digits, max_tries, timeout, valid_terminators, audio_file, bad_input_audio_file, SWIGTYPE_p_void.getCPtr(digit_buffer), digit_buffer_length, digits_regex);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_ivr_speak_text_handle(SWIGTYPE_p_switch_core_session session, switch_speech_handle sh, switch_codec codec, switch_timer timer, string text, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_speak_text_handle(SWIGTYPE_p_switch_core_session.getCPtr(session), switch_speech_handle.getCPtr(sh), switch_codec.getCPtr(codec), switch_timer.getCPtr(timer), text, switch_input_args_t.getCPtr(args));
+    return ret;
+  }
 
-public class switch_directories : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_ivr_clear_speech_cache(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_ivr_clear_speech_cache(SWIGTYPE_p_switch_core_session.getCPtr(session));
+  }
 
-  internal switch_directories(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_ivr_speak_text(SWIGTYPE_p_switch_core_session session, string tts_name, string voice_name, string text, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_speak_text(SWIGTYPE_p_switch_core_session.getCPtr(session), tts_name, voice_name, text, switch_input_args_t.getCPtr(args));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_directories obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_ivr_originate(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_p_switch_core_session bleg, SWIGTYPE_p_switch_call_cause_t cause, string bridgeto, uint timelimit_sec, switch_state_handler_table table, string cid_name_override, string cid_num_override, switch_caller_profile caller_profile_override, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_originate(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_p_switch_core_session.getCPtr(bleg), SWIGTYPE_p_switch_call_cause_t.getCPtr(cause), bridgeto, timelimit_sec, switch_state_handler_table.getCPtr(table), cid_name_override, cid_num_override, switch_caller_profile.getCPtr(caller_profile_override), flags);
+    return ret;
   }
 
-  ~switch_directories() {
-    Dispose();
+  public static switch_status_t switch_ivr_multi_threaded_bridge(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t dtmf_callback, SWIGTYPE_p_void session_data, SWIGTYPE_p_void peer_session_data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_multi_threaded_bridge(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session), SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(dtmf_callback), SWIGTYPE_p_void.getCPtr(session_data), SWIGTYPE_p_void.getCPtr(peer_session_data));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_directories(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_ivr_signal_bridge(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_signal_bridge(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session));
+    return ret;
   }
 
-  public string base_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_base_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_base_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_session_transfer(SWIGTYPE_p_switch_core_session session, string extension, string dialplan, string context) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_session_transfer(SWIGTYPE_p_switch_core_session.getCPtr(session), extension, dialplan, context);
+    return ret;
   }
 
-  public string mod_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_mod_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_mod_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_ivr_schedule_transfer(SWIGTYPE_p_time_t runtime, string uuid, string extension, string dialplan, string context) {
+    uint ret = freeswitchPINVOKE.switch_ivr_schedule_transfer(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, extension, dialplan, context);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public string conf_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_conf_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_conf_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_ivr_schedule_hangup(SWIGTYPE_p_time_t runtime, string uuid, switch_call_cause_t cause, switch_bool_t bleg) {
+    uint ret = freeswitchPINVOKE.switch_ivr_schedule_hangup(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, (int)cause, (int)bleg);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public string log_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_log_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_log_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_uuid_bridge(string originator_uuid, string originatee_uuid) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_uuid_bridge(originator_uuid, originatee_uuid);
+    return ret;
   }
 
-  public string db_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_db_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_db_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_media(string uuid, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_media(uuid, flags);
+    return ret;
   }
 
-  public string script_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_script_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_script_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_nomedia(string uuid, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_nomedia(uuid, flags);
+    return ret;
   }
 
-  public string temp_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_temp_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_temp_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_hold_uuid(string uuid, string message, switch_bool_t moh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_hold_uuid(uuid, message, (int)moh);
+    return ret;
   }
 
-  public string htdocs_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_htdocs_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_htdocs_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_unhold_uuid(string uuid) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unhold_uuid(uuid);
+    return ret;
   }
 
-  public string grammar_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_grammar_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_grammar_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_hold(SWIGTYPE_p_switch_core_session session, string message, switch_bool_t moh) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_hold(SWIGTYPE_p_switch_core_session.getCPtr(session), message, (int)moh);
+    return ret;
   }
 
-  public string storage_dir {
-    set {
-      freeswitchPINVOKE.switch_directories_storage_dir_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directories_storage_dir_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_unhold(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unhold(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public switch_directories() : this(freeswitchPINVOKE.new_switch_directories(), true) {
+  public static uint switch_ivr_schedule_broadcast(SWIGTYPE_p_time_t runtime, string uuid, string path, uint flags) {
+    uint ret = freeswitchPINVOKE.switch_ivr_schedule_broadcast(SWIGTYPE_p_time_t.getCPtr(runtime), uuid, path, flags);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-}
+  public static switch_status_t switch_ivr_broadcast(string uuid, string path, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_broadcast(uuid, path, flags);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_transfer_variable(SWIGTYPE_p_switch_core_session sessa, SWIGTYPE_p_switch_core_session sessb, string var) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_transfer_variable(SWIGTYPE_p_switch_core_session.getCPtr(sessa), SWIGTYPE_p_switch_core_session.getCPtr(sessb), var);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_ivr_digit_stream_parser_new(SWIGTYPE_p_apr_pool_t pool, SWIGTYPE_p_p_switch_ivr_digit_stream_parser parser) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_new(SWIGTYPE_p_apr_pool_t.getCPtr(pool), SWIGTYPE_p_p_switch_ivr_digit_stream_parser.getCPtr(parser));
+    return ret;
+  }
 
-[System.Flags] public enum switch_directory_flag_enum_t {
-  SWITCH_DIRECTORY_FLAG_FREE_POOL = (1 << 0)
-}
+  public static switch_status_t switch_ivr_digit_stream_parser_destroy(SWIGTYPE_p_switch_ivr_digit_stream_parser parser) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_destroy(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_digit_stream_new(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, SWIGTYPE_p_p_switch_ivr_digit_stream stream) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_new(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), SWIGTYPE_p_p_switch_ivr_digit_stream.getCPtr(stream));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_ivr_digit_stream_destroy(SWIGTYPE_p_switch_ivr_digit_stream stream) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_destroy(SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_ivr_digit_stream_parser_set_event(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, string digits, SWIGTYPE_p_void data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_set_event(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digits, SWIGTYPE_p_void.getCPtr(data));
+    return ret;
+  }
 
-public class switch_directory_handle : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_ivr_digit_stream_parser_del_event(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, string digits) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_del_event(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digits);
+    return ret;
+  }
 
-  internal switch_directory_handle(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static SWIGTYPE_p_void switch_ivr_digit_stream_parser_feed(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, SWIGTYPE_p_switch_ivr_digit_stream stream, char digit) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_ivr_digit_stream_parser_feed(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream), digit);
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_directory_handle obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_ivr_digit_stream_reset(SWIGTYPE_p_switch_ivr_digit_stream stream) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_reset(SWIGTYPE_p_switch_ivr_digit_stream.getCPtr(stream));
+    return ret;
   }
 
-  ~switch_directory_handle() {
-    Dispose();
+  public static switch_status_t switch_ivr_digit_stream_parser_set_terminator(SWIGTYPE_p_switch_ivr_digit_stream_parser parser, char digit) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_digit_stream_parser_set_terminator(SWIGTYPE_p_switch_ivr_digit_stream_parser.getCPtr(parser), digit);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_directory_handle(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_ivr_menu_init(SWIGTYPE_p_p_switch_ivr_menu new_menu, SWIGTYPE_p_switch_ivr_menu main, string name, string greeting_sound, string short_greeting_sound, string invalid_sound, string exit_sound, string confirm_macro, string confirm_key, int confirm_attempts, int inter_timeout, int digit_len, int timeout, int max_failures, int max_timeouts, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_init(SWIGTYPE_p_p_switch_ivr_menu.getCPtr(new_menu), SWIGTYPE_p_switch_ivr_menu.getCPtr(main), name, greeting_sound, short_greeting_sound, invalid_sound, exit_sound, confirm_macro, confirm_key, confirm_attempts, inter_timeout, digit_len, timeout, max_failures, max_timeouts, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
   }
 
-  public switch_directory_interface directory_interface {
-    set {
-      freeswitchPINVOKE.switch_directory_handle_directory_interface_set(swigCPtr, switch_directory_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_directory_interface_get(swigCPtr);
-      switch_directory_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_directory_interface(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_menu_bind_action(SWIGTYPE_p_switch_ivr_menu menu, switch_ivr_action_t ivr_action, string arg, string bind) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_bind_action(SWIGTYPE_p_switch_ivr_menu.getCPtr(menu), (int)ivr_action, arg, bind);
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_directory_handle_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_directory_handle_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_menu_bind_function(SWIGTYPE_p_switch_ivr_menu menu, SWIGTYPE_p_switch_ivr_menu_action_function_t function, string arg, string bind) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_bind_function(SWIGTYPE_p_switch_ivr_menu.getCPtr(menu), SWIGTYPE_p_switch_ivr_menu_action_function_t.getCPtr(function), arg, bind);
+    return ret;
   }
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_directory_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_menu_execute(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_ivr_menu stack, string name, SWIGTYPE_p_void obj) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_execute(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_ivr_menu.getCPtr(stack), name, SWIGTYPE_p_void.getCPtr(obj));
+    return ret;
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_directory_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_handle_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_menu_stack_free(SWIGTYPE_p_switch_ivr_menu stack) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_free(SWIGTYPE_p_switch_ivr_menu.getCPtr(stack));
+    return ret;
   }
 
-  public switch_directory_handle() : this(freeswitchPINVOKE.new_switch_directory_handle(), true) {
+  public static switch_status_t switch_ivr_menu_stack_xml_build(SWIGTYPE_p_switch_ivr_menu_xml_ctx xml_menu_ctx, SWIGTYPE_p_p_switch_ivr_menu menu_stack, switch_xml xml_menus, switch_xml xml_menu) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_build(SWIGTYPE_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), SWIGTYPE_p_p_switch_ivr_menu.getCPtr(menu_stack), switch_xml.getCPtr(xml_menus), switch_xml.getCPtr(xml_menu));
+    return ret;
   }
 
-}
+  public static switch_status_t switch_ivr_menu_str2action(string action_name, SWIGTYPE_p_switch_ivr_action_t action) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_str2action(action_name, SWIGTYPE_p_switch_ivr_action_t.getCPtr(action));
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_ivr_menu_stack_xml_add_custom(SWIGTYPE_p_switch_ivr_menu_xml_ctx xml_menu_ctx, string name, SWIGTYPE_p_switch_ivr_menu_action_function_t function) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_add_custom(SWIGTYPE_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), name, SWIGTYPE_p_switch_ivr_menu_action_function_t.getCPtr(function));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_ivr_menu_stack_xml_init(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx xml_menu_ctx, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_menu_stack_xml_init(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx.getCPtr(xml_menu_ctx), SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_ivr_phrase_macro(SWIGTYPE_p_switch_core_session session, string macro_name, string data, string lang, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_phrase_macro(SWIGTYPE_p_switch_core_session.getCPtr(session), macro_name, data, lang, switch_input_args_t.getCPtr(args));
+    return ret;
+  }
 
-public class switch_directory_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_ivr_delay_echo(SWIGTYPE_p_switch_core_session session, uint delay_ms) {
+    freeswitchPINVOKE.switch_ivr_delay_echo(SWIGTYPE_p_switch_core_session.getCPtr(session), delay_ms);
+  }
 
-  internal switch_directory_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_ivr_find_bridged_uuid(string uuid, string b_uuid, SWIGTYPE_p_switch_size_t blen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_find_bridged_uuid(uuid, b_uuid, SWIGTYPE_p_switch_size_t.getCPtr(blen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_directory_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_ivr_intercept_session(SWIGTYPE_p_switch_core_session session, string uuid, switch_bool_t bleg) {
+    freeswitchPINVOKE.switch_ivr_intercept_session(SWIGTYPE_p_switch_core_session.getCPtr(session), uuid, (int)bleg);
   }
 
-  ~switch_directory_interface() {
-    Dispose();
+  public static void switch_ivr_park_session(SWIGTYPE_p_switch_core_session session) {
+    freeswitchPINVOKE.switch_ivr_park_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_directory_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_status_t switch_ivr_wait_for_answer(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_switch_core_session peer_session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_wait_for_answer(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_switch_core_session.getCPtr(peer_session));
+    return ret;
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_directory_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_read(SWIGTYPE_p_switch_core_session session, uint min_digits, uint max_digits, string prompt_audio_file, string var_name, string digit_buffer, SWIGTYPE_p_switch_size_t digit_buffer_length, uint timeout, string valid_terminators) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_read(SWIGTYPE_p_switch_core_session.getCPtr(session), min_digits, max_digits, prompt_audio_file, var_name, digit_buffer, SWIGTYPE_p_switch_size_t.getCPtr(digit_buffer_length), timeout, valid_terminators);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t directory_open {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_directory_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_open_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_bind_dtmf_meta_session(SWIGTYPE_p_switch_core_session session, uint key, uint bind_flags, string app) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_bind_dtmf_meta_session(SWIGTYPE_p_switch_core_session.getCPtr(session), key, bind_flags, app);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t directory_close {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_directory_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_close_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_unbind_dtmf_meta_session(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_unbind_dtmf_meta_session(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t directory_query {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_directory_query_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_query_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_soft_hold(SWIGTYPE_p_switch_core_session session, string unhold_key, string moh_a, string moh_b) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_soft_hold(SWIGTYPE_p_switch_core_session.getCPtr(session), unhold_key, moh_a, moh_b);
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t directory_next {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_directory_next_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_next_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_say(SWIGTYPE_p_switch_core_session session, string tosay, string module_name, string say_type, string say_method, switch_input_args_t args) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_say(SWIGTYPE_p_switch_core_session.getCPtr(session), tosay, module_name, say_type, say_method, switch_input_args_t.getCPtr(args));
+    return ret;
   }
 
-  public SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t directory_next_pair {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_directory_next_pair_set(swigCPtr, SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_directory_next_pair_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_say_method_t switch_ivr_get_say_method_by_name(string name) {
+    switch_say_method_t ret = (switch_say_method_t)freeswitchPINVOKE.switch_ivr_get_say_method_by_name(name);
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_say_type_t switch_ivr_get_say_type_by_name(string name) {
+    switch_say_type_t ret = (switch_say_type_t)freeswitchPINVOKE.switch_ivr_get_say_type_by_name(name);
+    return ret;
   }
 
-  public switch_directory_interface next {
-    set {
-      freeswitchPINVOKE.switch_directory_interface_next_set(swigCPtr, switch_directory_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_directory_interface_next_get(swigCPtr);
-      switch_directory_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_directory_interface(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_ivr_set_user(SWIGTYPE_p_switch_core_session session, string data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_ivr_set_user(SWIGTYPE_p_switch_core_session.getCPtr(session), data);
+    return ret;
   }
 
-  public switch_directory_interface() : this(freeswitchPINVOKE.new_switch_directory_interface(), true) {
+  public static switch_status_t switch_rtp_add_crypto_key(SWIGTYPE_p_switch_rtp rtp_session, switch_rtp_crypto_direction_t direction, uint index, switch_rtp_crypto_key_type_t type, SWIGTYPE_p_unsigned_char key, SWIGTYPE_p_switch_size_t keylen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_add_crypto_key(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), (int)direction, index, (int)type, SWIGTYPE_p_unsigned_char.getCPtr(key), SWIGTYPE_p_switch_size_t.getCPtr(keylen));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-}
+  public static void switch_rtp_get_random(SWIGTYPE_p_void buf, uint len) {
+    freeswitchPINVOKE.switch_rtp_get_random(SWIGTYPE_p_void.getCPtr(buf), len);
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static void switch_rtp_init(SWIGTYPE_p_apr_pool_t pool) {
+    freeswitchPINVOKE.switch_rtp_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_rtp_shutdown() {
+    freeswitchPINVOKE.switch_rtp_shutdown();
+  }
 
-public enum switch_dtmf_direction_t {
-  SWITCH_DTMF_RECV = 0,
-  SWITCH_DTMF_SEND = 1
-}
+  public static ushort switch_rtp_set_start_port(ushort port) {
+    ushort ret = freeswitchPINVOKE.switch_rtp_set_start_port(port);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static ushort switch_rtp_set_end_port(ushort port) {
+    ushort ret = freeswitchPINVOKE.switch_rtp_set_end_port(port);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static ushort switch_rtp_request_port(string ip) {
+    ushort ret = freeswitchPINVOKE.switch_rtp_request_port(ip);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static void switch_rtp_release_port(string ip, ushort port) {
+    freeswitchPINVOKE.switch_rtp_release_port(ip, port);
+  }
 
-public class switch_dtmf_t : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_status_t switch_rtp_create(SWIGTYPE_p_p_switch_rtp new_rtp_session, byte payload, uint samples_per_interval, uint ms_per_packet, uint flags, string timer_name, ref string err, SWIGTYPE_p_apr_pool_t pool) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_create(SWIGTYPE_p_p_switch_rtp.getCPtr(new_rtp_session), payload, samples_per_interval, ms_per_packet, flags, timer_name, ref err, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    return ret;
+  }
 
-  internal switch_dtmf_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static SWIGTYPE_p_switch_rtp switch_rtp_new(string rx_host, ushort rx_port, string tx_host, ushort tx_port, byte payload, uint samples_per_interval, uint ms_per_packet, uint flags, string timer_name, ref string err, SWIGTYPE_p_apr_pool_t pool) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_new(rx_host, rx_port, tx_host, tx_port, payload, samples_per_interval, ms_per_packet, flags, timer_name, ref err, SWIGTYPE_p_apr_pool_t.getCPtr(pool));
+    SWIGTYPE_p_switch_rtp ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_rtp(cPtr, false);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_dtmf_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_rtp_set_remote_address(SWIGTYPE_p_switch_rtp rtp_session, string host, ushort port, switch_bool_t change_adv_addr, ref string err) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_set_remote_address(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), host, port, (int)change_adv_addr, ref err);
+    return ret;
   }
 
-  ~switch_dtmf_t() {
-    Dispose();
+  public static string switch_rtp_get_remote_host(SWIGTYPE_p_switch_rtp rtp_session) {
+    string ret = freeswitchPINVOKE.switch_rtp_get_remote_host(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_dtmf_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static ushort switch_rtp_get_remote_port(SWIGTYPE_p_switch_rtp rtp_session) {
+    ushort ret = freeswitchPINVOKE.switch_rtp_get_remote_port(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
   }
 
-  public char digit {
-    set {
-      freeswitchPINVOKE.switch_dtmf_t_digit_set(swigCPtr, value);
-    } 
-    get {
-      char ret = freeswitchPINVOKE.switch_dtmf_t_digit_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_rtp_set_max_missed_packets(SWIGTYPE_p_switch_rtp rtp_session, uint max) {
+    freeswitchPINVOKE.switch_rtp_set_max_missed_packets(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), max);
   }
 
-  public uint duration {
-    set {
-      freeswitchPINVOKE.switch_dtmf_t_duration_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_dtmf_t_duration_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_rtp_set_local_address(SWIGTYPE_p_switch_rtp rtp_session, string host, ushort port, ref string err) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_set_local_address(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), host, port, ref err);
+    return ret;
   }
 
-  public switch_dtmf_t() : this(freeswitchPINVOKE.new_switch_dtmf_t(), true) {
+  public static void switch_rtp_kill_socket(SWIGTYPE_p_switch_rtp rtp_session) {
+    freeswitchPINVOKE.switch_rtp_kill_socket(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
   }
 
-}
+  public static void switch_rtp_break(SWIGTYPE_p_switch_rtp rtp_session) {
+    freeswitchPINVOKE.switch_rtp_break(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static byte switch_rtp_ready(SWIGTYPE_p_switch_rtp rtp_session) {
+    byte ret = freeswitchPINVOKE.switch_rtp_ready(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_rtp_destroy(SWIGTYPE_p_p_switch_rtp rtp_session) {
+    freeswitchPINVOKE.switch_rtp_destroy(SWIGTYPE_p_p_switch_rtp.getCPtr(rtp_session));
+  }
 
-[System.Flags] public enum switch_eavesdrop_flag_enum_t {
-  ED_MUX_READ = (1 << 0),
-  ED_MUX_WRITE = (1 << 1),
-  ED_DTMF = (1 << 2)
-}
+  public static switch_status_t switch_rtp_activate_ice(SWIGTYPE_p_switch_rtp rtp_session, string login, string rlogin) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_ice(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), login, rlogin);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_rtp_activate_jitter_buffer(SWIGTYPE_p_switch_rtp rtp_session, uint queue_frames) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_jitter_buffer(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), queue_frames);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static void switch_rtp_set_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
+    freeswitchPINVOKE.switch_rtp_set_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static uint switch_rtp_test_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
+    uint ret = freeswitchPINVOKE.switch_rtp_test_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
+    return ret;
+  }
 
-public class switch_endpoint_interface : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static void switch_rtp_clear_flag(SWIGTYPE_p_switch_rtp rtp_session, uint flags) {
+    freeswitchPINVOKE.switch_rtp_clear_flag(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), flags);
+  }
 
-  internal switch_endpoint_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static SWIGTYPE_p_switch_socket_t switch_rtp_get_rtp_socket(SWIGTYPE_p_switch_rtp rtp_session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_get_rtp_socket(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    SWIGTYPE_p_switch_socket_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_socket_t(cPtr, false);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_endpoint_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static void switch_rtp_set_default_samples_per_interval(SWIGTYPE_p_switch_rtp rtp_session, ushort samples_per_interval) {
+    freeswitchPINVOKE.switch_rtp_set_default_samples_per_interval(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), samples_per_interval);
   }
 
-  ~switch_endpoint_interface() {
-    Dispose();
+  public static uint switch_rtp_get_default_samples_per_interval(SWIGTYPE_p_switch_rtp rtp_session) {
+    uint ret = freeswitchPINVOKE.switch_rtp_get_default_samples_per_interval(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_endpoint_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static void switch_rtp_set_default_payload(SWIGTYPE_p_switch_rtp rtp_session, byte payload) {
+    freeswitchPINVOKE.switch_rtp_set_default_payload(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), payload);
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_endpoint_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_rtp_get_default_payload(SWIGTYPE_p_switch_rtp rtp_session) {
+    uint ret = freeswitchPINVOKE.switch_rtp_get_default_payload(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
   }
 
-  public switch_io_routines io_routines {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_io_routines_set(swigCPtr, switch_io_routines.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_io_routines_get(swigCPtr);
-      switch_io_routines ret = (cPtr == IntPtr.Zero) ? null : new switch_io_routines(cPtr, false);
-      return ret;
-    } 
+  public static void switch_rtp_set_invald_handler(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void on_invalid) {
+    freeswitchPINVOKE.switch_rtp_set_invald_handler(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void.getCPtr(on_invalid));
   }
 
-  public switch_state_handler_table state_handler {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_state_handler_set(swigCPtr, switch_state_handler_table.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_state_handler_get(swigCPtr);
-      switch_state_handler_table ret = (cPtr == IntPtr.Zero) ? null : new switch_state_handler_table(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_rtp_read(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void data, SWIGTYPE_p_unsigned_long datalen, SWIGTYPE_p_unsigned_char payload_type, SWIGTYPE_p_unsigned_long flags, uint io_flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_read(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(data), SWIGTYPE_p_unsigned_long.getCPtr(datalen), SWIGTYPE_p_unsigned_char.getCPtr(payload_type), SWIGTYPE_p_unsigned_long.getCPtr(flags), io_flags);
+    return ret;
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_rtp_queue_rfc2833(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_queue_rfc2833(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_rtp_queue_rfc2833_in(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_queue_rfc2833_in(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf));
+    return ret;
   }
 
-  public switch_endpoint_interface next {
-    set {
-      freeswitchPINVOKE.switch_endpoint_interface_next_set(swigCPtr, switch_endpoint_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_endpoint_interface_next_get(swigCPtr);
-      switch_endpoint_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_endpoint_interface(cPtr, false);
-      return ret;
-    } 
+  public static SWIGTYPE_p_switch_size_t switch_rtp_has_dtmf(SWIGTYPE_p_switch_rtp rtp_session) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_has_dtmf(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session)), true);
+    return ret;
   }
 
-  public switch_endpoint_interface() : this(freeswitchPINVOKE.new_switch_endpoint_interface(), true) {
+  public static SWIGTYPE_p_switch_size_t switch_rtp_dequeue_dtmf(SWIGTYPE_p_switch_rtp rtp_session, switch_dtmf_t dtmf) {
+    SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_dequeue_dtmf(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_dtmf_t.getCPtr(dtmf)), true);
+    return ret;
   }
 
-}
+  public static switch_status_t switch_rtp_zerocopy_read(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_p_void data, SWIGTYPE_p_unsigned_long datalen, SWIGTYPE_p_unsigned_char payload_type, SWIGTYPE_p_unsigned_long flags, uint io_flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_zerocopy_read(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_p_void.getCPtr(data), SWIGTYPE_p_unsigned_long.getCPtr(datalen), SWIGTYPE_p_unsigned_char.getCPtr(payload_type), SWIGTYPE_p_unsigned_long.getCPtr(flags), io_flags);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_status_t switch_rtp_zerocopy_read_frame(SWIGTYPE_p_switch_rtp rtp_session, switch_frame frame, uint io_flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_zerocopy_read_frame(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_frame.getCPtr(frame), io_flags);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_rtp_enable_vad(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_switch_core_session session, switch_codec codec, uint flags) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_enable_vad(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_switch_core_session.getCPtr(session), switch_codec.getCPtr(codec), flags);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_rtp_disable_vad(SWIGTYPE_p_switch_rtp rtp_session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_disable_vad(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
+  }
 
-public class switch_event : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static int switch_rtp_write_frame(SWIGTYPE_p_switch_rtp rtp_session, switch_frame frame) {
+    int ret = freeswitchPINVOKE.switch_rtp_write_frame(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), switch_frame.getCPtr(frame));
+    return ret;
+  }
 
-  internal switch_event(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static int switch_rtp_write_manual(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void data, uint datalen, byte m, byte payload, uint ts, SWIGTYPE_p_unsigned_long flags) {
+    int ret = freeswitchPINVOKE.switch_rtp_write_manual(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(data), datalen, m, payload, ts, SWIGTYPE_p_unsigned_long.getCPtr(flags));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_event obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static uint switch_rtp_get_ssrc(SWIGTYPE_p_switch_rtp rtp_session) {
+    uint ret = freeswitchPINVOKE.switch_rtp_get_ssrc(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    return ret;
   }
 
-  ~switch_event() {
-    Dispose();
+  public static void switch_rtp_set_private(SWIGTYPE_p_switch_rtp rtp_session, SWIGTYPE_p_void private_data) {
+    freeswitchPINVOKE.switch_rtp_set_private(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), SWIGTYPE_p_void.getCPtr(private_data));
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_event(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static void switch_rtp_set_telephony_event(SWIGTYPE_p_switch_rtp rtp_session, byte te) {
+    freeswitchPINVOKE.switch_rtp_set_telephony_event(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), te);
   }
 
-  public switch_event_types_t event_id {
-    set {
-      freeswitchPINVOKE.switch_event_event_id_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_event_types_t ret = (switch_event_types_t)freeswitchPINVOKE.switch_event_event_id_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_rtp_set_cng_pt(SWIGTYPE_p_switch_rtp rtp_session, byte pt) {
+    freeswitchPINVOKE.switch_rtp_set_cng_pt(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), pt);
   }
 
-  public switch_priority_t priority {
-    set {
-      freeswitchPINVOKE.switch_event_priority_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_priority_t ret = (switch_priority_t)freeswitchPINVOKE.switch_event_priority_get(swigCPtr);
-      return ret;
-    } 
+  public static SWIGTYPE_p_void switch_rtp_get_private(SWIGTYPE_p_switch_rtp rtp_session) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_rtp_get_private(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session));
+    SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
+    return ret;
   }
 
-  public string owner {
-    set {
-      freeswitchPINVOKE.switch_event_owner_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_event_owner_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_rtp_activate_stun_ping(SWIGTYPE_p_switch_rtp rtp_session, string stun_ip, ushort stun_port, uint packet_count, switch_bool_t funny) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_rtp_activate_stun_ping(SWIGTYPE_p_switch_rtp.getCPtr(rtp_session), stun_ip, stun_port, packet_count, (int)funny);
+    return ret;
   }
 
-  public string subclass_name {
-    set {
-      freeswitchPINVOKE.switch_event_subclass_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_event_subclass_name_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_log_init(SWIGTYPE_p_apr_pool_t pool, switch_bool_t colorize) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool), (int)colorize);
+    return ret;
   }
 
-  public switch_event_header headers {
-    set {
-      freeswitchPINVOKE.switch_event_headers_set(swigCPtr, switch_event_header.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_headers_get(swigCPtr);
-      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_log_shutdown() {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_shutdown();
+    return ret;
   }
 
-  public switch_event_header last_header {
-    set {
-      freeswitchPINVOKE.switch_event_last_header_set(swigCPtr, switch_event_header.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_last_header_get(swigCPtr);
-      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_log_bind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t function, switch_log_level_t level, switch_bool_t is_console) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_bind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t.getCPtr(function), (int)level, (int)is_console);
+    return ret;
   }
 
-  public string body {
-    set {
-      freeswitchPINVOKE.switch_event_body_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_event_body_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_log_unbind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t function) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_log_unbind_logger(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t.getCPtr(function));
+    return ret;
   }
 
-  public SWIGTYPE_p_void bind_user_data {
-    set {
-      freeswitchPINVOKE.switch_event_bind_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_bind_user_data_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static string switch_log_level2str(switch_log_level_t level) {
+    string ret = freeswitchPINVOKE.switch_log_level2str((int)level);
+    return ret;
   }
 
-  public SWIGTYPE_p_void event_user_data {
-    set {
-      freeswitchPINVOKE.switch_event_event_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_event_user_data_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_log_level_t switch_log_str2level(string str) {
+    switch_log_level_t ret = (switch_log_level_t)freeswitchPINVOKE.switch_log_str2level(str);
+    return ret;
   }
 
-  public uint key {
-    set {
-      freeswitchPINVOKE.switch_event_key_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_event_key_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_log_str2mask(string str) {
+    uint ret = freeswitchPINVOKE.switch_log_str2mask(str);
+    return ret;
   }
 
-  public switch_event next {
-    set {
-      freeswitchPINVOKE.switch_event_next_set(swigCPtr, switch_event.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_next_get(swigCPtr);
-      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
-      return ret;
-    } 
+  public static switch_xml switch_xml_parse_str(string s, SWIGTYPE_p_switch_size_t len) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_str(s, SWIGTYPE_p_switch_size_t.getCPtr(len));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public switch_event() : this(freeswitchPINVOKE.new_switch_event(), true) {
+  public static switch_xml switch_xml_parse_fd(int fd) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_fd(fd);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
   }
 
-}
+  public static switch_xml switch_xml_parse_file(string file) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_file(file);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_xml switch_xml_parse_file_simple(string file) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_file_simple(file);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_xml switch_xml_parse_fp(SWIGTYPE_p_FILE fp) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_parse_fp(SWIGTYPE_p_FILE.getCPtr(fp));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_xml switch_xml_child(switch_xml xml, string name) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_child(switch_xml.getCPtr(xml), name);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-public class switch_event_header : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_xml switch_xml_find_child(switch_xml node, string childname, string attrname, string value) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_find_child(switch_xml.getCPtr(node), childname, attrname, value);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-  internal switch_event_header(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static string switch_xml_attr(switch_xml xml, string attr) {
+    string ret = freeswitchPINVOKE.switch_xml_attr(switch_xml.getCPtr(xml), attr);
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_event_header obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static string switch_xml_attr_soft(switch_xml xml, string attr) {
+    string ret = freeswitchPINVOKE.switch_xml_attr_soft(switch_xml.getCPtr(xml), attr);
+    return ret;
   }
 
-  ~switch_event_header() {
-    Dispose();
+  public static switch_xml switch_xml_get(switch_xml xml) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_get(switch_xml.getCPtr(xml));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_event_header(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static string switch_xml_toxml(switch_xml xml, switch_bool_t prn_header) {
+    string ret = freeswitchPINVOKE.switch_xml_toxml(switch_xml.getCPtr(xml), (int)prn_header);
+    return ret;
   }
 
-  public string name {
-    set {
-      freeswitchPINVOKE.switch_event_header_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_event_header_name_get(swigCPtr);
-      return ret;
-    } 
+  public static string switch_xml_toxml_buf(switch_xml xml, string buf, SWIGTYPE_p_switch_size_t buflen, SWIGTYPE_p_switch_size_t offset, switch_bool_t prn_header) {
+    string ret = freeswitchPINVOKE.switch_xml_toxml_buf(switch_xml.getCPtr(xml), buf, SWIGTYPE_p_switch_size_t.getCPtr(buflen), SWIGTYPE_p_switch_size_t.getCPtr(offset), (int)prn_header);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public string value {
-    set {
-      freeswitchPINVOKE.switch_event_header_value_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_event_header_value_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_xml_free(switch_xml xml) {
+    freeswitchPINVOKE.switch_xml_free(switch_xml.getCPtr(xml));
   }
 
-  public switch_event_header next {
-    set {
-      freeswitchPINVOKE.switch_event_header_next_set(swigCPtr, switch_event_header.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_event_header_next_get(swigCPtr);
-      switch_event_header ret = (cPtr == IntPtr.Zero) ? null : new switch_event_header(cPtr, false);
-      return ret;
-    } 
+  public static void switch_xml_free_in_thread(switch_xml xml, int stacksize) {
+    freeswitchPINVOKE.switch_xml_free_in_thread(switch_xml.getCPtr(xml), stacksize);
   }
 
-  public switch_event_header() : this(freeswitchPINVOKE.new_switch_event_header(), true) {
+  public static string switch_xml_error(switch_xml xml) {
+    string ret = freeswitchPINVOKE.switch_xml_error(switch_xml.getCPtr(xml));
+    return ret;
   }
 
-}
+  public static switch_xml switch_xml_new(string name) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_new(name);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_xml switch_xml_add_child(switch_xml xml, string name, SWIGTYPE_p_switch_size_t off) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_add_child(switch_xml.getCPtr(xml), name, SWIGTYPE_p_switch_size_t.getCPtr(off));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_xml switch_xml_set_txt(switch_xml xml, string txt) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_txt(switch_xml.getCPtr(xml), txt);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-public enum switch_event_types_t {
-  SWITCH_EVENT_CUSTOM,
-  SWITCH_EVENT_CHANNEL_CREATE,
-  SWITCH_EVENT_CHANNEL_DESTROY,
-  SWITCH_EVENT_CHANNEL_STATE,
-  SWITCH_EVENT_CHANNEL_ANSWER,
-  SWITCH_EVENT_CHANNEL_HANGUP,
-  SWITCH_EVENT_CHANNEL_EXECUTE,
-  SWITCH_EVENT_CHANNEL_EXECUTE_COMPLETE,
-  SWITCH_EVENT_CHANNEL_BRIDGE,
-  SWITCH_EVENT_CHANNEL_UNBRIDGE,
-  SWITCH_EVENT_CHANNEL_PROGRESS,
-  SWITCH_EVENT_CHANNEL_OUTGOING,
-  SWITCH_EVENT_CHANNEL_PARK,
-  SWITCH_EVENT_CHANNEL_UNPARK,
-  SWITCH_EVENT_CHANNEL_APPLICATION,
-  SWITCH_EVENT_CHANNEL_ORIGINATE,
-  SWITCH_EVENT_API,
-  SWITCH_EVENT_LOG,
-  SWITCH_EVENT_INBOUND_CHAN,
-  SWITCH_EVENT_OUTBOUND_CHAN,
-  SWITCH_EVENT_STARTUP,
-  SWITCH_EVENT_SHUTDOWN,
-  SWITCH_EVENT_PUBLISH,
-  SWITCH_EVENT_UNPUBLISH,
-  SWITCH_EVENT_TALK,
-  SWITCH_EVENT_NOTALK,
-  SWITCH_EVENT_SESSION_CRASH,
-  SWITCH_EVENT_MODULE_LOAD,
-  SWITCH_EVENT_MODULE_UNLOAD,
-  SWITCH_EVENT_DTMF,
-  SWITCH_EVENT_MESSAGE,
-  SWITCH_EVENT_PRESENCE_IN,
-  SWITCH_EVENT_PRESENCE_OUT,
-  SWITCH_EVENT_PRESENCE_PROBE,
-  SWITCH_EVENT_MESSAGE_WAITING,
-  SWITCH_EVENT_MESSAGE_QUERY,
-  SWITCH_EVENT_ROSTER,
-  SWITCH_EVENT_CODEC,
-  SWITCH_EVENT_BACKGROUND_JOB,
-  SWITCH_EVENT_DETECTED_SPEECH,
-  SWITCH_EVENT_DETECTED_TONE,
-  SWITCH_EVENT_PRIVATE_COMMAND,
-  SWITCH_EVENT_HEARTBEAT,
-  SWITCH_EVENT_TRAP,
-  SWITCH_EVENT_ADD_SCHEDULE,
-  SWITCH_EVENT_DEL_SCHEDULE,
-  SWITCH_EVENT_EXE_SCHEDULE,
-  SWITCH_EVENT_RE_SCHEDULE,
-  SWITCH_EVENT_RELOADXML,
-  SWITCH_EVENT_NOTIFY,
-  SWITCH_EVENT_SEND_MESSAGE,
-  SWITCH_EVENT_RECV_MESSAGE,
-  SWITCH_EVENT_ALL
-}
+  public static switch_xml switch_xml_set_attr(switch_xml xml, string name, string value) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_attr(switch_xml.getCPtr(xml), name, value);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_xml switch_xml_set_flag(switch_xml xml, switch_xml_flag_t flag) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_set_flag(switch_xml.getCPtr(xml), (int)flag);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_xml switch_xml_cut(switch_xml xml) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_cut(switch_xml.getCPtr(xml));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-[System.Flags] public enum switch_file_flag_enum_t {
-  SWITCH_FILE_FLAG_READ = (1 << 0),
-  SWITCH_FILE_FLAG_WRITE = (1 << 1),
-  SWITCH_FILE_FLAG_FREE_POOL = (1 << 2),
-  SWITCH_FILE_DATA_SHORT = (1 << 3),
-  SWITCH_FILE_DATA_INT = (1 << 4),
-  SWITCH_FILE_DATA_FLOAT = (1 << 5),
-  SWITCH_FILE_DATA_DOUBLE = (1 << 6),
-  SWITCH_FILE_DATA_RAW = (1 << 7),
-  SWITCH_FILE_PAUSE = (1 << 8),
-  SWITCH_FILE_NATIVE = (1 << 9),
-  SWITCH_FILE_SEEK = (1 << 10),
-  SWITCH_FILE_OPEN = (1 << 11),
-  SWITCH_FILE_CALLBACK = (1 << 12)
-}
+  public static switch_xml switch_xml_insert(switch_xml xml, switch_xml dest, SWIGTYPE_p_switch_size_t off) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_insert(switch_xml.getCPtr(xml), switch_xml.getCPtr(dest), SWIGTYPE_p_switch_size_t.getCPtr(off));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
+  }
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+  public static switch_xml switch_xml_open_root(byte reload, ref string err) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_open_root(reload, ref err);
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-namespace FreeSWITCH.Native {
+  public static switch_status_t switch_xml_init(SWIGTYPE_p_apr_pool_t pool, ref string err) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_init(SWIGTYPE_p_apr_pool_t.getCPtr(pool), ref err);
+    return ret;
+  }
 
-using System;
-using System.Runtime.InteropServices;
+  public static switch_status_t switch_xml_destroy() {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_destroy();
+    return ret;
+  }
 
-public class switch_file_handle : IDisposable {
-  private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
+  public static switch_xml switch_xml_root() {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_root();
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
+  }
 
-  internal switch_file_handle(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
-    swigCPtr = new HandleRef(this, cPtr);
+  public static switch_status_t switch_xml_locate(string section, string tag_name, string key_name, string key_value, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml node, switch_event arg6) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate(section, tag_name, key_name, key_value, SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(node), switch_event.getCPtr(arg6));
+    return ret;
   }
 
-  internal static HandleRef getCPtr(switch_file_handle obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  public static switch_status_t switch_xml_locate_domain(string domain_name, switch_event arg1, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml domain) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate_domain(domain_name, switch_event.getCPtr(arg1), SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(domain));
+    return ret;
   }
 
-  ~switch_file_handle() {
-    Dispose();
+  public static switch_status_t switch_xml_locate_user(string key, string user_name, string domain_name, string ip, SWIGTYPE_p_p_switch_xml root, SWIGTYPE_p_p_switch_xml domain, SWIGTYPE_p_p_switch_xml user, switch_event arg7) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_locate_user(key, user_name, domain_name, ip, SWIGTYPE_p_p_switch_xml.getCPtr(root), SWIGTYPE_p_p_switch_xml.getCPtr(domain), SWIGTYPE_p_p_switch_xml.getCPtr(user), switch_event.getCPtr(arg7));
+    return ret;
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_file_handle(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  public static switch_xml switch_xml_open_cfg(string file_path, SWIGTYPE_p_p_switch_xml node, switch_event arg2) {
+    IntPtr cPtr = freeswitchPINVOKE.switch_xml_open_cfg(file_path, SWIGTYPE_p_p_switch_xml.getCPtr(node), switch_event.getCPtr(arg2));
+    switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
+    return ret;
   }
 
-  public switch_file_interface file_interface {
-    set {
-      freeswitchPINVOKE.switch_file_handle_file_interface_set(swigCPtr, switch_file_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_file_interface_get(swigCPtr);
-      switch_file_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_file_interface(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_xml_bind_search_function(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml function, uint sections, SWIGTYPE_p_void user_data) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_bind_search_function(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml.getCPtr(function), sections, SWIGTYPE_p_void.getCPtr(user_data));
+    return ret;
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_file_handle_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_flags_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_xml_unbind_search_function(SWIGTYPE_p_p_switch_xml_binding binding) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_unbind_search_function(SWIGTYPE_p_p_switch_xml_binding.getCPtr(binding));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_file_t fd {
-    set {
-      freeswitchPINVOKE.switch_file_handle_fd_set(swigCPtr, SWIGTYPE_p_switch_file_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_fd_get(swigCPtr);
-      SWIGTYPE_p_switch_file_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_file_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_xml_unbind_search_function_ptr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml function) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_xml_unbind_search_function_ptr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml.getCPtr(function));
+    return ret;
   }
 
-  public uint samples {
-    set {
-      freeswitchPINVOKE.switch_file_handle_samples_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_samples_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_xml_parse_section_string(string str) {
+    uint ret = freeswitchPINVOKE.switch_xml_parse_section_string(str);
+    return ret;
   }
 
-  public uint samplerate {
-    set {
-      freeswitchPINVOKE.switch_file_handle_samplerate_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_samplerate_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_outgoing_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(outgoing_channel));
+    return ret;
   }
 
-  public uint native_rate {
-    set {
-      freeswitchPINVOKE.switch_file_handle_native_rate_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_native_rate_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_receive_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(receive_message));
+    return ret;
   }
 
-  public byte channels {
-    set {
-      freeswitchPINVOKE.switch_file_handle_channels_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_file_handle_channels_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(receive_event));
+    return ret;
   }
 
-  public uint format {
-    set {
-      freeswitchPINVOKE.switch_file_handle_format_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_format_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_state_change(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(state_change));
+    return ret;
   }
 
-  public uint sections {
-    set {
-      freeswitchPINVOKE.switch_file_handle_sections_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_sections_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(read_frame));
+    return ret;
   }
 
-  public int seekable {
-    set {
-      freeswitchPINVOKE.switch_file_handle_seekable_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_file_handle_seekable_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_add_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(write_frame));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_video_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_video_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_read_frame));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_video_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_video_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_write_frame));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_kill_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(kill_channel));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_send_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(send_dtmf));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_recv_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(recv_dtmf));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_add_resurrect_session(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_add_resurrect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(resurrect_session));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_remove_outgoing_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_outgoing_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(outgoing_channel));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_remove_receive_message(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_receive_message(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(receive_message));
+    return ret;
+  }
+
+  public static switch_status_t switch_core_event_hook_remove_receive_event(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_receive_event(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(receive_event));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_size_t sample_count {
-    set {
-      freeswitchPINVOKE.switch_file_handle_sample_count_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_file_handle_sample_count_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_state_change(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_state_change(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(state_change));
+    return ret;
   }
 
-  public int speed {
-    set {
-      freeswitchPINVOKE.switch_file_handle_speed_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_file_handle_speed_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(read_frame));
+    return ret;
   }
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_file_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(write_frame));
+    return ret;
   }
 
-  public uint prebuf {
-    set {
-      freeswitchPINVOKE.switch_file_handle_prebuf_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_prebuf_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_video_read_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_video_read_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_read_frame));
+    return ret;
   }
 
-  public uint interval {
-    set {
-      freeswitchPINVOKE.switch_file_handle_interval_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_interval_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_video_write_frame(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_video_write_frame(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(video_write_frame));
+    return ret;
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_file_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_kill_channel(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_kill_channel(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(kill_channel));
+    return ret;
   }
 
-  public string handler {
-    set {
-      freeswitchPINVOKE.switch_file_handle_handler_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_file_handle_handler_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_send_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_send_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(send_dtmf));
+    return ret;
   }
 
-  public long pos {
-    set {
-      freeswitchPINVOKE.switch_file_handle_pos_set(swigCPtr, value);
-    } 
-    get {
-      long ret = freeswitchPINVOKE.switch_file_handle_pos_get(swigCPtr);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_recv_dtmf(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_recv_dtmf(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(recv_dtmf));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_buffer audio_buffer {
-    set {
-      freeswitchPINVOKE.switch_file_handle_audio_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_audio_buffer_get(swigCPtr);
-      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
-      return ret;
-    } 
+  public static switch_status_t switch_core_event_hook_remove_resurrect_session(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.switch_core_event_hook_remove_resurrect_session(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(resurrect_session));
+    return ret;
   }
 
-  public SWIGTYPE_p_switch_buffer sp_audio_buffer {
-    set {
-      freeswitchPINVOKE.switch_file_handle_sp_audio_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_sp_audio_buffer_get(swigCPtr);
-      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
-      return ret;
-    } 
+  public static uint switch_scheduler_add_task(SWIGTYPE_p_time_t task_runtime, SWIGTYPE_p_f_p_switch_scheduler_task__void func, string desc, string group, uint cmd_id, SWIGTYPE_p_void cmd_arg, uint flags) {
+    uint ret = freeswitchPINVOKE.switch_scheduler_add_task(SWIGTYPE_p_time_t.getCPtr(task_runtime), SWIGTYPE_p_f_p_switch_scheduler_task__void.getCPtr(func), desc, group, cmd_id, SWIGTYPE_p_void.getCPtr(cmd_arg), flags);
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
+    return ret;
   }
 
-  public uint thresh {
-    set {
-      freeswitchPINVOKE.switch_file_handle_thresh_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_thresh_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_scheduler_del_task_id(uint task_id) {
+    uint ret = freeswitchPINVOKE.switch_scheduler_del_task_id(task_id);
+    return ret;
   }
 
-  public uint silence_hits {
-    set {
-      freeswitchPINVOKE.switch_file_handle_silence_hits_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_silence_hits_get(swigCPtr);
-      return ret;
-    } 
+  public static uint switch_scheduler_del_task_group(string group) {
+    uint ret = freeswitchPINVOKE.switch_scheduler_del_task_group(group);
+    return ret;
   }
 
-  public uint offset_pos {
-    set {
-      freeswitchPINVOKE.switch_file_handle_offset_pos_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_offset_pos_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_scheduler_task_thread_start() {
+    freeswitchPINVOKE.switch_scheduler_task_thread_start();
   }
 
-  public uint last_pos {
-    set {
-      freeswitchPINVOKE.switch_file_handle_last_pos_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_file_handle_last_pos_get(swigCPtr);
-      return ret;
-    } 
+  public static void switch_scheduler_task_thread_stop() {
+    freeswitchPINVOKE.switch_scheduler_task_thread_stop();
   }
 
-  public int vol {
-    set {
-      freeswitchPINVOKE.switch_file_handle_vol_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_file_handle_vol_get(swigCPtr);
-      return ret;
-    } 
+  public static int switch_config_open_file(switch_config cfg, string file_path) {
+    int ret = freeswitchPINVOKE.switch_config_open_file(switch_config.getCPtr(cfg), file_path);
+    return ret;
   }
 
-  public switch_audio_resampler_t resampler {
-    set {
-      freeswitchPINVOKE.switch_file_handle_resampler_set(swigCPtr, switch_audio_resampler_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_resampler_get(swigCPtr);
-      switch_audio_resampler_t ret = (cPtr == IntPtr.Zero) ? null : new switch_audio_resampler_t(cPtr, false);
-      return ret;
-    } 
+  public static void switch_config_close_file(switch_config cfg) {
+    freeswitchPINVOKE.switch_config_close_file(switch_config.getCPtr(cfg));
   }
 
-  public SWIGTYPE_p_switch_buffer buffer {
-    set {
-      freeswitchPINVOKE.switch_file_handle_buffer_set(swigCPtr, SWIGTYPE_p_switch_buffer.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_buffer_get(swigCPtr);
-      SWIGTYPE_p_switch_buffer ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_buffer(cPtr, false);
-      return ret;
-    } 
+  public static int switch_config_next_pair(switch_config cfg, ref string var, ref string val) {
+    int ret = freeswitchPINVOKE.switch_config_next_pair(switch_config.getCPtr(cfg), ref var, ref val);
+    return ret;
   }
 
-  public SWIGTYPE_p_unsigned_char dbuf {
-    set {
-      freeswitchPINVOKE.switch_file_handle_dbuf_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_handle_dbuf_get(swigCPtr);
-      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-      return ret;
-    } 
+  public static void consoleLog(string level_str, string msg) {
+    freeswitchPINVOKE.consoleLog(level_str, msg);
   }
 
-  public SWIGTYPE_p_switch_size_t dbuflen {
-    set {
-      freeswitchPINVOKE.switch_file_handle_dbuflen_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_file_handle_dbuflen_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  public static void consoleCleanLog(string msg) {
+    freeswitchPINVOKE.consoleCleanLog(msg);
   }
 
-  public string file {
-    set {
-      freeswitchPINVOKE.switch_file_handle_file_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_file_handle_file_get(swigCPtr);
-      return ret;
-    } 
+  public static void console_log(string level_str, string msg) {
+    freeswitchPINVOKE.console_log(level_str, msg);
   }
 
-  public string func {
-    set {
-      freeswitchPINVOKE.switch_file_handle_func_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_file_handle_func_get(swigCPtr);
-      return ret;
-    } 
+  public static void console_clean_log(string msg) {
+    freeswitchPINVOKE.console_clean_log(msg);
   }
 
-  public int line {
-    set {
-      freeswitchPINVOKE.switch_file_handle_line_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_file_handle_line_get(swigCPtr);
-      return ret;
-    } 
+  public static void bridge(CoreSession session_a, CoreSession session_b) {
+    freeswitchPINVOKE.bridge(CoreSession.getCPtr(session_a), CoreSession.getCPtr(session_b));
+    if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
   }
 
-  public switch_file_handle() : this(freeswitchPINVOKE.new_switch_file_handle(), true) {
+  public static switch_status_t hanguphook(SWIGTYPE_p_switch_core_session session) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.hanguphook(SWIGTYPE_p_switch_core_session.getCPtr(session));
+    return ret;
+  }
+
+  public static switch_status_t dtmf_callback(SWIGTYPE_p_switch_core_session session, SWIGTYPE_p_void input, switch_input_type_t itype, SWIGTYPE_p_void buf, uint buflen) {
+    switch_status_t ret = (switch_status_t)freeswitchPINVOKE.dtmf_callback(SWIGTYPE_p_switch_core_session.getCPtr(session), SWIGTYPE_p_void.getCPtr(input), (int)itype, SWIGTYPE_p_void.getCPtr(buf), buflen);
+    return ret;
   }
 
+  public static readonly string FREESWITCH_PEN = freeswitchPINVOKE.FREESWITCH_PEN_get();
+  public static readonly string FREESWITCH_OID_PREFIX = freeswitchPINVOKE.FREESWITCH_OID_PREFIX_get();
+  public static readonly string FREESWITCH_ITAD = freeswitchPINVOKE.FREESWITCH_ITAD_get();
+  public static readonly int __EXTENSIONS__ = freeswitchPINVOKE.__EXTENSIONS___get();
+  public static readonly int __BSD_VISIBLE = freeswitchPINVOKE.__BSD_VISIBLE_get();
+  public static readonly string SWITCH_BLANK_STRING = freeswitchPINVOKE.SWITCH_BLANK_STRING_get();
+  public static readonly string SWITCH_SEQ_ESC = freeswitchPINVOKE.SWITCH_SEQ_ESC_get();
+  public static readonly char SWITCH_SEQ_HOME_CHAR = freeswitchPINVOKE.SWITCH_SEQ_HOME_CHAR_get();
+  public static readonly string SWITCH_SEQ_HOME_CHAR_STR = freeswitchPINVOKE.SWITCH_SEQ_HOME_CHAR_STR_get();
+  public static readonly char SWITCH_SEQ_CLEARLINE_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_CHAR_get();
+  public static readonly string SWITCH_SEQ_CLEARLINE_CHAR_STR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_CHAR_STR_get();
+  public static readonly string SWITCH_SEQ_CLEARLINEEND_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINEEND_CHAR_get();
+  public static readonly char SWITCH_SEQ_CLEARSCR_CHAR0 = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR0_get();
+  public static readonly char SWITCH_SEQ_CLEARSCR_CHAR1 = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR1_get();
+  public static readonly string SWITCH_SEQ_CLEARSCR_CHAR = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_CHAR_get();
+  public static readonly string SWITCH_SEQ_AND_COLOR = freeswitchPINVOKE.SWITCH_SEQ_AND_COLOR_get();
+  public static readonly string SWITCH_SEQ_END_COLOR = freeswitchPINVOKE.SWITCH_SEQ_END_COLOR_get();
+  public static readonly string SWITCH_SEQ_F_BLACK = freeswitchPINVOKE.SWITCH_SEQ_F_BLACK_get();
+  public static readonly string SWITCH_SEQ_F_RED = freeswitchPINVOKE.SWITCH_SEQ_F_RED_get();
+  public static readonly string SWITCH_SEQ_F_GREEN = freeswitchPINVOKE.SWITCH_SEQ_F_GREEN_get();
+  public static readonly string SWITCH_SEQ_F_YELLOW = freeswitchPINVOKE.SWITCH_SEQ_F_YELLOW_get();
+  public static readonly string SWITCH_SEQ_F_BLUE = freeswitchPINVOKE.SWITCH_SEQ_F_BLUE_get();
+  public static readonly string SWITCH_SEQ_F_MAGEN = freeswitchPINVOKE.SWITCH_SEQ_F_MAGEN_get();
+  public static readonly string SWITCH_SEQ_F_CYAN = freeswitchPINVOKE.SWITCH_SEQ_F_CYAN_get();
+  public static readonly string SWITCH_SEQ_F_WHITE = freeswitchPINVOKE.SWITCH_SEQ_F_WHITE_get();
+  public static readonly string SWITCH_SEQ_B_BLACK = freeswitchPINVOKE.SWITCH_SEQ_B_BLACK_get();
+  public static readonly string SWITCH_SEQ_B_RED = freeswitchPINVOKE.SWITCH_SEQ_B_RED_get();
+  public static readonly string SWITCH_SEQ_B_GREEN = freeswitchPINVOKE.SWITCH_SEQ_B_GREEN_get();
+  public static readonly string SWITCH_SEQ_B_YELLOW = freeswitchPINVOKE.SWITCH_SEQ_B_YELLOW_get();
+  public static readonly string SWITCH_SEQ_B_BLUE = freeswitchPINVOKE.SWITCH_SEQ_B_BLUE_get();
+  public static readonly string SWITCH_SEQ_B_MAGEN = freeswitchPINVOKE.SWITCH_SEQ_B_MAGEN_get();
+  public static readonly string SWITCH_SEQ_B_CYAN = freeswitchPINVOKE.SWITCH_SEQ_B_CYAN_get();
+  public static readonly string SWITCH_SEQ_B_WHITE = freeswitchPINVOKE.SWITCH_SEQ_B_WHITE_get();
+  public static readonly string SWITCH_SEQ_FBLACK = freeswitchPINVOKE.SWITCH_SEQ_FBLACK_get();
+  public static readonly string SWITCH_SEQ_FRED = freeswitchPINVOKE.SWITCH_SEQ_FRED_get();
+  public static readonly string SWITCH_SEQ_FGREEN = freeswitchPINVOKE.SWITCH_SEQ_FGREEN_get();
+  public static readonly string SWITCH_SEQ_FYELLOW = freeswitchPINVOKE.SWITCH_SEQ_FYELLOW_get();
+  public static readonly string SWITCH_SEQ_FBLUE = freeswitchPINVOKE.SWITCH_SEQ_FBLUE_get();
+  public static readonly string SWITCH_SEQ_FMAGEN = freeswitchPINVOKE.SWITCH_SEQ_FMAGEN_get();
+  public static readonly string SWITCH_SEQ_FCYAN = freeswitchPINVOKE.SWITCH_SEQ_FCYAN_get();
+  public static readonly string SWITCH_SEQ_FWHITE = freeswitchPINVOKE.SWITCH_SEQ_FWHITE_get();
+  public static readonly string SWITCH_SEQ_BBLACK = freeswitchPINVOKE.SWITCH_SEQ_BBLACK_get();
+  public static readonly string SWITCH_SEQ_BRED = freeswitchPINVOKE.SWITCH_SEQ_BRED_get();
+  public static readonly string SWITCH_SEQ_BGREEN = freeswitchPINVOKE.SWITCH_SEQ_BGREEN_get();
+  public static readonly string SWITCH_SEQ_BYELLOW = freeswitchPINVOKE.SWITCH_SEQ_BYELLOW_get();
+  public static readonly string SWITCH_SEQ_BBLUE = freeswitchPINVOKE.SWITCH_SEQ_BBLUE_get();
+  public static readonly string SWITCH_SEQ_BMAGEN = freeswitchPINVOKE.SWITCH_SEQ_BMAGEN_get();
+  public static readonly string SWITCH_SEQ_BCYAN = freeswitchPINVOKE.SWITCH_SEQ_BCYAN_get();
+  public static readonly string SWITCH_SEQ_BWHITE = freeswitchPINVOKE.SWITCH_SEQ_BWHITE_get();
+  public static readonly string SWITCH_SEQ_HOME = freeswitchPINVOKE.SWITCH_SEQ_HOME_get();
+  public static readonly string SWITCH_SEQ_CLEARLINE = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINE_get();
+  public static readonly string SWITCH_SEQ_CLEARLINEEND = freeswitchPINVOKE.SWITCH_SEQ_CLEARLINEEND_get();
+  public static readonly string SWITCH_SEQ_CLEARSCR = freeswitchPINVOKE.SWITCH_SEQ_CLEARSCR_get();
+  public static readonly int SWITCH_DEFAULT_DTMF_DURATION = freeswitchPINVOKE.SWITCH_DEFAULT_DTMF_DURATION_get();
+  public static readonly int SWITCH_MAX_DTMF_DURATION = freeswitchPINVOKE.SWITCH_MAX_DTMF_DURATION_get();
+  public static readonly string SWITCH_PATH_SEPARATOR = freeswitchPINVOKE.SWITCH_PATH_SEPARATOR_get();
+  public static readonly string SWITCH_URL_SEPARATOR = freeswitchPINVOKE.SWITCH_URL_SEPARATOR_get();
+  public static readonly string SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_BYPASS_MEDIA_AFTER_BRIDGE_VARIABLE_get();
+  public static readonly string SWITCH_READ_RESULT_VARIABLE = freeswitchPINVOKE.SWITCH_READ_RESULT_VARIABLE_get();
+  public static readonly string SWITCH_COPY_XML_CDR_VARIABLE = freeswitchPINVOKE.SWITCH_COPY_XML_CDR_VARIABLE_get();
+  public static readonly string SWITCH_CURRENT_APPLICATION_VARIABLE = freeswitchPINVOKE.SWITCH_CURRENT_APPLICATION_VARIABLE_get();
+  public static readonly string SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE = freeswitchPINVOKE.SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE_get();
+  public static readonly string SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE_get();
+  public static readonly string SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE_get();
+  public static readonly string SWITCH_CALL_TIMEOUT_VARIABLE = freeswitchPINVOKE.SWITCH_CALL_TIMEOUT_VARIABLE_get();
+  public static readonly string SWITCH_HOLDING_UUID_VARIABLE = freeswitchPINVOKE.SWITCH_HOLDING_UUID_VARIABLE_get();
+  public static readonly string SWITCH_API_BRIDGE_END_VARIABLE = freeswitchPINVOKE.SWITCH_API_BRIDGE_END_VARIABLE_get();
+  public static readonly string SWITCH_API_HANGUP_HOOK_VARIABLE = freeswitchPINVOKE.SWITCH_API_HANGUP_HOOK_VARIABLE_get();
+  public static readonly string SWITCH_PROCESS_CDR_VARIABLE = freeswitchPINVOKE.SWITCH_PROCESS_CDR_VARIABLE_get();
+  public static readonly string SWITCH_BRIDGE_CHANNEL_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_CHANNEL_VARIABLE_get();
+  public static readonly string SWITCH_CHANNEL_NAME_VARIABLE = freeswitchPINVOKE.SWITCH_CHANNEL_NAME_VARIABLE_get();
+  public static readonly string SWITCH_BRIDGE_UUID_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_UUID_VARIABLE_get();
+  public static readonly string SWITCH_CONTINUE_ON_FAILURE_VARIABLE = freeswitchPINVOKE.SWITCH_CONTINUE_ON_FAILURE_VARIABLE_get();
+  public static readonly string SWITCH_PLAYBACK_TERMINATORS_VARIABLE = freeswitchPINVOKE.SWITCH_PLAYBACK_TERMINATORS_VARIABLE_get();
+  public static readonly string SWITCH_PLAYBACK_TERMINATOR_USED = freeswitchPINVOKE.SWITCH_PLAYBACK_TERMINATOR_USED_get();
+  public static readonly string SWITCH_CACHE_SPEECH_HANDLES_VARIABLE = freeswitchPINVOKE.SWITCH_CACHE_SPEECH_HANDLES_VARIABLE_get();
+  public static readonly string SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME = freeswitchPINVOKE.SWITCH_CACHE_SPEECH_HANDLES_OBJ_NAME_get();
+  public static readonly string SWITCH_BYPASS_MEDIA_VARIABLE = freeswitchPINVOKE.SWITCH_BYPASS_MEDIA_VARIABLE_get();
+  public static readonly string SWITCH_PROXY_MEDIA_VARIABLE = freeswitchPINVOKE.SWITCH_PROXY_MEDIA_VARIABLE_get();
+  public static readonly string SWITCH_ENDPOINT_DISPOSITION_VARIABLE = freeswitchPINVOKE.SWITCH_ENDPOINT_DISPOSITION_VARIABLE_get();
+  public static readonly string SWITCH_HOLD_MUSIC_VARIABLE = freeswitchPINVOKE.SWITCH_HOLD_MUSIC_VARIABLE_get();
+  public static readonly string SWITCH_EXPORT_VARS_VARIABLE = freeswitchPINVOKE.SWITCH_EXPORT_VARS_VARIABLE_get();
+  public static readonly string SWITCH_R_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_R_SDP_VARIABLE_get();
+  public static readonly string SWITCH_L_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_L_SDP_VARIABLE_get();
+  public static readonly string SWITCH_B_SDP_VARIABLE = freeswitchPINVOKE.SWITCH_B_SDP_VARIABLE_get();
+  public static readonly string SWITCH_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_BRIDGE_VARIABLE_get();
+  public static readonly string SWITCH_SIGNAL_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_SIGNAL_BRIDGE_VARIABLE_get();
+  public static readonly string SWITCH_SIGNAL_BOND_VARIABLE = freeswitchPINVOKE.SWITCH_SIGNAL_BOND_VARIABLE_get();
+  public static readonly string SWITCH_ORIGINATOR_VARIABLE = freeswitchPINVOKE.SWITCH_ORIGINATOR_VARIABLE_get();
+  public static readonly string SWITCH_ORIGINATOR_CODEC_VARIABLE = freeswitchPINVOKE.SWITCH_ORIGINATOR_CODEC_VARIABLE_get();
+  public static readonly string SWITCH_LOCAL_MEDIA_IP_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_MEDIA_IP_VARIABLE_get();
+  public static readonly string SWITCH_LOCAL_MEDIA_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_MEDIA_PORT_VARIABLE_get();
+  public static readonly string SWITCH_REMOTE_MEDIA_IP_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_MEDIA_IP_VARIABLE_get();
+  public static readonly string SWITCH_REMOTE_MEDIA_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_MEDIA_PORT_VARIABLE_get();
+  public static readonly string SWITCH_REMOTE_VIDEO_IP_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_VIDEO_IP_VARIABLE_get();
+  public static readonly string SWITCH_REMOTE_VIDEO_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_REMOTE_VIDEO_PORT_VARIABLE_get();
+  public static readonly string SWITCH_LOCAL_VIDEO_IP_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_VIDEO_IP_VARIABLE_get();
+  public static readonly string SWITCH_LOCAL_VIDEO_PORT_VARIABLE = freeswitchPINVOKE.SWITCH_LOCAL_VIDEO_PORT_VARIABLE_get();
+  public static readonly string SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE = freeswitchPINVOKE.SWITCH_HANGUP_AFTER_BRIDGE_VARIABLE_get();
+  public static readonly string SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE = freeswitchPINVOKE.SWITCH_EXEC_AFTER_BRIDGE_APP_VARIABLE_get();
+  public static readonly string SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE = freeswitchPINVOKE.SWITCH_EXEC_AFTER_BRIDGE_ARG_VARIABLE_get();
+  public static readonly string SWITCH_MAX_FORWARDS_VARIABLE = freeswitchPINVOKE.SWITCH_MAX_FORWARDS_VARIABLE_get();
+  public static readonly string SWITCH_DISABLE_APP_LOG_VARIABLE = freeswitchPINVOKE.SWITCH_DISABLE_APP_LOG_VARIABLE_get();
+  public static readonly string SWITCH_SPEECH_KEY = freeswitchPINVOKE.SWITCH_SPEECH_KEY_get();
+  public static readonly string SWITCH_UUID_BRIDGE = freeswitchPINVOKE.SWITCH_UUID_BRIDGE_get();
+  public static readonly int SWITCH_BITS_PER_BYTE = freeswitchPINVOKE.SWITCH_BITS_PER_BYTE_get();
+  public static readonly int SWITCH_MAX_STACKS = freeswitchPINVOKE.SWITCH_MAX_STACKS_get();
+  public static readonly int SWITCH_THREAD_STACKSIZE = freeswitchPINVOKE.SWITCH_THREAD_STACKSIZE_get();
+  public static readonly int SWITCH_SYSTEM_THREAD_STACKSIZE = freeswitchPINVOKE.SWITCH_SYSTEM_THREAD_STACKSIZE_get();
+  public static readonly int SWITCH_MAX_INTERVAL = freeswitchPINVOKE.SWITCH_MAX_INTERVAL_get();
+  public static readonly int SWITCH_INTERVAL_PAD = freeswitchPINVOKE.SWITCH_INTERVAL_PAD_get();
+  public static readonly int SWITCH_MAX_SAMPLE_LEN = freeswitchPINVOKE.SWITCH_MAX_SAMPLE_LEN_get();
+  public static readonly int SWITCH_BYTES_PER_SAMPLE = freeswitchPINVOKE.SWITCH_BYTES_PER_SAMPLE_get();
+  public static readonly int SWITCH_RECOMMENDED_BUFFER_SIZE = freeswitchPINVOKE.SWITCH_RECOMMENDED_BUFFER_SIZE_get();
+  public static readonly int SWITCH_MAX_CODECS = freeswitchPINVOKE.SWITCH_MAX_CODECS_get();
+  public static readonly int SWITCH_MAX_STATE_HANDLERS = freeswitchPINVOKE.SWITCH_MAX_STATE_HANDLERS_get();
+  public static readonly int SWITCH_CORE_QUEUE_LEN = freeswitchPINVOKE.SWITCH_CORE_QUEUE_LEN_get();
+  public static readonly int SWITCH_MAX_MANAGEMENT_BUFFER_LEN = freeswitchPINVOKE.SWITCH_MAX_MANAGEMENT_BUFFER_LEN_get();
+  public static readonly int SWITCH_RTP_CNG_PAYLOAD = freeswitchPINVOKE.SWITCH_RTP_CNG_PAYLOAD_get();
+  public static readonly int SWITCH_API_VERSION = freeswitchPINVOKE.SWITCH_API_VERSION_get();
+  public static readonly int SWITCH_CORE_DB_OK = freeswitchPINVOKE.SWITCH_CORE_DB_OK_get();
+  public static readonly int SWITCH_CORE_DB_ERROR = freeswitchPINVOKE.SWITCH_CORE_DB_ERROR_get();
+  public static readonly int SWITCH_CORE_DB_INTERNAL = freeswitchPINVOKE.SWITCH_CORE_DB_INTERNAL_get();
+  public static readonly int SWITCH_CORE_DB_PERM = freeswitchPINVOKE.SWITCH_CORE_DB_PERM_get();
+  public static readonly int SWITCH_CORE_DB_ABORT = freeswitchPINVOKE.SWITCH_CORE_DB_ABORT_get();
+  public static readonly int SWITCH_CORE_DB_BUSY = freeswitchPINVOKE.SWITCH_CORE_DB_BUSY_get();
+  public static readonly int SWITCH_CORE_DB_LOCKED = freeswitchPINVOKE.SWITCH_CORE_DB_LOCKED_get();
+  public static readonly int SWITCH_CORE_DB_NOMEM = freeswitchPINVOKE.SWITCH_CORE_DB_NOMEM_get();
+  public static readonly int SWITCH_CORE_DB_READONLY = freeswitchPINVOKE.SWITCH_CORE_DB_READONLY_get();
+  public static readonly int SWITCH_CORE_DB_INTERRUPT = freeswitchPINVOKE.SWITCH_CORE_DB_INTERRUPT_get();
+  public static readonly int SWITCH_CORE_DB_IOERR = freeswitchPINVOKE.SWITCH_CORE_DB_IOERR_get();
+  public static readonly int SWITCH_CORE_DB_CORRUPT = freeswitchPINVOKE.SWITCH_CORE_DB_CORRUPT_get();
+  public static readonly int SWITCH_CORE_DB_NOTFOUND = freeswitchPINVOKE.SWITCH_CORE_DB_NOTFOUND_get();
+  public static readonly int SWITCH_CORE_DB_FULL = freeswitchPINVOKE.SWITCH_CORE_DB_FULL_get();
+  public static readonly int SWITCH_CORE_DB_CANTOPEN = freeswitchPINVOKE.SWITCH_CORE_DB_CANTOPEN_get();
+  public static readonly int SWITCH_CORE_DB_PROTOCOL = freeswitchPINVOKE.SWITCH_CORE_DB_PROTOCOL_get();
+  public static readonly int SWITCH_CORE_DB_EMPTY = freeswitchPINVOKE.SWITCH_CORE_DB_EMPTY_get();
+  public static readonly int SWITCH_CORE_DB_SCHEMA = freeswitchPINVOKE.SWITCH_CORE_DB_SCHEMA_get();
+  public static readonly int SWITCH_CORE_DB_TOOBIG = freeswitchPINVOKE.SWITCH_CORE_DB_TOOBIG_get();
+  public static readonly int SWITCH_CORE_DB_CONSTRAINT = freeswitchPINVOKE.SWITCH_CORE_DB_CONSTRAINT_get();
+  public static readonly int SWITCH_CORE_DB_MISMATCH = freeswitchPINVOKE.SWITCH_CORE_DB_MISMATCH_get();
+  public static readonly int SWITCH_CORE_DB_MISUSE = freeswitchPINVOKE.SWITCH_CORE_DB_MISUSE_get();
+  public static readonly int SWITCH_CORE_DB_NOLFS = freeswitchPINVOKE.SWITCH_CORE_DB_NOLFS_get();
+  public static readonly int SWITCH_CORE_DB_AUTH = freeswitchPINVOKE.SWITCH_CORE_DB_AUTH_get();
+  public static readonly int SWITCH_CORE_DB_FORMAT = freeswitchPINVOKE.SWITCH_CORE_DB_FORMAT_get();
+  public static readonly int SWITCH_CORE_DB_RANGE = freeswitchPINVOKE.SWITCH_CORE_DB_RANGE_get();
+  public static readonly int SWITCH_CORE_DB_NOTADB = freeswitchPINVOKE.SWITCH_CORE_DB_NOTADB_get();
+  public static readonly int SWITCH_CORE_DB_ROW = freeswitchPINVOKE.SWITCH_CORE_DB_ROW_get();
+  public static readonly int SWITCH_CORE_DB_DONE = freeswitchPINVOKE.SWITCH_CORE_DB_DONE_get();
+  public static readonly int SWITCH_MAX_CORE_THREAD_SESSION_OBJS = freeswitchPINVOKE.SWITCH_MAX_CORE_THREAD_SESSION_OBJS_get();
+  public static readonly int SWITCH_MAX_STREAMS = freeswitchPINVOKE.SWITCH_MAX_STREAMS_get();
+  public static readonly string SWITCH_CORE_DB = freeswitchPINVOKE.SWITCH_CORE_DB_get();
+  public static readonly int SWITCH_CMD_CHUNK_LEN = freeswitchPINVOKE.SWITCH_CMD_CHUNK_LEN_get();
+  public static readonly int SWITCH_SMAX = freeswitchPINVOKE.SWITCH_SMAX_get();
+  public static readonly int SWITCH_SMIN = freeswitchPINVOKE.SWITCH_SMIN_get();
+  public static readonly int SWITCH_RTP_MAX_BUF_LEN = freeswitchPINVOKE.SWITCH_RTP_MAX_BUF_LEN_get();
+  public static readonly int SWITCH_RTP_MAX_CRYPTO_LEN = freeswitchPINVOKE.SWITCH_RTP_MAX_CRYPTO_LEN_get();
+  public static readonly int SWITCH_RTP_KEY_LEN = freeswitchPINVOKE.SWITCH_RTP_KEY_LEN_get();
+  public static readonly string SWITCH_RTP_CRYPTO_KEY_32 = freeswitchPINVOKE.SWITCH_RTP_CRYPTO_KEY_32_get();
+  public static readonly string SWITCH_RTP_CRYPTO_KEY_80 = freeswitchPINVOKE.SWITCH_RTP_CRYPTO_KEY_80_get();
+  public static readonly int SWITCH_XML_BUFSIZE = freeswitchPINVOKE.SWITCH_XML_BUFSIZE_get();
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19157,161 +19803,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_file_interface : IDisposable {
+public class SWIGTYPE_p_p_switch_caller_extension {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_file_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_caller_extension(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_file_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_file_interface() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_file_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  protected SWIGTYPE_p_p_switch_caller_extension() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_file_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_file_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_caller_extension obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t file_open {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_open_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_file_handle__switch_status_t file_close {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_close_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t file_read {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_read_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_read_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t file_write {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_write_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_write_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t file_seek {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_seek_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_seek_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t file_set_string {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_set_string_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_set_string_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t file_get_string {
-    set {
-      freeswitchPINVOKE.switch_file_interface_file_get_string_set(swigCPtr, SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_file_get_string_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public string extens {
-  set { freeswitchPINVOKE.switch_file_interface_extens_set(swigCPtr, ref value); }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  get {
-    return freeswitchPINVOKE.switch_file_interface_extens_get(swigCPtr);
-  }
+namespace FreeSWITCH.Native {
 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_file_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_p_switch_media_bug {
+  private HandleRef swigCPtr;
 
-  public switch_file_interface next {
-    set {
-      freeswitchPINVOKE.switch_file_interface_next_set(swigCPtr, switch_file_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_file_interface_next_get(swigCPtr);
-      switch_file_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_file_interface(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_p_switch_media_bug(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_file_interface() : this(freeswitchPINVOKE.new_switch_file_interface(), true) {
+  protected SWIGTYPE_p_p_switch_media_bug() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_media_bug obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19322,198 +19893,206 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_frame : IDisposable {
+public class SWIGTYPE_p_switch_media_bug {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_frame(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_switch_media_bug(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_frame obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_switch_media_bug() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_frame() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_media_bug obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_frame(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_rtp {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_rtp(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_codec codec {
-    set {
-      freeswitchPINVOKE.switch_frame_codec_set(swigCPtr, switch_codec.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_frame_codec_get(swigCPtr);
-      switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_rtp() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public string source {
-    set {
-      freeswitchPINVOKE.switch_frame_source_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_frame_source_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_rtp obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_void packet {
-    set {
-      freeswitchPINVOKE.switch_frame_packet_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_frame_packet_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_rtp {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_rtp(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint packetlen {
-    set {
-      freeswitchPINVOKE.switch_frame_packetlen_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_packetlen_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_rtp() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_void data {
-    set {
-      freeswitchPINVOKE.switch_frame_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_frame_data_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_rtp obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint datalen {
-    set {
-      freeswitchPINVOKE.switch_frame_datalen_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_datalen_get(swigCPtr);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_ssize_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_ssize_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint buflen {
-    set {
-      freeswitchPINVOKE.switch_frame_buflen_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_buflen_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_ssize_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public uint samples {
-    set {
-      freeswitchPINVOKE.switch_frame_samples_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_samples_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ssize_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint rate {
-    set {
-      freeswitchPINVOKE.switch_frame_rate_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_rate_get(swigCPtr);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_size_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_size_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public byte payload {
-    set {
-      freeswitchPINVOKE.switch_frame_payload_set(swigCPtr, value);
-    } 
-    get {
-      byte ret = freeswitchPINVOKE.switch_frame_payload_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_size_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t timestamp {
-    set {
-      freeswitchPINVOKE.switch_frame_timestamp_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_frame_timestamp_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_size_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public ushort seq {
-    set {
-      freeswitchPINVOKE.switch_frame_seq_set(swigCPtr, value);
-    } 
-    get {
-      ushort ret = freeswitchPINVOKE.switch_frame_seq_get(swigCPtr);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint ssrc {
-    set {
-      freeswitchPINVOKE.switch_frame_ssrc_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_ssrc_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_bool_t m {
-    set {
-      freeswitchPINVOKE.switch_frame_m_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_bool_t ret = (switch_bool_t)freeswitchPINVOKE.switch_frame_m_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_frame_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_frame_flags_get(swigCPtr);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_frame() : this(freeswitchPINVOKE.new_switch_frame(), true) {
+  protected SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19521,20 +20100,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_frame_flag_enum_t {
-  SFF_NONE = 0,
-  SFF_CNG = (1 << 0),
-  SFF_RAW_RTP = (1 << 1),
-  SFF_RTP_HEADER = (1 << 2),
-  SFF_PLC = (1 << 3),
-  SFF_RFC2833 = (1 << 4),
-  SFF_PROXY_PACKET = (1 << 5)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_sockaddr_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_sockaddr_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_sockaddr_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_sockaddr_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19545,97 +20133,116 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_input_args_t : IDisposable {
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_input_args_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_input_args_t obj) {
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  ~switch_input_args_t() {
-    Dispose();
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_input_args_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t input_callback {
-    set {
-      freeswitchPINVOKE.switch_input_args_t_input_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_input_callback_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_void buf {
-    set {
-      freeswitchPINVOKE.switch_input_args_t_buf_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_buf_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_buffer {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_buffer(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint buflen {
-    set {
-      freeswitchPINVOKE.switch_input_args_t_buflen_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_input_args_t_buflen_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_buffer() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t read_frame_callback {
-    set {
-      freeswitchPINVOKE.switch_input_args_t_read_frame_callback_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_read_frame_callback_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_buffer obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_void user_data {
-    set {
-      freeswitchPINVOKE.switch_input_args_t_user_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_input_args_t_user_data_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_input_args_t() : this(freeswitchPINVOKE.new_switch_input_args_t(), true) {
+  protected SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char_p_char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19643,15 +20250,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_input_type_t {
-  SWITCH_INPUT_TYPE_DTMF,
-  SWITCH_INPUT_TYPE_EVENT
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_char_p_char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19662,175 +20283,176 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hooks : IDisposable {
+public class SWIGTYPE_p_p_switch_buffer {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hooks(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_buffer(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hooks obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_p_switch_buffer() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hooks() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_buffer obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hooks(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_unsigned_short {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_unsigned_short(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_outgoing_channel outgoing_channel {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_outgoing_channel_set(swigCPtr, switch_io_event_hook_outgoing_channel.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_outgoing_channel_get(swigCPtr);
-      switch_io_event_hook_outgoing_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_outgoing_channel(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_unsigned_short() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_receive_message receive_message {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_receive_message_set(swigCPtr, switch_io_event_hook_receive_message.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_receive_message_get(swigCPtr);
-      switch_io_event_hook_receive_message ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_message(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_short obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_io_event_hook_receive_event receive_event {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_receive_event_set(swigCPtr, switch_io_event_hook_receive_event.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_receive_event_get(swigCPtr);
-      switch_io_event_hook_receive_event ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_event(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_real_pcre {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_real_pcre(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_read_frame read_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_read_frame_set(swigCPtr, switch_io_event_hook_read_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_read_frame_get(swigCPtr);
-      switch_io_event_hook_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_read_frame(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_real_pcre() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_video_read_frame video_read_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_video_read_frame_set(swigCPtr, switch_io_event_hook_video_read_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_video_read_frame_get(swigCPtr);
-      switch_io_event_hook_video_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_read_frame(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_real_pcre obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_io_event_hook_write_frame write_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_write_frame_set(swigCPtr, switch_io_event_hook_write_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_write_frame_get(swigCPtr);
-      switch_io_event_hook_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_write_frame(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_real_pcre {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_real_pcre(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_video_write_frame video_write_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_video_write_frame_set(swigCPtr, switch_io_event_hook_video_write_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_video_write_frame_get(swigCPtr);
-      switch_io_event_hook_video_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_write_frame(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_real_pcre() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_kill_channel kill_channel {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_kill_channel_set(swigCPtr, switch_io_event_hook_kill_channel.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_kill_channel_get(swigCPtr);
-      switch_io_event_hook_kill_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_kill_channel(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_real_pcre obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_io_event_hook_send_dtmf send_dtmf {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_send_dtmf_set(swigCPtr, switch_io_event_hook_send_dtmf.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_send_dtmf_get(swigCPtr);
-      switch_io_event_hook_send_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_send_dtmf(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_short {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_short(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_recv_dtmf recv_dtmf {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_recv_dtmf_set(swigCPtr, switch_io_event_hook_recv_dtmf.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_recv_dtmf_get(swigCPtr);
-      switch_io_event_hook_recv_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_recv_dtmf(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_short() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_state_change state_change {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_state_change_set(swigCPtr, switch_io_event_hook_state_change.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_state_change_get(swigCPtr);
-      switch_io_event_hook_state_change ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_state_change(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_short obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
+
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
 
-  public switch_io_event_hook_resurrect_session resurrect_session {
-    set {
-      freeswitchPINVOKE.switch_io_event_hooks_resurrect_session_set(swigCPtr, switch_io_event_hook_resurrect_session.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hooks_resurrect_session_get(swigCPtr);
-      switch_io_event_hook_resurrect_session ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_resurrect_session(cPtr, false);
-      return ret;
-    } 
+public class SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hooks() : this(freeswitchPINVOKE.new_switch_io_event_hooks(), true) {
+  protected SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_media_bug_p_void_enum_switch_abc_type_t__switch_bool_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19841,65 +20463,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_kill_channel : IDisposable {
+public class SWIGTYPE_p_switch_pollfd_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_kill_channel(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_switch_pollfd_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_kill_channel obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_switch_pollfd_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_kill_channel() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_pollfd_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_kill_channel(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_kill_channel_kill_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_kill_channel_kill_channel_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_kill_channel next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_kill_channel_next_set(swigCPtr, switch_io_event_hook_kill_channel.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_kill_channel_next_get(swigCPtr);
-      switch_io_event_hook_kill_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_kill_channel(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_kill_channel() : this(freeswitchPINVOKE.new_switch_io_event_hook_kill_channel(), true) {
+  protected SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19910,65 +20523,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_outgoing_channel : IDisposable {
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_outgoing_channel(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_outgoing_channel obj) {
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char__switch_status_t obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  ~switch_io_event_hook_outgoing_channel() {
-    Dispose();
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_outgoing_channel(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  protected SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t outgoing_channel {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_outgoing_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_outgoing_channel_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec_unsigned_long_p_q_const__switch_codec_settings__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_io_event_hook_outgoing_channel next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_next_set(swigCPtr, switch_io_event_hook_outgoing_channel.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_outgoing_channel_next_get(swigCPtr);
-      switch_io_event_hook_outgoing_channel ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_outgoing_channel(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_outgoing_channel() : this(freeswitchPINVOKE.new_switch_io_event_hook_outgoing_channel(), true) {
+  protected SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec_p_switch_codec_p_void_unsigned_long_unsigned_long_p_void_p_unsigned_long_p_unsigned_long_p_unsigned_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -19979,65 +20613,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_read_frame : IDisposable {
+public class SWIGTYPE_p_p_switch_event_node {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_read_frame(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_event_node(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_read_frame obj) {
+  protected SWIGTYPE_p_p_switch_event_node() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_event_node obj) {
     return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  ~switch_io_event_hook_read_frame() {
-    Dispose();
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_event_node {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_event_node(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_read_frame(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  protected SWIGTYPE_p_switch_event_node() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_read_frame_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_read_frame_read_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_event_node obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_io_event_hook_read_frame next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_read_frame_next_set(swigCPtr, switch_io_event_hook_read_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_read_frame_next_get(swigCPtr);
-      switch_io_event_hook_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_read_frame(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_event {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_event(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_read_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_read_frame(), true) {
+  protected SWIGTYPE_p_p_switch_event() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_event obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20048,65 +20703,26 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_receive_event : IDisposable {
+public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_receive_event(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_receive_event obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_io_event_hook_receive_event() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_receive_event(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
-
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_receive_event_receive_event_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_event_receive_event_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
-
-  public switch_io_event_hook_receive_event next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_receive_event_next_set(swigCPtr, switch_io_event_hook_receive_event.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_event_next_get(swigCPtr);
-      switch_io_event_hook_receive_event ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_event(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_receive_event() : this(freeswitchPINVOKE.new_switch_io_event_hook_receive_event(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__char__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20117,65 +20733,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_receive_message : IDisposable {
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_receive_message(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_receive_message obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_receive_message() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_void_unsigned_int_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_receive_message(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_receive_message_receive_message_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_message_receive_message_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_receive_message next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_receive_message_next_set(swigCPtr, switch_io_event_hook_receive_message.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_receive_message_next_get(swigCPtr);
-      switch_io_event_hook_receive_message ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_receive_message(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_receive_message() : this(freeswitchPINVOKE.new_switch_io_event_hook_receive_message(), true) {
+  protected SWIGTYPE_p_f_p_switch_core_session__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20186,65 +20793,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_recv_dtmf : IDisposable {
+public class SWIGTYPE_p_void {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_recv_dtmf(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_void(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_recv_dtmf obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_recv_dtmf() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_recv_dtmf(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t recv_dtmf {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_recv_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_recv_dtmf_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_recv_dtmf next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_next_set(swigCPtr, switch_io_event_hook_recv_dtmf.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_recv_dtmf_next_get(swigCPtr);
-      switch_io_event_hook_recv_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_recv_dtmf(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_void {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_recv_dtmf() : this(freeswitchPINVOKE.new_switch_io_event_hook_recv_dtmf(), true) {
+  protected SWIGTYPE_p_p_void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20255,65 +20853,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_resurrect_session : IDisposable {
+public class SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_resurrect_session(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_resurrect_session obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_resurrect_session() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_thread_t_p_void__p_void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_resurrect_session(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_resurrect_session_resurrect_session_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_resurrect_session_resurrect_session_get(swigCPtr);
-      SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(cPtr, false);
-      return ret;
-    } 
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_call_cause_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_resurrect_session next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_resurrect_session_next_set(swigCPtr, switch_io_event_hook_resurrect_session.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_resurrect_session_next_get(swigCPtr);
-      switch_io_event_hook_resurrect_session ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_resurrect_session(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_call_cause_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_resurrect_session() : this(freeswitchPINVOKE.new_switch_io_event_hook_resurrect_session(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_call_cause_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20324,65 +20913,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_send_dtmf : IDisposable {
+public class SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_send_dtmf(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_send_dtmf obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_send_dtmf() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_rtp_p_switch_socket_t_p_void_switch_size_t_p_switch_sockaddr_t__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_send_dtmf(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t send_dtmf {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_send_dtmf_send_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_send_dtmf_send_dtmf_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_send_dtmf next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_send_dtmf_next_set(swigCPtr, switch_io_event_hook_send_dtmf.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_send_dtmf_next_get(swigCPtr);
-      switch_io_event_hook_send_dtmf ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_send_dtmf(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_send_dtmf() : this(freeswitchPINVOKE.new_switch_io_event_hook_send_dtmf(), true) {
+  protected SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_void_enum_switch_input_type_t_p_void_unsigned_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20393,65 +20973,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_state_change : IDisposable {
+public class SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_state_change(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_state_change obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_state_change() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_state_change(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_state_change_state_change_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_state_change_state_change_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_state_change next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_state_change_next_set(swigCPtr, switch_io_event_hook_state_change.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_state_change_next_get(swigCPtr);
-      switch_io_event_hook_state_change ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_state_change(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_state_change() : this(freeswitchPINVOKE.new_switch_io_event_hook_state_change(), true) {
+  protected SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__switch_log_node_t_enum_switch_log_level_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20462,65 +21033,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_video_read_frame : IDisposable {
+public class SWIGTYPE_p_p_switch_xml_binding {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_video_read_frame(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_xml_binding(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_video_read_frame obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_p_switch_xml_binding() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_video_read_frame() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_xml_binding obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_video_read_frame(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t video_read_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_video_read_frame_video_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_read_frame_video_read_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_video_read_frame next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_video_read_frame_next_set(swigCPtr, switch_io_event_hook_video_read_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_read_frame_next_get(swigCPtr);
-      switch_io_event_hook_video_read_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_read_frame(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_speech_handle__void {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_speech_handle__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_video_read_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_video_read_frame(), true) {
+  protected SWIGTYPE_p_f_p_switch_speech_handle__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20531,65 +21093,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_video_write_frame : IDisposable {
+public class SWIGTYPE_p_f_p_switch_scheduler_task__void {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_video_write_frame(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_scheduler_task__void(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_video_write_frame obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_scheduler_task__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_io_event_hook_video_write_frame() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_scheduler_task__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_video_write_frame(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t video_write_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_video_write_frame_video_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_write_frame_video_write_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_io_event_hook_video_write_frame next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_video_write_frame_next_set(swigCPtr, switch_io_event_hook_video_write_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_video_write_frame_next_get(swigCPtr);
-      switch_io_event_hook_video_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_video_write_frame(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_event_hook_video_write_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_video_write_frame(), true) {
+  protected SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20600,65 +21153,26 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_event_hook_write_frame : IDisposable {
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_event_hook_write_frame(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_event_hook_write_frame obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_io_event_hook_write_frame() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_event_hook_write_frame(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
-
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_write_frame_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_write_frame_write_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
-
-  public switch_io_event_hook_write_frame next {
-    set {
-      freeswitchPINVOKE.switch_io_event_hook_write_frame_next_set(swigCPtr, switch_io_event_hook_write_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_event_hook_write_frame_next_get(swigCPtr);
-      switch_io_event_hook_write_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_io_event_hook_write_frame(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_io_event_hook_write_frame() : this(freeswitchPINVOKE.new_switch_io_event_hook_write_frame(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_int_p_q_const__char_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20666,15 +21180,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_io_flag_enum_t {
-  SWITCH_IO_FLAG_NONE = 0,
-  SWITCH_IO_FLAG_NOBLOCK = (1 << 0)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_network_list {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_network_list(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_network_list() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_network_list obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20685,175 +21213,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_io_routines : IDisposable {
+public class SWIGTYPE_p_p_switch_network_list {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_io_routines(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_network_list(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_io_routines obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_io_routines() {
-    Dispose();
+  protected SWIGTYPE_p_p_switch_network_list() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_io_routines(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_network_list obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t outgoing_channel {
-    set {
-      freeswitchPINVOKE.switch_io_routines_outgoing_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_outgoing_channel_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_frame {
-    set {
-      freeswitchPINVOKE.switch_io_routines_read_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_read_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_frame {
-    set {
-      freeswitchPINVOKE.switch_io_routines_write_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_write_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t kill_channel {
-    set {
-      freeswitchPINVOKE.switch_io_routines_kill_channel_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_kill_channel_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_sockaddr {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t send_dtmf {
-    set {
-      freeswitchPINVOKE.switch_io_routines_send_dtmf_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_send_dtmf_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_sockaddr(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t receive_message {
-    set {
-      freeswitchPINVOKE.switch_io_routines_receive_message_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_receive_message_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_core_session_message__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_sockaddr() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t receive_event {
-    set {
-      freeswitchPINVOKE.switch_io_routines_receive_event_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_receive_event_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_sockaddr obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t state_change {
-    set {
-      freeswitchPINVOKE.switch_io_routines_state_change_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_state_change_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t read_video_frame {
-    set {
-      freeswitchPINVOKE.switch_io_routines_read_video_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_read_video_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t write_video_frame {
-    set {
-      freeswitchPINVOKE.switch_io_routines_write_video_frame_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_write_video_frame_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t resurrect_session {
-    set {
-      freeswitchPINVOKE.switch_io_routines_resurrect_session_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_resurrect_session_get(swigCPtr);
-      SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_p_void padding {
-    set {
-      freeswitchPINVOKE.switch_io_routines_padding_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_io_routines_padding_get(swigCPtr);
-      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_io_routines() : this(freeswitchPINVOKE.new_switch_io_routines(), true) {
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20861,45 +21300,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_io_routine_name_t {
-  SWITCH_IO_OUTGOING_CHANNEL,
-  SWITCH_IO_READ_FRAME,
-  SWITCH_IO_WRITE_FRAME,
-  SWITCH_IO_KILL_CHANNEL,
-  SWITCH_IO_SEND_DTMF,
-  SWITCH_IO_RECEIVE_MESSAGE,
-  SWITCH_IO_RECEIVE_EVENT,
-  SWITCH_IO_STATE_CHANGE,
-  SWITCH_IO_READ_VIDEO_FRAME,
-  SWITCH_IO_WRITE_VIDEO_FRAME,
-  SWITCH_IO_RESURRECT_SESSION
-}
+using System;
+using System.Runtime.InteropServices;
 
-}
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
- *
- * Do not make changes to this file unless you know what you are doing--modify
- * the SWIG interface file instead.
- * ----------------------------------------------------------------------------- */
+public class SWIGTYPE_p_switch_event_types_t {
+  private HandleRef swigCPtr;
 
-namespace FreeSWITCH.Native {
+  internal SWIGTYPE_p_switch_event_types_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
 
-public enum switch_ivr_action_t {
-  SWITCH_IVR_ACTION_DIE,
-  SWITCH_IVR_ACTION_EXECMENU,
-  SWITCH_IVR_ACTION_EXECAPP,
-  SWITCH_IVR_ACTION_PLAYSOUND,
-  SWITCH_IVR_ACTION_BACK,
-  SWITCH_IVR_ACTION_TOMAIN,
-  SWITCH_IVR_ACTION_NOOP
+  protected SWIGTYPE_p_switch_event_types_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_event_types_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20907,16 +21330,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_ivr_menu_flags {
-  SWITCH_IVR_MENU_FLAG_FALLTOMAIN = (1 << 0),
-  SWITCH_IVR_MENU_FLAG_FREEPOOL = (1 << 1),
-  SWITCH_IVR_MENU_FLAG_STACK = (1 << 2)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_void_p_switch_size_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20924,16 +21360,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_ivr_option_enum_t {
-  SWITCH_IVR_OPTION_NONE = 0,
-  SWITCH_IVR_OPTION_ASYNC = (1 << 0),
-  SWITCH_IVR_OPTION_FILE = (1 << 1)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_mutex_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_mutex_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_mutex_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_mutex_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -20944,86 +21393,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_loadable_module_function_table_t : IDisposable {
+public class SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_loadable_module_function_table_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_loadable_module_function_table_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_loadable_module_function_table_t() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_loadable_module_function_table_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public int switch_api_version {
-    set {
-      freeswitchPINVOKE.switch_loadable_module_function_table_t_switch_api_version_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_loadable_module_function_table_t_switch_api_version_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t load {
-    set {
-      freeswitchPINVOKE.switch_loadable_module_function_table_t_load_set(swigCPtr, SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_load_get(swigCPtr);
-      SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_void__switch_status_t shutdown {
-    set {
-      freeswitchPINVOKE.switch_loadable_module_function_table_t_shutdown_set(swigCPtr, SWIGTYPE_p_f_void__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_shutdown_get(swigCPtr);
-      SWIGTYPE_p_f_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_void__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_socklen_t {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_f_void__switch_status_t runtime {
-    set {
-      freeswitchPINVOKE.switch_loadable_module_function_table_t_runtime_set(swigCPtr, SWIGTYPE_p_f_void__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_loadable_module_function_table_t_runtime_get(swigCPtr);
-      SWIGTYPE_p_f_void__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_void__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_socklen_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_loadable_module_function_table_t() : this(freeswitchPINVOKE.new_switch_loadable_module_function_table_t(), true) {
+  protected SWIGTYPE_p_socklen_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_socklen_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21031,22 +21450,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_log_level_t {
-  SWITCH_LOG_DEBUG = 7,
-  SWITCH_LOG_INFO = 6,
-  SWITCH_LOG_NOTICE = 5,
-  SWITCH_LOG_WARNING = 4,
-  SWITCH_LOG_ERROR = 3,
-  SWITCH_LOG_CRIT = 2,
-  SWITCH_LOG_ALERT = 1,
-  SWITCH_LOG_CONSOLE = 0,
-  SWITCH_LOG_INVALID = 64
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_HashElem {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_HashElem(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_HashElem() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_HashElem obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21057,125 +21483,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_log_node_t : IDisposable {
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_log_node_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_log_node_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_log_node_t() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_p_char_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_log_node_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string data {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_data_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_log_node_t_data_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public string file {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_file_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_log_node_t_file_get(swigCPtr);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t {
+  private HandleRef swigCPtr;
 
-  public uint line {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_line_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_log_node_t_line_get(swigCPtr);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public string func {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_func_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_log_node_t_func_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_log_level_t level {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_level_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_log_level_t ret = (switch_log_level_t)freeswitchPINVOKE.switch_log_node_t_level_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_q_const__char_p_q_const__char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_switch_time_t timestamp {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_timestamp_set(swigCPtr, SWIGTYPE_p_switch_time_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_time_t ret = new SWIGTYPE_p_switch_time_t(freeswitchPINVOKE.switch_log_node_t_timestamp_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string content {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_content_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_log_node_t_content_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public string userdata {
-    set {
-      freeswitchPINVOKE.switch_log_node_t_userdata_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_log_node_t_userdata_get(swigCPtr);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_log_node_t() : this(freeswitchPINVOKE.new_switch_log_node_t(), true) {
+  protected SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21183,16 +21570,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_management_action_t {
-  SMA_NONE,
-  SMA_GET,
-  SMA_SET
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_p_q_const__char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21203,86 +21603,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_management_interface : IDisposable {
+public class SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_management_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_management_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_management_interface() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_enum_switch_audio_col_t_p_q_const__char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_management_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string relative_oid {
-    set {
-      freeswitchPINVOKE.switch_management_interface_relative_oid_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_management_interface_relative_oid_get(swigCPtr);
-      return ret;
-    } 
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_audio_resampler_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_audio_resampler_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t management_function {
-    set {
-      freeswitchPINVOKE.switch_management_interface_management_function_set(swigCPtr, SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_management_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_char_enum_switch_management_action_t_p_char_switch_size_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_audio_resampler_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_management_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_audio_resampler_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_management_interface next {
-    set {
-      freeswitchPINVOKE.switch_management_interface_next_set(swigCPtr, switch_management_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_management_interface_next_get(swigCPtr);
-      switch_management_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_management_interface(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_time_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_time_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_management_interface() : this(freeswitchPINVOKE.new_switch_management_interface(), true) {
+  protected SWIGTYPE_p_switch_time_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_time_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21290,22 +21690,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_media_bug_flag_enum_t {
-  SMBF_BOTH = 0,
-  SMBF_READ_STREAM = (1 << 0),
-  SMBF_WRITE_STREAM = (1 << 1),
-  SMBF_WRITE_REPLACE = (1 << 2),
-  SMBF_READ_REPLACE = (1 << 3),
-  SMBF_READ_PING = (1 << 4),
-  SMBF_STEREO = (1 << 5),
-  SMBF_RECORD_ANSWER_REQ = (1 << 6),
-  SMBF_THREAD_LOCK = (1 << 7)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_time_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_time_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_time_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_time_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21313,21 +21720,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_media_flag_enum_t {
-  SMF_NONE = 0,
-  SMF_REBRIDGE = (1 << 0),
-  SMF_ECHO_ALEG = (1 << 1),
-  SMF_ECHO_BLEG = (1 << 2),
-  SMF_FORCE = (1 << 3),
-  SMF_LOOP = (1 << 4),
-  SMF_HOLD_BLEG = (1 << 5),
-  SMF_IMMEDIATE = (1 << 6)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_void_enum_switch_input_type_t__p_char obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21335,26 +21750,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_module_interface_name_t {
-  SWITCH_ENDPOINT_INTERFACE,
-  SWITCH_TIMER_INTERFACE,
-  SWITCH_DIALPLAN_INTERFACE,
-  SWITCH_CODEC_INTERFACE,
-  SWITCH_APPLICATION_INTERFACE,
-  SWITCH_API_INTERFACE,
-  SWITCH_FILE_INTERFACE,
-  SWITCH_SPEECH_INTERFACE,
-  SWITCH_DIRECTORY_INTERFACE,
-  SWITCH_CHAT_INTERFACE,
-  SWITCH_SAY_INTERFACE,
-  SWITCH_ASR_INTERFACE,
-  SWITCH_MANAGEMENT_INTERFACE
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_sqlite3_stmt {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_sqlite3_stmt(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_p_sqlite3_stmt() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_sqlite3_stmt obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21362,18 +21780,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_originate_flag_enum_t {
-  SOF_NONE = 0,
-  SOF_NOBLOCK = (1 << 0),
-  SOF_FORKED_DIAL = (1 << 1),
-  SOF_NO_EFFECTIVE_CID_NUM = (1 << 2),
-  SOF_NO_EFFECTIVE_CID_NAME = (1 << 3)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_sqlite3_stmt {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_sqlite3_stmt(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_sqlite3_stmt() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_sqlite3_stmt obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21381,16 +21810,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_port_flag_enum_t {
-  SPF_NONE = 0,
-  SPF_ODD = (1 << 0),
-  SPF_EVEN = (1 << 1)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21398,16 +21840,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_priority_t {
-  SWITCH_PRIORITY_NORMAL,
-  SWITCH_PRIORITY_LOW,
-  SWITCH_PRIORITY_HIGH
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_q_const__switch_dtmf_t_enum_switch_dtmf_direction_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21415,16 +21870,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_rtp_crypto_direction_t {
-  SWITCH_RTP_CRYPTO_SEND,
-  SWITCH_RTP_CRYPTO_RECV,
-  SWITCH_RTP_CRYPTO_MAX
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21435,97 +21903,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_rtp_crypto_key : IDisposable {
+public class SWIGTYPE_p_switch_loadable_module_interface {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_rtp_crypto_key(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_switch_loadable_module_interface(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_rtp_crypto_key obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_switch_loadable_module_interface() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_rtp_crypto_key() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_loadable_module_interface obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_rtp_crypto_key(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public uint index {
-    set {
-      freeswitchPINVOKE.switch_rtp_crypto_key_index_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_crypto_key_index_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_rtp_crypto_key_type_t type {
-    set {
-      freeswitchPINVOKE.switch_rtp_crypto_key_type_set(swigCPtr, (int)value);
-    } 
-    get {
-      switch_rtp_crypto_key_type_t ret = (switch_rtp_crypto_key_type_t)freeswitchPINVOKE.switch_rtp_crypto_key_type_get(swigCPtr);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_unsigned_char key {
-    set {
-      freeswitchPINVOKE.switch_rtp_crypto_key_key_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_rtp_crypto_key_key_get(swigCPtr);
-      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t keylen {
-    set {
-      freeswitchPINVOKE.switch_rtp_crypto_key_keylen_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_rtp_crypto_key_keylen_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_p_switch_core_session_p_p_apr_pool_t_p_void__switch_call_cause_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_rtp_crypto_key next {
-    set {
-      freeswitchPINVOKE.switch_rtp_crypto_key_next_set(swigCPtr, switch_rtp_crypto_key.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_rtp_crypto_key_next_get(swigCPtr);
-      switch_rtp_crypto_key ret = (cPtr == IntPtr.Zero) ? null : new switch_rtp_crypto_key(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_char {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_char(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_rtp_crypto_key() : this(freeswitchPINVOKE.new_switch_rtp_crypto_key(), true) {
+  protected SWIGTYPE_p_p_char() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_char obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21533,17 +21990,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_rtp_crypto_key_type_t {
-  NO_CRYPTO,
-  AES_CM_128_HMAC_SHA1_80,
-  AES_CM_128_HMAC_SHA1_32,
-  AES_CM_128_NULL_AUTH
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_p_char {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_p_char(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_p_p_char() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_p_char obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21551,33 +22020,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_rtp_flag_enum_t {
-  SWITCH_RTP_FLAG_NOBLOCK = (1 << 0),
-  SWITCH_RTP_FLAG_IO = (1 << 1),
-  SWITCH_RTP_FLAG_USE_TIMER = (1 << 2),
-  SWITCH_RTP_FLAG_TIMER_RECLOCK = (1 << 3),
-  SWITCH_RTP_FLAG_SECURE_SEND = (1 << 4),
-  SWITCH_RTP_FLAG_SECURE_RECV = (1 << 5),
-  SWITCH_RTP_FLAG_AUTOADJ = (1 << 6),
-  SWITCH_RTP_FLAG_RAW_WRITE = (1 << 7),
-  SWITCH_RTP_FLAG_GOOGLEHACK = (1 << 8),
-  SWITCH_RTP_FLAG_VAD = (1 << 9),
-  SWITCH_RTP_FLAG_BREAK = (1 << 10),
-  SWITCH_RTP_FLAG_MINI = (1 << 11),
-  SWITCH_RTP_FLAG_DATAWAIT = (1 << 12),
-  SWITCH_RTP_FLAG_BUGGY_2833 = (1 << 13),
-  SWITCH_RTP_FLAG_PASS_RFC2833 = (1 << 14),
-  SWITCH_RTP_FLAG_AUTO_CNG = (1 << 15),
-  SWITCH_RTP_FLAG_SECURE_SEND_RESET = (1 << 16),
-  SWITCH_RTP_FLAG_SECURE_RECV_RESET = (1 << 17),
-  SWITCH_RTP_FLAG_PROXY_MEDIA = (1 << 18),
-  SWITCH_RTP_FLAG_SHUTDOWN = (1 << 19)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_channel {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_channel(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_channel() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_channel obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21588,133 +22053,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_rtp_hdr_t : IDisposable {
+public class SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_rtp_hdr_t(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_rtp_hdr_t obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_rtp_hdr_t() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_char_p_char_p_char_p_char_p_char_p_char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_rtp_hdr_t(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public uint version {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_version_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_version_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public uint p {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_p_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_p_get(swigCPtr);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public uint x {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_x_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_x_get(swigCPtr);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t {
+  private HandleRef swigCPtr;
 
-  public uint cc {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_cc_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_cc_get(swigCPtr);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint m {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_m_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_m_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public uint pt {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_pt_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_pt_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle_p_p_char_p_p_char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint seq {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_seq_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_seq_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public uint ts {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_ts_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_ts_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public uint ssrc {
-    set {
-      freeswitchPINVOKE.switch_rtp_hdr_t_ssrc_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_rtp_hdr_t_ssrc_get(swigCPtr);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_channel {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_channel(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_rtp_hdr_t() : this(freeswitchPINVOKE.new_switch_rtp_hdr_t(), true) {
+  protected SWIGTYPE_p_p_switch_channel() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_channel obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21725,86 +22143,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_say_interface : IDisposable {
+public class SWIGTYPE_p_switch_ivr_menu_xml_ctx {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_say_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_switch_ivr_menu_xml_ctx(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_say_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_switch_ivr_menu_xml_ctx() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_say_interface() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu_xml_ctx obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_say_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_say_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_say_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t say_function {
-    set {
-      freeswitchPINVOKE.switch_say_interface_say_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_say_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session_p_char_enum_switch_say_type_t_enum_switch_say_method_t_p_switch_input_args_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_say_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_p_switch_ivr_menu_xml_ctx {
+  private HandleRef swigCPtr;
 
-  public switch_say_interface next {
-    set {
-      freeswitchPINVOKE.switch_say_interface_next_set(swigCPtr, switch_say_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_say_interface_next_get(swigCPtr);
-      switch_say_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_say_interface(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_p_switch_ivr_menu_xml_ctx(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_say_interface() : this(freeswitchPINVOKE.new_switch_say_interface(), true) {
+  protected SWIGTYPE_p_p_switch_ivr_menu_xml_ctx() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_menu_xml_ctx obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21812,17 +22200,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_say_method_t {
-  SSM_NA,
-  SSM_PRONOUNCED,
-  SSM_ITERATED,
-  SSM_COUNTED
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_int {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_int(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_int() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_int obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21830,31 +22230,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_say_type_t {
-  SST_NUMBER,
-  SST_ITEMS,
-  SST_PERSONS,
-  SST_MESSAGES,
-  SST_CURRENCY,
-  SST_TIME_MEASUREMENT,
-  SST_CURRENT_DATE,
-  SST_CURRENT_TIME,
-  SST_CURRENT_DATE_TIME,
-  SST_TELEPHONE_NUMBER,
-  SST_TELEPHONE_EXTENSION,
-  SST_URL,
-  SST_IP_ADDRESS,
-  SST_EMAIL_ADDRESS,
-  SST_POSTAL_ADDRESS,
-  SST_ACCOUNT_NUMBER,
-  SST_NAME_SPELLED,
-  SST_NAME_PHONETIC
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_file_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_file_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_file_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_file_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21862,17 +22260,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_scheduler_flag_enum_t {
-  SSHF_NONE = 0,
-  SSHF_OWN_THREAD = (1 << 0),
-  SSHF_FREE_ARG = (1 << 1),
-  SSHF_NO_DEL = (1 << 2)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_p_switch_loadable_module_interface_p_apr_pool_t__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21883,104 +22293,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_scheduler_task : IDisposable {
+public class SWIGTYPE_p_p_switch_core_port_allocator {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_scheduler_task(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_core_port_allocator(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_scheduler_task obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_scheduler_task() {
-    Dispose();
+  protected SWIGTYPE_p_p_switch_core_port_allocator() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_scheduler_task(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_port_allocator obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public long created {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_created_set(swigCPtr, value);
-    } 
-    get {
-      long ret = freeswitchPINVOKE.switch_scheduler_task_created_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public long runtime {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_runtime_set(swigCPtr, value);
-    } 
-    get {
-      long ret = freeswitchPINVOKE.switch_scheduler_task_runtime_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public uint cmd_id {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_cmd_id_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_scheduler_task_cmd_id_get(swigCPtr);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public string group {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_group_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_scheduler_task_group_get(swigCPtr);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_switch_core_port_allocator {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_void cmd_arg {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_cmd_arg_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_scheduler_task_cmd_arg_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_switch_core_port_allocator(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint task_id {
-    set {
-      freeswitchPINVOKE.switch_scheduler_task_task_id_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_scheduler_task_task_id_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_core_port_allocator() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_scheduler_task() : this(freeswitchPINVOKE.new_switch_scheduler_task(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_core_port_allocator obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -21988,25 +22350,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_session_ctl_t {
-  SCSC_PAUSE_INBOUND,
-  SCSC_HUPALL,
-  SCSC_SHUTDOWN,
-  SCSC_CHECK_RUNNING,
-  SCSC_LOGLEVEL,
-  SCSC_SPS,
-  SCSC_LAST_SPS,
-  SCSC_RECLAIM,
-  SCSC_MAX_SESSIONS,
-  SCSC_SYNC_CLOCK,
-  SCSC_MAX_DTMF_DURATION,
-  SCSC_DEFAULT_DTMF_DURATION
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_unsigned_int_long_long_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22014,17 +22380,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_signal_t {
-  SWITCH_SIG_NONE,
-  SWITCH_SIG_KILL,
-  SWITCH_SIG_XFER,
-  SWITCH_SIG_BREAK
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22032,19 +22410,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_speech_flag_enum_t {
-  SWITCH_SPEECH_FLAG_NONE = 0,
-  SWITCH_SPEECH_FLAG_HASTEXT = (1 << 0),
-  SWITCH_SPEECH_FLAG_PEEK = (1 << 1),
-  SWITCH_SPEECH_FLAG_FREE_POOL = (1 << 2),
-  SWITCH_SPEECH_FLAG_BLOCKING = (1 << 3),
-  SWITCH_SPEECH_FLAG_PAUSE = (1 << 4)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_ivr_menu_action_function_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_ivr_menu_action_function_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_ivr_menu_action_function_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu_action_function_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22055,156 +22443,56 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_speech_handle : IDisposable {
+public class SWIGTYPE_p_switch_ivr_action_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_speech_handle(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_switch_ivr_action_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_speech_handle obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_speech_handle() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_speech_handle(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
-
-  public switch_speech_interface speech_interface {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_speech_interface_set(swigCPtr, switch_speech_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_speech_interface_get(swigCPtr);
-      switch_speech_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_speech_interface(cPtr, false);
-      return ret;
-    } 
-  }
-
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_speech_handle_flags_get(swigCPtr);
-      return ret;
-    } 
-  }
-
-  public string name {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_speech_handle_name_get(swigCPtr);
-      return ret;
-    } 
-  }
-
-  public uint rate {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_rate_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_speech_handle_rate_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_ivr_action_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public uint speed {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_speed_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_speech_handle_speed_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_action_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint samples {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_samples_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_speech_handle_samples_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string voice {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_voice_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_speech_handle_voice_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public string engine {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_engine_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_speech_handle_engine_get(swigCPtr);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public string param {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_param_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_speech_handle_param_get(swigCPtr);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_speech_handle_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_handle_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_speech_handle() : this(freeswitchPINVOKE.new_switch_speech_handle(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__char_p_q_const__char_p_q_const__char_p_q_const__char_p_switch_event_t_p_void__p_switch_xml obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22215,163 +22503,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_speech_interface : IDisposable {
+public class SWIGTYPE_p_p_switch_ivr_digit_stream {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_speech_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_switch_ivr_digit_stream(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_speech_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_speech_interface() {
-    Dispose();
-  }
-
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_speech_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  protected SWIGTYPE_p_p_switch_ivr_digit_stream() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_speech_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_digit_stream obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t speech_open {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_open_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_open_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t speech_close {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_close_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_close_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t speech_feed_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_feed_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_feed_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t speech_read_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_read_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_read_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_void_p_switch_size_t_p_unsigned_long_p_unsigned_long__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_switch_ivr_digit_stream {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_f_p_switch_speech_handle__void speech_flush_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_flush_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle__void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_flush_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle__void(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_switch_ivr_digit_stream(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void speech_text_param_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_text_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_text_param_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_p_q_const__char__void(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_ivr_digit_stream() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void speech_numeric_param_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_numeric_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_numeric_param_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_int__void(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_digit_stream obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void speech_float_param_tts {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_speech_float_param_tts_set(swigCPtr, SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_speech_float_param_tts_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_speech_handle_p_char_double__void(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_speech_interface next {
-    set {
-      freeswitchPINVOKE.switch_speech_interface_next_set(swigCPtr, switch_speech_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_speech_interface_next_get(swigCPtr);
-      switch_speech_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_speech_interface(cPtr, false);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_unsigned_long {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_unsigned_long(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_speech_interface() : this(freeswitchPINVOKE.new_switch_speech_interface(), true) {
+  protected SWIGTYPE_p_unsigned_long() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_long obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22379,15 +22590,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_stack_t {
-  SWITCH_STACK_BOTTOM,
-  SWITCH_STACK_TOP
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_hash {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_hash(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_hash() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_hash obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22395,23 +22620,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_state_handler_name_t {
-  SWITCH_SHN_ON_INIT,
-  SWITCH_SHN_ON_ROUTING,
-  SWITCH_SHN_ON_EXECUTE,
-  SWITCH_SHN_ON_HANGUP,
-  SWITCH_SHN_ON_EXCHANGE_MEDIA,
-  SWITCH_SHN_ON_SOFT_EXECUTE,
-  SWITCH_SHN_ON_CONSUME_MEDIA,
-  SWITCH_SHN_ON_HIBERNATE,
-  SWITCH_SHN_ON_RESET,
-  SWITCH_SHN_ON_PARK
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_hash {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_hash(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_p_switch_hash() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_hash obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22422,164 +22653,146 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_state_handler_table : IDisposable {
+public class SWIGTYPE_p_p_sqlite3 {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_state_handler_table(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_p_sqlite3(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_state_handler_table obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_p_sqlite3() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_state_handler_table() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_sqlite3 obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_state_handler_table(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_init {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_init_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_sqlite3 {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_sqlite3(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_routing {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_routing_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_routing_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_sqlite3() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_execute {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_execute_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_execute_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_sqlite3 obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_hangup {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_hangup_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_hangup_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_ivr_digit_stream_parser {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_ivr_digit_stream_parser(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_exchange_media {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_exchange_media_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_exchange_media_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_ivr_digit_stream_parser() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_soft_execute {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_soft_execute_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_soft_execute_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_digit_stream_parser obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
+
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_consume_media {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_consume_media_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_consume_media_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_hibernate {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_hibernate_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_hibernate_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+public class SWIGTYPE_p_switch_ivr_digit_stream_parser {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_ivr_digit_stream_parser(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_reset {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_reset_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_reset_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_ivr_digit_stream_parser() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_core_session__switch_status_t on_park {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_on_park_set(swigCPtr, SWIGTYPE_p_f_p_switch_core_session__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_on_park_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_core_session__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_core_session__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_digit_stream_parser obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_p_void padding {
-    set {
-      freeswitchPINVOKE.switch_state_handler_table_padding_set(swigCPtr, SWIGTYPE_p_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_state_handler_table_padding_get(swigCPtr);
-      SWIGTYPE_p_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_p_void(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_state_handler_table() : this(freeswitchPINVOKE.new_switch_state_handler_table(), true) {
+  protected SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22587,31 +22800,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_status_t {
-  SWITCH_STATUS_SUCCESS,
-  SWITCH_STATUS_FALSE,
-  SWITCH_STATUS_TIMEOUT,
-  SWITCH_STATUS_RESTART,
-  SWITCH_STATUS_TERM,
-  SWITCH_STATUS_NOTIMPL,
-  SWITCH_STATUS_MEMERR,
-  SWITCH_STATUS_NOOP,
-  SWITCH_STATUS_RESAMPLE,
-  SWITCH_STATUS_GENERR,
-  SWITCH_STATUS_INUSE,
-  SWITCH_STATUS_BREAK,
-  SWITCH_STATUS_SOCKERR,
-  SWITCH_STATUS_MORE_DATA,
-  SWITCH_STATUS_NOTFOUND,
-  SWITCH_STATUS_UNLOAD,
-  SWITCH_STATUS_NOUNLOAD,
-  SWITCH_STATUS_IGNORE
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_frame {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_frame(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_p_switch_frame() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_frame obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22622,146 +22833,146 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_stream_handle : IDisposable {
+public class SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_stream_handle(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_stream_handle obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_stream_handle() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_directory_handle__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_stream_handle(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_ivr_menu {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_ivr_menu(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t write_function {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_write_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_write_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_ivr_menu() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t raw_write_function {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_raw_write_function_set(swigCPtr, SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_raw_write_function_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_stream_handle_p_unsigned_char_switch_size_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_ivr_menu obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_void data {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_data_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_data_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_ivr_menu {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_ivr_menu(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_void end {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_end_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_end_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_ivr_menu() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t data_size {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_data_size_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_data_size_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_ivr_menu obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_switch_size_t data_len {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_data_len_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_data_len_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_unsigned_int {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_unsigned_int(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_switch_size_t alloc_len {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_alloc_len_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_alloc_len_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  protected SWIGTYPE_p_unsigned_int() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t alloc_chunk {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_alloc_chunk_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_stream_handle_alloc_chunk_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_int obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_event param_event {
-    set {
-      freeswitchPINVOKE.switch_stream_handle_param_event_set(swigCPtr, switch_event.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_stream_handle_param_event_get(swigCPtr);
-      switch_event ret = (cPtr == IntPtr.Zero) ? null : new switch_event(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_unsigned_char {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_unsigned_char(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_stream_handle() : this(freeswitchPINVOKE.new_switch_stream_handle(), true) {
+  protected SWIGTYPE_p_unsigned_char() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_unsigned_char obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22769,16 +22980,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_text_channel_t {
-  SWITCH_CHANNEL_ID_LOG,
-  SWITCH_CHANNEL_ID_LOG_CLEAN,
-  SWITCH_CHANNEL_ID_EVENT
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_t_p_void_p_switch_caller_profile_t__p_switch_caller_extension obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22789,140 +23013,146 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_timer : IDisposable {
+public class SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_timer(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_timer obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_timer() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_stream_handle_p_q_const__char_v_______switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_timer(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public int interval {
-    set {
-      freeswitchPINVOKE.switch_timer_interval_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_timer_interval_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_timer_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_timer_flags_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_speech_handle_p_q_const__char_int_p_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public uint samples {
-    set {
-      freeswitchPINVOKE.switch_timer_samples_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_timer_samples_get(swigCPtr);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_core_session_message {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_core_session_message(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint samplecount {
-    set {
-      freeswitchPINVOKE.switch_timer_samplecount_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_timer_samplecount_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_core_session_message() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_timer_interface timer_interface {
-    set {
-      freeswitchPINVOKE.switch_timer_timer_interface_set(swigCPtr, switch_timer_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_timer_interface_get(swigCPtr);
-      switch_timer_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_timer_interface(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_session_message obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_apr_pool_t memory_pool {
-    set {
-      freeswitchPINVOKE.switch_timer_memory_pool_set(swigCPtr, SWIGTYPE_p_apr_pool_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_memory_pool_get(swigCPtr);
-      SWIGTYPE_p_apr_pool_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_apr_pool_t(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_file_handle__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_file_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_void private_info {
-    set {
-      freeswitchPINVOKE.switch_timer_private_info_set(swigCPtr, SWIGTYPE_p_void.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_private_info_get(swigCPtr);
-      SWIGTYPE_p_void ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_void(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_file_handle__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t diff {
-    set {
-      freeswitchPINVOKE.switch_timer_diff_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_timer_diff_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
+
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
 
-  public SWIGTYPE_p_switch_size_t tick {
-    set {
-      freeswitchPINVOKE.switch_timer_tick_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_timer_tick_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_timer__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_timer__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_timer() : this(freeswitchPINVOKE.new_switch_timer(), true) {
+  protected SWIGTYPE_p_f_p_switch_timer__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_timer__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22930,14 +23160,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_timer_flag_enum_t {
-  SWITCH_TIMER_FLAG_FREE_POOL = (1 << 0)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_void__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_void__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_void__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_void__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22945,19 +23190,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_timer_func_name_t {
-  SWITCH_TIMER_FUNC_TIMER_INIT,
-  SWITCH_TIMER_FUNC_TIMER_NEXT,
-  SWITCH_TIMER_FUNC_TIMER_STEP,
-  SWITCH_TIMER_FUNC_TIMER_SYNC,
-  SWITCH_TIMER_FUNC_TIMER_CHECK,
-  SWITCH_TIMER_FUNC_TIMER_DESTROY
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_asr_handle__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -22968,141 +23223,146 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_timer_interface : IDisposable {
+public class SWIGTYPE_p_f_p_switch_codec__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_timer_interface(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_codec__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_timer_interface obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_codec__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_timer_interface() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_codec__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_timer_interface(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_apr_pool_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_apr_pool_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public string interface_name {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_interface_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_timer_interface_interface_name_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_apr_pool_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_init {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_init_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_init_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_apr_pool_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_next {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_next_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_next_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_apr_pool_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_apr_pool_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_step {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_step_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_step_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_apr_pool_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_sync {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_sync_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_sync_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_apr_pool_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t timer_check {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_check_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_check_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer_enum_switch_bool_t__switch_status_t(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_float {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_float(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_f_p_switch_timer__switch_status_t timer_destroy {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_timer_destroy_set(swigCPtr, SWIGTYPE_p_f_p_switch_timer__switch_status_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_timer_destroy_get(swigCPtr);
-      SWIGTYPE_p_f_p_switch_timer__switch_status_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_f_p_switch_timer__switch_status_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_float() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_thread_rwlock_t rwlock {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_rwlock_set(swigCPtr, SWIGTYPE_p_switch_thread_rwlock_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_rwlock_get(swigCPtr);
-      SWIGTYPE_p_switch_thread_rwlock_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_thread_rwlock_t(cPtr, false);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_float obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_timer_interface next {
-    set {
-      freeswitchPINVOKE.switch_timer_interface_next_set(swigCPtr, switch_timer_interface.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_timer_interface_next_get(swigCPtr);
-      switch_timer_interface ret = (cPtr == IntPtr.Zero) ? null : new switch_timer_interface(cPtr, false);
-      return ret;
-    } 
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
+
+namespace FreeSWITCH.Native {
+
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_socket_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_socket_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_timer_interface() : this(freeswitchPINVOKE.new_switch_timer_interface(), true) {
+  protected SWIGTYPE_p_switch_socket_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_socket_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23113,211 +23373,116 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_unicast_conninfo : IDisposable {
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_unicast_conninfo(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_unicast_conninfo obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  ~switch_unicast_conninfo() {
-    Dispose();
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_unicast_conninfo(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public SWIGTYPE_p_switch_core_session session {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_session_set(swigCPtr, SWIGTYPE_p_switch_core_session.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_session_get(swigCPtr);
-      SWIGTYPE_p_switch_core_session ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_core_session(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_codec read_codec {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_read_codec_set(swigCPtr, switch_codec.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_read_codec_get(swigCPtr);
-      switch_codec ret = (cPtr == IntPtr.Zero) ? null : new switch_codec(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public switch_frame write_frame {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_write_frame_set(swigCPtr, switch_frame.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_write_frame_get(swigCPtr);
-      switch_frame ret = (cPtr == IntPtr.Zero) ? null : new switch_frame(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_unsigned_char write_frame_data {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_write_frame_data_set(swigCPtr, SWIGTYPE_p_unsigned_char.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_write_frame_data_get(swigCPtr);
-      SWIGTYPE_p_unsigned_char ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_unsigned_char(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_switch_socket_t socket {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_socket_set(swigCPtr, SWIGTYPE_p_switch_socket_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_socket_get(swigCPtr);
-      SWIGTYPE_p_switch_socket_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_socket_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public string local_ip {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_local_ip_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_unicast_conninfo_local_ip_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_p_switch_core_session_p_p_apr_pool_t_unsigned_long__switch_call_cause_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public ushort local_port {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_local_port_set(swigCPtr, value);
-    } 
-    get {
-      ushort ret = freeswitchPINVOKE.switch_unicast_conninfo_local_port_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string remote_ip {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_remote_ip_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_unicast_conninfo_remote_ip_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public ushort remote_port {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_remote_port_set(swigCPtr, value);
-    } 
-    get {
-      ushort ret = freeswitchPINVOKE.switch_unicast_conninfo_remote_port_get(swigCPtr);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public SWIGTYPE_p_switch_sockaddr_t local_addr {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_local_addr_set(swigCPtr, SWIGTYPE_p_switch_sockaddr_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_local_addr_get(swigCPtr);
-      SWIGTYPE_p_switch_sockaddr_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_sockaddr_t(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_switch_core_session {
+  private HandleRef swigCPtr;
 
-  public SWIGTYPE_p_switch_sockaddr_t remote_addr {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_remote_addr_set(swigCPtr, SWIGTYPE_p_switch_sockaddr_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_remote_addr_get(swigCPtr);
-      SWIGTYPE_p_switch_sockaddr_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_sockaddr_t(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_switch_core_session(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public SWIGTYPE_p_switch_mutex_t flag_mutex {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_flag_mutex_set(swigCPtr, SWIGTYPE_p_switch_mutex_t.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_unicast_conninfo_flag_mutex_get(swigCPtr);
-      SWIGTYPE_p_switch_mutex_t ret = (cPtr == IntPtr.Zero) ? null : new SWIGTYPE_p_switch_mutex_t(cPtr, false);
-      return ret;
-    } 
+  protected SWIGTYPE_p_switch_core_session() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public int flags {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_flags_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_unicast_conninfo_flags_get(swigCPtr);
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_core_session obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public int type {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_type_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_unicast_conninfo_type_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public int transport {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_transport_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_unicast_conninfo_transport_get(swigCPtr);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public int stream_id {
-    set {
-      freeswitchPINVOKE.switch_unicast_conninfo_stream_id_set(swigCPtr, value);
-    } 
-    get {
-      int ret = freeswitchPINVOKE.switch_unicast_conninfo_stream_id_get(swigCPtr);
-      return ret;
-    } 
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_p_switch_core_session {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_p_switch_core_session(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public switch_unicast_conninfo() : this(freeswitchPINVOKE.new_switch_unicast_conninfo(), true) {
+  protected SWIGTYPE_p_p_switch_core_session() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_core_session obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23325,17 +23490,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_unicast_flag_enum_t {
-  SUF_NONE = 0,
-  SUF_THREAD_RUNNING = (1 << 0),
-  SUF_READY = (1 << 1),
-  SUF_NATIVE = (1 << 2)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_file_handle_p_q_const__char__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23343,16 +23520,29 @@
 
 namespace FreeSWITCH.Native {
 
-public enum switch_uri_flags {
-  SWITCH_URI_NUMERIC_HOST = 1,
-  SWITCH_URI_NUMERIC_PORT = 2,
-  SWITCH_URI_NO_SCOPE = 4
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_q_const__char_p_switch_core_session_p_switch_stream_handle__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23360,17 +23550,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_vad_flag_enum_t {
-  SWITCH_VAD_FLAG_TALKING = (1 << 0),
-  SWITCH_VAD_FLAG_EVENTS_TALK = (1 << 1),
-  SWITCH_VAD_FLAG_EVENTS_NOTALK = (1 << 2),
-  SWITCH_VAD_FLAG_CNG = (1 << 3)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_event_p_switch_caller_profile_p_switch_core_session_unsigned_long__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23381,159 +23583,86 @@
 using System;
 using System.Runtime.InteropServices;
 
-public class switch_xml : IDisposable {
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t {
   private HandleRef swigCPtr;
-  protected bool swigCMemOwn;
 
-  internal switch_xml(IntPtr cPtr, bool cMemoryOwn) {
-    swigCMemOwn = cMemoryOwn;
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t(IntPtr cPtr, bool futureUse) {
     swigCPtr = new HandleRef(this, cPtr);
   }
 
-  internal static HandleRef getCPtr(switch_xml obj) {
-    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
-  }
-
-  ~switch_xml() {
-    Dispose();
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public virtual void Dispose() {
-    lock(this) {
-      if(swigCPtr.Handle != IntPtr.Zero && swigCMemOwn) {
-        swigCMemOwn = false;
-        freeswitchPINVOKE.delete_switch_xml(swigCPtr);
-      }
-      swigCPtr = new HandleRef(null, IntPtr.Zero);
-      GC.SuppressFinalize(this);
-    }
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_unsigned_long_int__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public string name {
-    set {
-      freeswitchPINVOKE.switch_xml_name_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_xml_name_get(swigCPtr);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public string attr {
-  set { freeswitchPINVOKE.switch_xml_attr_set(swigCPtr, ref value); }
+namespace FreeSWITCH.Native {
 
-  get {
-    return freeswitchPINVOKE.switch_xml_attr_get(swigCPtr);
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  }
+public class SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t {
+  private HandleRef swigCPtr;
 
-  public string txt {
-    set {
-      freeswitchPINVOKE.switch_xml_txt_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_xml_txt_get(swigCPtr);
-      return ret;
-    } 
+  internal SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public string free_path {
-    set {
-      freeswitchPINVOKE.switch_xml_free_path_set(swigCPtr, value);
-    } 
-    get {
-      string ret = freeswitchPINVOKE.switch_xml_free_path_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public SWIGTYPE_p_switch_size_t off {
-    set {
-      freeswitchPINVOKE.switch_xml_off_set(swigCPtr, SWIGTYPE_p_switch_size_t.getCPtr(value));
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-    } 
-    get {
-      SWIGTYPE_p_switch_size_t ret = new SWIGTYPE_p_switch_size_t(freeswitchPINVOKE.switch_xml_off_get(swigCPtr), true);
-      if (freeswitchPINVOKE.SWIGPendingException.Pending) throw freeswitchPINVOKE.SWIGPendingException.Retrieve();
-      return ret;
-    } 
+  internal static HandleRef getCPtr(SWIGTYPE_p_f_p_switch_core_session_p_switch_frame_p_void__switch_status_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
+}
 
-  public switch_xml next {
-    set {
-      freeswitchPINVOKE.switch_xml_next_set(swigCPtr, switch_xml.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_xml_next_get(swigCPtr);
-      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-      return ret;
-    } 
-  }
+}
+/* ----------------------------------------------------------------------------
+ * This file was automatically generated by SWIG (http://www.swig.org).
+ * Version 1.3.36
+ *
+ * Do not make changes to this file unless you know what you are doing--modify
+ * the SWIG interface file instead.
+ * ----------------------------------------------------------------------------- */
 
-  public switch_xml sibling {
-    set {
-      freeswitchPINVOKE.switch_xml_sibling_set(swigCPtr, switch_xml.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_xml_sibling_get(swigCPtr);
-      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-      return ret;
-    } 
-  }
+namespace FreeSWITCH.Native {
 
-  public switch_xml ordered {
-    set {
-      freeswitchPINVOKE.switch_xml_ordered_set(swigCPtr, switch_xml.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_xml_ordered_get(swigCPtr);
-      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-      return ret;
-    } 
-  }
+using System;
+using System.Runtime.InteropServices;
 
-  public switch_xml child {
-    set {
-      freeswitchPINVOKE.switch_xml_child_set(swigCPtr, switch_xml.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_xml_child_get(swigCPtr);
-      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-      return ret;
-    } 
-  }
+public class SWIGTYPE_p_p_switch_xml {
+  private HandleRef swigCPtr;
 
-  public switch_xml parent {
-    set {
-      freeswitchPINVOKE.switch_xml_parent_set(swigCPtr, switch_xml.getCPtr(value));
-    } 
-    get {
-      IntPtr cPtr = freeswitchPINVOKE.switch_xml_parent_get(swigCPtr);
-      switch_xml ret = (cPtr == IntPtr.Zero) ? null : new switch_xml(cPtr, false);
-      return ret;
-    } 
+  internal SWIGTYPE_p_p_switch_xml(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
   }
 
-  public uint flags {
-    set {
-      freeswitchPINVOKE.switch_xml_flags_set(swigCPtr, value);
-    } 
-    get {
-      uint ret = freeswitchPINVOKE.switch_xml_flags_get(swigCPtr);
-      return ret;
-    } 
+  protected SWIGTYPE_p_p_switch_xml() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
   }
 
-  public switch_xml() : this(freeswitchPINVOKE.new_switch_xml(), true) {
+  internal static HandleRef getCPtr(SWIGTYPE_p_p_switch_xml obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
   }
-
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23541,17 +23670,29 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_xml_flag_t {
-  SWITCH_XML_ROOT = (1 << 0),
-  SWITCH_XML_NAMEM = (1 << 1),
-  SWITCH_XML_TXTM = (1 << 2),
-  SWITCH_XML_DUP = (1 << 3)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_FILE {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_FILE(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_FILE() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_FILE obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }
 /* ----------------------------------------------------------------------------
  * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 1.3.35
+ * Version 1.3.36
  *
  * Do not make changes to this file unless you know what you are doing--modify
  * the SWIG interface file instead.
@@ -23559,12 +23700,23 @@
 
 namespace FreeSWITCH.Native {
 
-[System.Flags] public enum switch_xml_section_enum_t {
-  SWITCH_XML_SECTION_RESULT = 0,
-  SWITCH_XML_SECTION_CONFIG = (1 << 0),
-  SWITCH_XML_SECTION_DIRECTORY = (1 << 1),
-  SWITCH_XML_SECTION_DIALPLAN = (1 << 2),
-  SWITCH_XML_SECTION_PHRASES = (1 << 3)
+using System;
+using System.Runtime.InteropServices;
+
+public class SWIGTYPE_p_switch_thread_rwlock_t {
+  private HandleRef swigCPtr;
+
+  internal SWIGTYPE_p_switch_thread_rwlock_t(IntPtr cPtr, bool futureUse) {
+    swigCPtr = new HandleRef(this, cPtr);
+  }
+
+  protected SWIGTYPE_p_switch_thread_rwlock_t() {
+    swigCPtr = new HandleRef(null, IntPtr.Zero);
+  }
+
+  internal static HandleRef getCPtr(SWIGTYPE_p_switch_thread_rwlock_t obj) {
+    return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
+  }
 }
 
 }



More information about the Freeswitch-svn mailing list