亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? gc_basic_call_model.c

?? dialogic gcwithvoice
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):

#ifdef _WIN32	/* Defined in Windows */  
	struct _timeb	  Timeb;										/* used to get milliseconds */
#else			/* Defined in Unix	*/
	struct timeb		Timeb;	  
#endif
	 
	/* Put time stamp	 - everything but the milliseconds */
	TimeStr[0] = '\0';
	time(&Timet);
	Time = localtime(&Timet);

#ifdef _WIN32	/* Defined in Windows */  
	_ftime(&Timeb);												/* needed to get the milliseconds */
#else			/* Defined in Unix	 */  
	ftime(&Timeb); 
#endif

	if (fp){
		fprintf(fp, "%02d/%02d %02d:%02d:%02d.%03d ", Time->tm_mon+1, Time->tm_mday, Time->tm_hour, Time->tm_min, Time->tm_sec, Timeb.millitm);
		fprintf(fp, ": %10s, %s\n", devname, messages);
		fclose(fp);
	}
	return;
}

/********************************************************************************
 *			NAME: main ()
 *DESCRIPTION: This is the entry point. 
 *					It loads the configuration file.
 *					Take cares the	 Event Handling process.
 *					Starts GC Library.
 *					Opens Configured Devices.
 *					Waits for user interrupted signal (ctrl+c).
 *					Whenever an event is received on any of the opened 
 *					devices, Depending upon the event received the proper 
 *					action will be taken.
 *		  INPUT: None
 *		RETURNS: 0 if success else -1
 ********************************************************************************/
int main(int argc, char *argv[])
{
	int						i, ret;
	char						str[MAX_STRING_SIZE], str1[MAX_STRING_SIZE];
	GC_CCLIB_STATUSALL	cclib_status_all;

	/* Note down the start time for the test */
	time(&start_time);

	
	/* Give control to Event Handler */ 
#ifdef _WIN32
	signal(SIGINT, (void (__cdecl*)(int)) intr_hdlr);
	signal(SIGTERM, (void (__cdecl*)(int)) intr_hdlr);
#else
	signal(SIGHUP, (void (*)()) intr_hdlr);
	signal(SIGQUIT, (void (*)()) intr_hdlr);
	signal(SIGINT, (void (*)()) intr_hdlr);
	signal(SIGTERM, (void (*)()) intr_hdlr);
#endif

	init_srl_mode();									/* set SRL mode to ASYNC, polled */

	/* Load Configuration file */
	load_config_file();
	if ( ( introfd = fileopen( INTRO_VOX, O_RDONLY ) ) == -1 ) {
      sprintf( tmpbuff, "Cannot fileopen %s", INTRO_VOX );
      QUIT( 1 );
   }

   if ( ( invalidfd = fileopen( INVALID_VOX, O_RDONLY ) ) == -1 ) {
      sprintf( tmpbuff, "Cannot fileopen %s", INVALID_VOX );
      QUIT( 1 );
   }

   if ( ( goodbyefd = fileopen( GOODBYE_VOX, O_RDONLY ) ) == -1 ) {
      sprintf( tmpbuff, "Cannot fileopen %s", GOODBYE_VOX );
      QUIT( 1 );
   }

   if ( ( blankfd = fileopen( BLANK_VOX, O_RDONLY ) ) == -1 ) {
      sprintf( tmpbuff, "Cannot fileopen %s", BLANK_VOX );
      QUIT( 1 );
   }

	/* Function to open all the logfiles */
	//printError("System", "Application start");
	//open_all_logfiles();
	if (num_devices == 0) {
		exitdemo(1);
	}
	printandlog(ALL_DEVICES, MISC, NULL, "********** GC DEMO - BASIC CALL MODEL ***********\n", 0);
	
	/* Start GlobalCall */
	if (gc_Start(NULL) != GC_SUCCESS) { 
		sprintf(str, "gc_Start(startp = NULL) Failed");
		printandlog(ALL_DEVICES, GC_APIERR, NULL, str, 0);
		exitdemo(1);
	}
	/* Set the flag gc_started to YES */
	gc_started = YES;
	sprintf(str, "gc_Start(startp = NULL) Success");
	printandlog(ALL_DEVICES, GC_APICALL, NULL, str, 0);


	/* this code is usefule for installation problem debugging */
	/* you may not wish to use this code in production systems */
	if (gc_CCLibStatusEx("GC_ALL_LIB", &cclib_status_all) != GC_SUCCESS) {
		sprintf(str, "gc_CCLibStatusEx(GC_ALL_LIB, &cclib_status_all) Failed");
		printandlog(ALL_DEVICES, GC_APIERR, NULL, str, 0);
		exitdemo(1);
	}	
	strcpy(str, " Call Control Library Status:\n");
	for (i = 0; i < GC_TOTAL_CCLIBS; i++) {
		switch (cclib_status_all.cclib_state[i].state) {
			case GC_CCLIB_CONFIGURED:
				sprintf(str1, "		  %s - configured\n", cclib_status_all.cclib_state[i].name);
				break;

			case GC_CCLIB_AVAILABLE:
				sprintf(str1, "		  %s - available\n", cclib_status_all.cclib_state[i].name);
				break;

			case GC_CCLIB_FAILED:
				sprintf(str1, "		  %s - is not available for use\n", cclib_status_all.cclib_state[i].name);
				break;

			default:
				sprintf(str1, "		  %s - unknown CCLIB status\n", cclib_status_all.cclib_state[i].name);
				break;


		}
		strcat(str, str1);
	}
	printandlog(ALL_DEVICES, MISC, NULL, str, 0);

	/* open all the GC devices */
	open_all_devices(); 
	
	/* 
	-- Forever loop where the main work is done - wait for an event or user requested exit
	*/
	for (;;) {
		ret = sr_waitevt(500);					/* 1/2 second */
		if (ret != -1) {							/* i.e. not timeout */
			process_event();
		}

		if (interrupted == NO) {				/* flag set in intr_hdlr() */
			drop_outbound_calls_if_required();/* an artifact of the demo program */
														/* where the outbound side disconnects 1-2 */
														/* seconds after connected */

			make_calls_if_required();			/* handles error conditions on makecall */
		} else {
			initiate_exit();
			if (reset_linedevs_left_to_complete == 0) {
				exitdemo(1);
			}
		}

	}
} /* End of Main */

/****************************************************************
*			NAME: void init_srl_mode(void)
* DESCRIPTION: Inits SR mode
*		RETURNS: None
*	  CAUTIONS: NA
****************************************************************/
static void init_srl_mode(void)
{
/* 
SRL MODEL TYPE - Single Threaded Async, event handler will be called in the Main thread 
*/
#ifdef _WIN32
	int	mode = SR_STASYNC | SR_POLLMODE; 
#else
	int	mode = SR_POLLMODE;
#endif
	

	/* Set SRL mode */
#ifdef _WIN32
	if (sr_setparm(SRL_DEVICE, SR_MODELTYPE, &mode) == -1) {
		printandlog(ALL_DEVICES, NON_GC_APIERR, NULL, "Unable to set to SR_STASYNC | SR_POLLMODE", 0);
		exitdemo(1);
	}
	printandlog(ALL_DEVICES, MISC, NULL, "SRL Model Set to SR_STASYNC | SR_POLLMODE", 0);
#else
	if (sr_setparm(SRL_DEVICE, SR_MODEID, &mode) == -1) {
		printandlog(ALL_DEVICES, NON_GC_APIERR, NULL, "Unable to set mode ID to SR_POLLMODE ", 0);
		exitdemo(1);
	}
	
	printandlog(ALL_DEVICES, MISC, NULL, "SRL mode ID set to SR_POLLMODE", 0);
#endif
}

/****************************************************************
*			NAME: open_all_logfiles(void)
* DESCRIPTION: Function to Open the Logfiles and put file pointers in file 
*					pointer field of port array. Later depending upon the index the
*					particular file can be accessed to dump the data.
*					If the network device name is present, then the log file
*					uses the network device name
*					else it uses the voice device name
*		RETURNS: returns 1 if successful
*	  CAUTIONS: Assumes device name includes network device name or a voice device name
****************************************************************/
static int open_all_logfiles(void)
{	
	char		temp_filename[MAX_DEVNAME], temp_str[MAX_STRING_SIZE];
	char		*i;
	int		index;

	for (index = 0; index < num_devices; index++) {
		/* build up temp_filename */
		strcpy(temp_filename, logfile);

		/* case 1: if dti name exists, use it */
		if (strcmp(port[index].netdevice, "NONE") != 0) {
			/* IP has different "dti" name than NON-IP */
			if (port[index].netdevice[0] == 'i') {
				sscanf(port[index].devname, ":N_ipt%[^:]", temp_str); 
			} else {
				if (strstr(port[index].devname,"N_dum")){
					sscanf(port[index].devname, ":N_dum%[^:]", temp_str); 
				}else{
					sscanf(port[index].devname, ":N_dti%[^:]", temp_str); 
				}
			}
			strcat(temp_filename,  "_");
			strcat(temp_filename, temp_str);
		}
		/* case 2: if voice name exists, use it */
		else if (strcmp(port[index].voicedevice, "NONE") != 0) {
			i = (char *)strstr(port[index].voicedevice, "B");
			strcpy(temp_str, i);
			strcat(temp_filename,  "_");
			strcat(temp_filename, temp_str);
		} else {
			//printf("Missing both DTI and Voice resource in config file device name (%s)\n", port[index].devname);
			exitdemo(1);
		}		
		strcat(temp_filename, ".log");

		if ((port[index].log_fp = fopen(temp_filename, "w")) == NULL) {
			//printf("\nCannot open log file %s for write\n", temp_filename);
			perror("Reason is: ");
			exitdemo(1);
		}
		//printf("%s successfully opened\n", temp_filename); 
		
	} /* End of for loop */
	return 1;
}

/****************************************************************
*			NAME: inbound_application(struct channel *pline)
* DESCRIPTION: Place holder for your inbound application code in the connected state
*		  INPUT: pline - pointer to port data structure
*		RETURNS: NA
*	  CAUTIONS: none
****************************************************************/
static void inbound_application(struct channel *pline)
{
	/* Place holder - your app code goes here */
	int channum = pline->index;
	
	if (pline->chdev == 0){
		return;
	}

	pline->state = ST_INTRO;
	if (dx_clrdigbuf(pline->chdev) == -1) { 
		printandlog(pline->index, VOICE, NULL, "dx_clrdigbuf failed!\n", 0);
	}
	
	if ( play( channum, INTRO_VOX ) == -1 ) {
		sprintf( tmpbuff, "Error playing Introduction on channel %s", ATDV_NAMEP( pline->chdev ) );
		printandlog(pline->index, VOICE, NULL, tmpbuff, 0);
	}else{
		sprintf( tmpbuff, "Playing Introduction on channel %s", ATDV_NAMEP( pline->chdev ) );
		printandlog(pline->index, VOICE, NULL, tmpbuff, 0);
	}

}
/****************************************************************
*			NAME: outbound_application(struct channel *pline)
* DESCRIPTION: Place holder for your outbound application code in the connected state
*		  INPUT: pline - pointer to port data structure
*		RETURNS: NA
*	  CAUTIONS: none
****************************************************************/
static void outbound_application(struct channel *pline)
{

	// Place holder - your app code goes here
	int channum = pline->index;
	
	if (pline->chdev == 0){
		return;
	}

	pline->state = ST_PLAY;

	if (dx_clrdigbuf(pline->chdev) == -1) { 
		printandlog(pline->index, VOICE, NULL, "dx_clrdigbuf failed!\n", 0);
	}
	if ( play( channum, GOODBYE_VOX ) == -1 ) {
		sprintf( tmpbuff, "Error playing Goodbye on channel %s", ATDV_NAMEP( pline->chdev ) );
		printandlog(pline->index, VOICE, NULL, tmpbuff, 0);
	}


}

/****************************************************************
*			NAME: drop_outbound_calls_if_required(void)
* DESCRIPTION: This drops outbound side calls if required
*					For purposes of the demo, a call stays in the connected
*					state state for a second or two, then is dropped by the outbound side
*					Your application does not need this code
*					and hence it is not optimized
*		RETURNS: NA
*	  CAUTIONS: none
****************************************************************/
static void drop_outbound_calls_if_required(void)
{
	int					index;
	struct channel		*pline;
	time_t				current_time;								/* in seconds */
	char					str[MAX_STRING_SIZE];
	int					callindex;

	/* get the current time in seconds */
	time(&current_time);

	/* check all devices for an "expired" drop call time */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区蜜桃网| 久久蜜臀中文字幕| 波波电影院一区二区三区| 蜜桃在线一区二区三区| 午夜亚洲国产au精品一区二区| 亚洲人成人一区二区在线观看 | 最新不卡av在线| 国产欧美一二三区| 日韩毛片精品高清免费| 亚洲日本成人在线观看| 亚洲人成精品久久久久久| 亚洲视频一二区| 一个色综合av| 日韩精品免费视频人成| 日韩成人一级片| 九色综合国产一区二区三区| 精品在线免费观看| 国产不卡免费视频| 99在线精品观看| 欧美丝袜丝交足nylons| 91精品国产色综合久久| 久久婷婷久久一区二区三区| 国产精品色哟哟| 一区二区三区波多野结衣在线观看| 亚洲国产精品综合小说图片区| 亚洲成av人片在www色猫咪| 视频在线观看91| 国产精品自拍三区| 91成人免费网站| 日韩精品一区国产麻豆| 欧美激情在线免费观看| 亚洲卡通动漫在线| 美国av一区二区| 成人av集中营| 欧美高清精品3d| 中文字幕免费一区| 亚洲mv在线观看| 国产成人自拍在线| 欧美日韩国产一区| 久久综合狠狠综合久久综合88| 亚洲天天做日日做天天谢日日欢| 日韩电影免费在线看| caoporn国产精品| 日韩一区二区免费高清| 中文字幕一区二区三区不卡| 日本少妇一区二区| 成人avav在线| 日韩欧美成人午夜| 亚洲高清久久久| 粗大黑人巨茎大战欧美成人| 在线电影一区二区三区| 亚洲天堂av老司机| 国产一区二区剧情av在线| 欧美午夜电影网| 国产精品久久一卡二卡| 激情综合色丁香一区二区| 在线视频你懂得一区二区三区| 精品日韩一区二区三区免费视频| 夜夜精品视频一区二区| 国产v日产∨综合v精品视频| 欧美一区二区福利视频| 一区二区三区波多野结衣在线观看 | 精品亚洲国产成人av制服丝袜 | 日韩一区二区麻豆国产| 一个色妞综合视频在线观看| 波多野结衣精品在线| 精品久久一区二区| 午夜激情一区二区三区| 99久久精品免费看国产| 久久精品一区二区三区不卡牛牛| 日韩精品电影一区亚洲| 在线观看日韩精品| 亚洲精品国产无天堂网2021| www..com久久爱| 亚洲国产精品ⅴa在线观看| 国产精品一区二区在线观看网站| 日韩久久久精品| 久久精品国产精品亚洲红杏| 91麻豆精品国产91久久久久| 亚洲国产视频网站| 欧美色倩网站大全免费| 亚洲精品第1页| 91国产丝袜在线播放| 亚洲人成人一区二区在线观看 | 国产在线播放一区二区三区| 69久久夜色精品国产69蝌蚪网| 亚洲国产一区二区视频| 8v天堂国产在线一区二区| 香蕉av福利精品导航| 欧美绝品在线观看成人午夜影视| 午夜电影一区二区三区| 91精品久久久久久久久99蜜臂| 欧美aⅴ一区二区三区视频| 日韩欧美一二三区| 九色综合狠狠综合久久| 久久免费美女视频| 99在线热播精品免费| 亚洲三级在线播放| 欧美日韩1区2区| 久久精品国产一区二区| 国产亚洲制服色| 91在线视频观看| 午夜久久久久久电影| 精品乱人伦小说| 成人午夜视频网站| 亚洲永久精品大片| 精品久久久影院| 成人app下载| 日欧美一区二区| 国产亚洲一区二区三区| 99精品黄色片免费大全| 午夜精品福利久久久| 欧美成人精品高清在线播放| 亚洲国产成人va在线观看天堂| 日韩免费性生活视频播放| 成人一区二区三区| 性做久久久久久久免费看| 欧美精品一区二区精品网| 一本一本久久a久久精品综合麻豆| 午夜伊人狠狠久久| 久久一区二区三区国产精品| 在线欧美日韩国产| 国产在线精品免费av| 亚洲精品中文在线| 久久综合久色欧美综合狠狠| 91久久人澡人人添人人爽欧美| 麻豆一区二区三| 亚洲色图色小说| 久久久精品黄色| 在线看国产日韩| 国产成人精品一区二区三区网站观看| 亚洲激情自拍视频| 中文字幕欧美区| 欧美成人a∨高清免费观看| 色欧美日韩亚洲| 精品一区二区三区久久| 亚洲国产你懂的| 亚洲区小说区图片区qvod| 久久精品欧美一区二区三区不卡| 日本丶国产丶欧美色综合| 国产风韵犹存在线视精品| 日本美女一区二区三区视频| 亚洲免费av在线| 国产欧美一区在线| 欧美老肥妇做.爰bbww视频| 91麻豆高清视频| 丁香天五香天堂综合| 精品写真视频在线观看| 日韩国产在线观看| 亚洲免费资源在线播放| 中文在线一区二区| 2020国产精品| 日韩免费看网站| 欧美一二三区精品| 51精品秘密在线观看| 欧美色综合久久| 在线观看www91| 97精品视频在线观看自产线路二 | 日韩中文欧美在线| 亚洲chinese男男1069| 亚洲影院在线观看| 亚洲最大成人综合| 亚洲最色的网站| 亚洲已满18点击进入久久| 一区二区三区欧美在线观看| 国产精品久久久久7777按摩| 国产欧美一区二区在线| 久久久久久久久久久久久夜| 精品国产1区二区| 精品国产凹凸成av人网站| www激情久久| 久久久不卡网国产精品二区| 国产人伦精品一区二区| 国产欧美精品一区| 国产精品每日更新在线播放网址| 国产精品三级久久久久三级| 国产精品你懂的在线| 成人欧美一区二区三区| 亚洲精品免费播放| 亚洲.国产.中文慕字在线| 蜜桃av一区二区在线观看 | 成人免费高清在线观看| 成人黄色电影在线| 91高清视频免费看| 7777精品伊人久久久大香线蕉最新版| 91麻豆精品国产综合久久久久久| 欧美α欧美αv大片| 国产亚洲精品aa午夜观看| 国产精品久久久久四虎| 一区二区三区中文字幕在线观看| 午夜精品久久久久久久蜜桃app| 亚洲18女电影在线观看| 韩国成人在线视频| 91蝌蚪porny九色| 欧美日韩亚洲高清一区二区| 精品第一国产综合精品aⅴ| 中文字幕一区视频| 亚洲va韩国va欧美va| 国产美女视频91| 日本丶国产丶欧美色综合|