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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? irc-core.c

?? Serveez是一個服務器框架
?? C
字號:
/* * irc-core.c - IRC core protocol functions * * Copyright (C) 2000 Stefan Jahn <stefan@lkcc.org> * * This is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. *  * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. *  * You should have received a copy of the GNU General Public License * along with this package; see the file COPYING.  If not, write to * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA.   * * $Id: irc-core.c,v 1.26 2001/06/27 20:38:36 ela Exp $ * */#if HAVE_CONFIG_H# include <config.h>#endif#if ENABLE_IRC_PROTO#define _GNU_SOURCE#include <stdio.h>#include <string.h>#include <ctype.h>#ifdef __MINGW32__# include <winsock2.h>#endif#include "libserveez.h"#include "irc-core.h"#include "irc-server/irc-proto.h"irc_request_t irc_request; /* single IRC request */char irc_lcset[256];       /* lower case character set *//* * Gets called when a nslookup coserver has resolved a IP address * for socket SOCK. */static intirc_nslookup_done (char *host, int id, int version){  irc_client_t *client;  svz_socket_t *sock = svz_sock_find (id, version);  if (sock)    {      client = sock->data;      client->flag |= UMODE_DNS;      if (host)	{	  if (client->host)	    svz_free (client->host);	  client->host = svz_strdup (host);	  irc_printf (sock, "NOTICE AUTH :%s\n", IRC_DNS_DONE);	}      else	{	  irc_printf (sock, "NOTICE AUTH :%s\n", IRC_DNS_NOREPLY);	}      return 0;    }  return -1;}/* * Gets called when an ident coserver has got a reply * for socket SOCK. */static intirc_ident_done (char *user, int id, int version){  irc_client_t *client;  svz_socket_t *sock = svz_sock_find (id, version);  if (sock)    {      client = sock->data;      client->flag |= UMODE_IDENT;      if (user)	{	  if (client->user)	    svz_free (client->user);	  client->user = svz_strdup (user);	  irc_printf (sock, "NOTICE AUTH :%s\n", IRC_IDENT_DONE);	}      else	{	  irc_printf (sock, "NOTICE AUTH :%s\n", IRC_IDENT_NOREPLY);	}      return 0;    }  return -1;}/* * Initialization of the authentication (DNS and IDENT) for an * IRC client. */static voidirc_start_auth (svz_socket_t *sock){  irc_config_t *cfg = sock->cfg;  irc_client_t *client;        /*    * Create and initialize a local IRC client ! This is not yet within the   * actual client hash.    */  client = irc_create_client (cfg);  client->server = svz_strdup (cfg->host);  client->since = time (NULL);  client->sock = sock;  sock->data = client;  /* Set password flag, if there is not server password defined. */  if (!cfg->pass)     client->flag |= UMODE_PASS;  /* Start here the nslookup and ident lookup. */  svz_coserver_rdns (sock->remote_addr, irc_nslookup_done, 		     sock->id, sock->version);  irc_printf (sock, "NOTICE AUTH :" IRC_DNS_INIT "\n");        svz_coserver_ident (sock, irc_ident_done, sock->id, sock->version);  irc_printf (sock, "NOTICE AUTH :" IRC_IDENT_INIT "\n");}/* * Detection routine for the IRC protocol. Returns no-zero if an * IRC connection has been detected. Otherwise zero. */intirc_detect_proto (svz_server_t *server, svz_socket_t *sock){  int ret = 0;  if (sock->recv_buffer_fill >= 1 && sock->recv_buffer[0] == ':')    {      ret = 1;    }  else if (sock->recv_buffer_fill >= 4 && 	   (!memcmp (sock->recv_buffer, "PASS", 4) ||	    !memcmp (sock->recv_buffer, "NICK", 4) ||	    !memcmp (sock->recv_buffer, "USER", 4)))    {      ret = 4;    }  if (ret)    {#if ENABLE_DEBUG      svz_log (LOG_DEBUG, "irc protocol detected\n");#endif      return -1;    }    return 0;}/* * When a client connection has been identified by IRC_DETECT_PROTO * this routine is called to setup this socket for an IRC connection. */intirc_connect_socket (svz_server_t *server, svz_socket_t *sock){  sock->check_request = irc_check_request;  sock->disconnected_socket = irc_disconnect;  sock->idle_func = irc_idle;  sock->idle_counter = 1;  irc_start_auth (sock);  return 0;}/* * The CHECK_REQUEST looks through the receive buffer of the  * IRC connection for complete messages and calls then the * HANDLE_REQUEST function. */intirc_check_request (svz_socket_t *sock){  int retval = 0;  int request_len = 0;  char *p, *packet;  p = sock->recv_buffer;  packet = p;  do    {      while (p < sock->recv_buffer + sock->recv_buffer_fill && *p != '\n')        p++;      if (*p == '\n' && p < sock->recv_buffer + sock->recv_buffer_fill)        {          p++;          request_len += (p - packet);#if 0	  svz_hexdump (stdout, "irc packet", sock->sock_desc,		       packet, p - packet, 0);#endif          retval = irc_handle_request (sock, packet, p - packet - 				       ((*(p - 2) == '\r') ? 2 : 1));          packet = p;        }    }  while (p < sock->recv_buffer + sock->recv_buffer_fill && !retval);    if (request_len > 0 && request_len < sock->recv_buffer_fill)    {      memmove (sock->recv_buffer, packet,	       sock->recv_buffer_fill - request_len);    }  sock->recv_buffer_fill -= request_len;  return retval;}/* * Parse the 'nr'th string (IRC targets could be channels, nicks, etc.)  * by a given IRC parameter string. All these strings should be separated  * by colons (','). */char *irc_get_target (char *para, int nr){  static char target[MAX_NAME_LEN];  char *p;  int n;  target[0] = '\0';  p = para;  for (n = 0; *p && n < nr; n++)    while (*p && *p != ',')      p++;    /* got a key (first or any ',' separated) */  if (*p == ',' || p == para)    {      n = 0;      if (*p == ',')	p++;      while (*p && *p != ',')	{	  target[n++] = *p++;	}      target[n + 1] = 0;    }  return target;}/* * This routine parses a complete IRC message and fills in * all the information into the request structure. */intirc_parse_request (char *request, int len){  char *p;  int n, paras;  int size = 0;  memset (&irc_request, 0, sizeof (irc_request_t));    p = request;  /* parse message origin if necessary */  if (*p == ':')    {      n = 0;      /* get server or nick */      while (*p != '!' && *p != '@' && *p != ' ' && size < len) 	{	  irc_request.server[n] = *p;	  irc_request.nick[n++] = *p++;	  size++;	}      /* user follows */      if (*p == '!')	{	  n = 0;	  p++;	  size++;	  while (*p != '@' && *p != ' ' && size < len) 	    {	      irc_request.user[n++] = *p++;	      size++;	    }	}      /* host follows */      if (*p == '@')	{	  n = 0;	  p++;	  size++;	  while (*p != ' ' && size < len) 	    {	      irc_request.host[n++] = *p++;	      size++;	    }	}      /* skip whitespace(s) */      while (*p == ' ' && size < len)	{	  size++;	  p++;	}    }  /* no message origin, command follow */  n = 0;  while (*p != ' ' && size < len)    {      irc_request.request[n++] = *p++;      size++;    }  /* get parameter(s) */  paras = 0;  while (size < len)    {      /* skip whitespace(s) */      while (*p == ' ' && size < len) 	{	  size++;	  p++;	}      if (size == len)	break;            /* get next parameter */      n = 0;            /* trailing parameter ? */      if (*p == ':')	{	  p++;	  size++;	  while (size < len)	    {	      irc_request.para[paras][n++] = *p++;	      size++;	    }	}            /* normal parameter */      else	{	  while (*p != ' ' && size < len)	    {	      irc_request.para[paras][n++] = *p++;	      size++;	    }	}      paras++;    }  if (paras > 0 && irc_request.para[paras - 1][0] == '\0')    paras--;  irc_request.paras = paras;  irc_parse_target (&irc_request, 0);    return 0;}/* * This function parses one of the given requests paras * and stores all targets in its targets. */voidirc_parse_target (irc_request_t *request, int para){  int i, size, n, len;  char *p;    request->targets = 0;  /* is there a para ? */  if (request->paras <= para)    return;  /* yes, start parsing */  i = 0;  size = 0;  p = request->para[para];  len = strlen (request->para[para]);  while (size < len)    {      /* local channel */      if (*p == '&')	{	  n = 0;	  while (*p != ',' && size < len)	    {	      request->target[i].channel[n++] = *p++;	      size++;	    }	}      /* mask */      else if (*p == '$')	{	  n = 0;	  while (*p != ',' && size < len)	    {	      request->target[i].mask[n++] = *p++;	      size++;	    }	}      /* channel or mask */      else if (*p == '#')	{	  n = 0;	  while (*p != ',' && size < len)	    {	      request->target[i].mask[n] = *p;	      request->target[i].channel[n++] = *p++;	      size++;	    }	}      /* nick or user@host */      else	{	  n = 0;	  while (*p != ',' && *p != '@' && size < len)	    {	      request->target[i].user[n] = *p;	      request->target[i].nick[n++] = *p++;	      size++;	    }	  /* host */	  if (*p == '@')	    {	      p++;	      size++;	      n = 0;	      memset (request->target[i].nick, 0, MAX_NICK_LEN);	      while (*p != ',' && size < len)		{		  request->target[i].host[n++] = *p++;		  size++;		}	    }	}      if (*p == ',')	{	  size++;	  p++;	}      i++;    }  request->targets = i;}/* * This routine just tries to match two strings. It returns non zero * if it does. Because IRC is case insensitive we use the lower case * character set for comparisons. */intirc_string_regex (char *text, char *regex){  char *p;  /* parse until end of both strings */  while (*regex && *text)    {      /* find end of strings or '?' or '*' */      while (*regex != '*' && *regex != '?' && *regex && *text)	{	  /* return no match if so */	  if (irc_lcset[(unsigned) *text] != irc_lcset[(unsigned) *regex])	    return 0;	  text++;	  regex++;	}      /* single free character */      if (*regex == '?')	{	  if (!(*text))	    return 0;	  text++;	  regex++;	}      /* free characters */      else if (*regex == '*')	{	  regex++;	  /* skip useless '?'s after '*'s */	  while (*regex == '?')	    regex++;	  /* skip all characters until next character in pattern found */	  while (*text && 		 irc_lcset[(unsigned) *regex] != irc_lcset[(unsigned) *text]) 	    text++;	  /* next character in pattern found */	  if (*text)	    {	      /* find the last occurrence of this character in the text */	      p = text + strlen (text);	      while (irc_lcset[(unsigned) *p] != irc_lcset[(unsigned) *text]) 		p--;	      /* continue parsing at this character */	      text = p;	    }	}    }  /* is the text longer than the regex ? */  if (!*text && !*regex)    return -1;  return 0;}/* * Create the lowercase character set for string comparisons. */voidirc_create_lcset (void){  int n;    for (n = 0; n < 256; n++)    {      irc_lcset[n] = (char) tolower (n);    }  irc_lcset['['] = '{';  irc_lcset[']'] = '}';  irc_lcset['|'] = '\\';}/* * Make a case insensitive string compare. Return zero if both * strings are equal. */intirc_string_equal (char *str1, char *str2){  char *p1, *p2;  if (str1 == str2)    return 0;    p1 = str1;  p2 = str2;  while (*p1 && *p2)    {      if (irc_lcset[(unsigned) *p1] != irc_lcset[(unsigned) *p2]) 	return -1;      p1++;      p2++;    }  if (!*p1 && !*p2)    return 0;  return -1;}#else /* ENABLE_IRC_PROTO */int irc_core_dummy; /* Shut up compiler. */#endif /* ENABLE_IRC_PROTO */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产最新精品精品你懂的| 青青草原综合久久大伊人精品优势 | 亚洲欧美日韩在线播放| 欧美片在线播放| 成人av中文字幕| 久久99精品国产麻豆婷婷洗澡| 亚洲黄色av一区| 久久人人爽人人爽| 在线不卡的av| 在线视频观看一区| 成人精品鲁一区一区二区| 日本视频中文字幕一区二区三区| 亚洲视频 欧洲视频| 日韩欧美一区二区久久婷婷| 欧美在线免费观看视频| 不卡视频在线观看| 国产精品一区二区男女羞羞无遮挡| 亚洲r级在线视频| 一区二区三区日韩欧美精品| 国产精品久久久久久久久动漫| 久久综合成人精品亚洲另类欧美 | 91麻豆精品国产91久久久使用方法| 成人黄色a**站在线观看| 精品一区二区三区视频| 午夜精品久久久久久久久| 亚洲视频精选在线| 亚洲色图制服诱惑| 国产日韩成人精品| 久久久99久久| 精品国产乱码久久久久久闺蜜| 欧美性三三影院| 99v久久综合狠狠综合久久| 夫妻av一区二区| 精品一区中文字幕| 成人爽a毛片一区二区免费| 黄一区二区三区| 国内精品视频666| 精品一区二区三区免费播放| 美女www一区二区| 久久精品二区亚洲w码| 日本在线不卡一区| 久久成人av少妇免费| 麻豆高清免费国产一区| 久久99国产精品免费网站| 精品一区二区三区免费播放| 国内外成人在线视频| 国产河南妇女毛片精品久久久| 国产成人8x视频一区二区| 成人免费视频一区| 91在线看国产| 欧美天天综合网| 宅男噜噜噜66一区二区66| 日韩欧美资源站| 久久精品人人做人人综合| 国产精品日日摸夜夜摸av| 一区在线观看视频| 亚洲综合另类小说| 日韩高清电影一区| 国产综合一区二区| 9色porny自拍视频一区二区| 91麻豆123| 7799精品视频| 久久久久久夜精品精品免费| 中文字幕av免费专区久久| 日韩美女视频一区二区| 首页综合国产亚洲丝袜| 国产自产2019最新不卡| 99麻豆久久久国产精品免费优播| 91福利视频网站| 欧美成人官网二区| 国产精品黄色在线观看| 亚洲午夜久久久久久久久久久 | 91精品国产综合久久精品app| 欧美成人aa大片| 日韩高清在线观看| 成人性色生活片| 欧美视频在线观看一区二区| 久久色在线视频| 一区二区三区成人| 国产一区三区三区| 色婷婷av一区二区三区gif | 国产麻豆视频精品| 欧洲精品视频在线观看| 久久女同性恋中文字幕| 一区二区三区欧美日| 国产一区二区主播在线| 91精品福利视频| 久久久久久久久久久99999| 亚洲一级在线观看| 国产精品一区二区在线观看不卡| 在线视频欧美精品| 国产欧美一区二区三区在线看蜜臀| 一区二区三区四区精品在线视频| 狠狠久久亚洲欧美| 欧美日韩在线一区二区| 国产精品三级视频| 久久国产夜色精品鲁鲁99| 色婷婷久久综合| 久久嫩草精品久久久精品| 偷偷要91色婷婷| 色美美综合视频| 久久精品亚洲麻豆av一区二区| 亚洲一级片在线观看| 成人av第一页| 久久蜜桃一区二区| 日产国产欧美视频一区精品| 91麻豆国产香蕉久久精品| 国产欧美一区二区精品仙草咪| 日本vs亚洲vs韩国一区三区二区| 在线日韩国产精品| 亚洲日本va午夜在线电影| 国产精品一卡二| 日韩一区二区三区av| 午夜免费久久看| 色婷婷综合久久久久中文一区二区| 国产欧美精品一区二区三区四区 | 国产69精品久久久久777| 欧美电影免费观看高清完整版在| 亚洲第一电影网| 欧美性受xxxx黑人xyx| 亚洲日本va在线观看| 成人免费av网站| 中文在线资源观看网站视频免费不卡 | 中文字幕第一页久久| 国产麻豆视频精品| 久久综合色婷婷| 国模冰冰炮一区二区| 日韩欧美电影一区| 麻豆91在线看| 精品国产乱码久久久久久久久 | 精品久久久久一区| 理论片日本一区| 精品国产乱码久久久久久影片| 蜜桃视频免费观看一区| 日韩一区二区视频| 久久99久久99| 精品少妇一区二区三区视频免付费| 免费人成网站在线观看欧美高清| 这里只有精品电影| 看电影不卡的网站| 精品精品欲导航| 国产精品1区2区| 欧美国产激情二区三区| 国产白丝网站精品污在线入口| 国产精品视频九色porn| 99久久99久久精品免费观看| 亚洲人成影院在线观看| 色婷婷综合久色| 日日骚欧美日韩| 2024国产精品| 成人国产精品视频| 成人免费在线视频| 91国内精品野花午夜精品| 午夜av电影一区| 2019国产精品| 99久久伊人精品| 亚洲丰满少妇videoshd| 欧美成人三级电影在线| 风间由美一区二区av101| 亚洲人一二三区| 91精品国产入口在线| 国产一区二区三区久久久 | 亚洲精品一卡二卡| 在线播放视频一区| 国产精品一区二区不卡| 亚洲人123区| 91精品福利在线一区二区三区 | 国产毛片精品国产一区二区三区| 国产日韩av一区| 欧美在线小视频| 久久国产精品第一页| 国产精品三级久久久久三级| 欧美日韩免费一区二区三区| 日韩国产在线一| 中文字幕乱码日本亚洲一区二区 | 美日韩一区二区| 国产三区在线成人av| 91成人看片片| 国产呦萝稀缺另类资源| 亚洲另类中文字| 日韩一级高清毛片| 成人免费视频一区二区| 日日嗨av一区二区三区四区| 国产丝袜美腿一区二区三区| 欧美日韩精品系列| 国产成人午夜精品影院观看视频| 亚洲一区欧美一区| 日韩区在线观看| 亚洲人123区| wwww国产精品欧美| 欧美日韩一本到| 丁香婷婷综合激情五月色| 午夜精品在线视频一区| 日本一区免费视频| 欧美大片国产精品| 欧美性大战久久久久久久| 国产91富婆露脸刺激对白| 三级影片在线观看欧美日韩一区二区| 中文字幕欧美日本乱码一线二线| 337p亚洲精品色噜噜|