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

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

?? w32sock.cpp

?? FastDb是高效的內(nèi)存數(shù)據(jù)庫系統(tǒng)
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//-< W32SOCK.CXX >---------------------------------------------------*--------*
// FastDB                    Version 1.0         (c) 1997  GARRET    *     ?  *
// (Main Memory Database Management System)                          *   /\|  *
//                                                                   *  /  \  *
//                          Created:      8-May-97    K.A. Knizhnik  * / [] \ *
//                          Last update: 19-May-97    K.A. Knizhnik  * GARRET *
//-------------------------------------------------------------------*--------*
// Windows sockets
//-------------------------------------------------------------------*--------*

#define INSIDE_FASTDB

#include "stdtp.h"
#include "w32sock.h"
#include "sync.h"

#define MAX_HOST_NAME         256
#define MILLISECOND           1000

static HANDLE WatchDogMutex;

#if defined(__MINGW32__)
#define ASM_CPUID_NOT_SUPPORTED
#endif

#ifdef ASM_CPUID_NOT_SUPPORTED
static CRITICAL_SECTION cs;
#endif

class win_socket_library
{

public:
  SYSTEM_INFO sinfo;

  win_socket_library()
  {
    WSADATA wsa;

    if (WSAStartup(MAKEWORD(1, 1), &wsa) != 0)
    {
      fprintf(stderr,"Failed to initialize windows sockets: %d\n",
              WSAGetLastError());
    }

    //
    // This mutex is used to recognize process termination
    //
    WatchDogMutex = CreateMutex(FASTDB_SECURITY_ATTRIBUTES, TRUE, NULL);

#ifdef PHAR_LAP

    sinfo.wProcessorLevel = 5;

#else

    GetSystemInfo(&sinfo);

#endif
#ifdef ASM_CPUID_NOT_SUPPORTED

    InitializeCriticalSection(&cs);

#endif

  }

  ~win_socket_library()
  {
#ifdef ASM_CPUID_NOT_SUPPORTED
    DeleteCriticalSection(&cs);
#endif
    // WSACleanup();
  }
};

static win_socket_library ws32_lib;

#ifdef __BORLANDC__
static
#else
inline
#endif
void serialize()
{
#ifndef ASM_CPUID_NOT_SUPPORTED

  if (ws32_lib.sinfo.wProcessorLevel >= 5)
  { // Pemtium or higher
    __asm CPUID;
  }

#else
  EnterCriticalSection(&cs);

  LeaveCriticalSection(&cs);

#endif
}

bool win_socket::open(int listen_queue_size)
{
  unsigned short port;
  char* p;
  char hostname[MAX_HOST_NAME];

  assert(address != NULL);

  if ((p = strchr(address, ':')) == NULL
      || sscanf(p+1, "%hu", &port) != 1)
  {
    errcode = bad_address;
    return false;
  }

  memcpy(hostname, address, p - address);
  hostname[p - address] = '\0';

  if ((s = socket(AF_INET, SOCK_STREAM, 0)) == INVALID_SOCKET)
  {
    errcode = WSAGetLastError();
    return false;
  }

  struct sockaddr_in insock;

  insock.sin_family = AF_INET;

  if (*hostname && stricmp(hostname, "localhost") != 0)
  {

    struct hostent* hp;  // entry in hosts table

    if ((hp = gethostbyname(hostname)) == NULL
        || hp->h_addrtype != AF_INET)
    {
      errcode = bad_address;
      return false;
    }

    memcpy(&insock.sin_addr, hp->h_addr, sizeof insock.sin_addr);
  }
  else
  {
    insock.sin_addr.s_addr = htonl(INADDR_ANY);
  }

  insock.sin_port = htons(port);

  int on = 1;
  setsockopt(s, SOL_SOCKET, SO_REUSEADDR, (char*)&on, sizeof on);

  if (bind(s, (sockaddr*)&insock, sizeof(insock)) != 0)
  {
    errcode = WSAGetLastError();
    closesocket(s);
    return false;
  }

  if (listen(s, listen_queue_size) != 0)
  {
    errcode = WSAGetLastError();
    closesocket(s);
    return false;
  }

  errcode = ok;
  state = ss_open;
  return true;
}

bool win_socket::is_ok()
{
  return errcode == ok;
}

int win_socket::get_handle()
{
  return s;
}

void win_socket::get_error_text(char* buf, size_t buf_size)
{
  char* msg;
  char  msgbuf[64];

  switch(errcode)
  {

  case ok:
    msg = "ok";
    break;

  case not_opened:
    msg = "socket not opened";
    break;

  case bad_address:
    msg = "bad address";
    break;

  case connection_failed:
    msg = "exceed limit of attempts of connection to server";
    break;

  case broken_pipe:
    msg = "connection is broken";
    break;

  case invalid_access_mode:
    msg = "invalid access mode";
    break;

  default:
#ifndef PHAR_LAP

    {
      int   len;
      len = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM,
                          NULL,
                          errcode,
                          0,
                          buf,
                          buf_size,
                          NULL);

      if (len == 0)
      {
        sprintf(msgbuf, "unknown error code %u", errcode);
        msg = msgbuf;
      }
      else
      {
        return;
      }
    }
#else
    sprintf(msgbuf, "System error code: %u", errcode);
    msg = msgbuf;
#endif

  }

  strncpy(buf, msg, buf_size);
}

socket_t* win_socket::accept()
{
  if (state != ss_open)
  {
    errcode = not_opened;
    return NULL;
  }

  SOCKET new_sock = ::accept(s, NULL, NULL );

  if (new_sock == INVALID_SOCKET)
  {
    errcode = WSAGetLastError();
    return NULL;
  }
  else
  {

    static struct linger l =
      {
        1, LINGER_TIME
      };

    if (setsockopt(new_sock, SOL_SOCKET, SO_LINGER, (char*)&l, sizeof l) != 0)
    {
      errcode = WSAGetLastError();
      closesocket(new_sock);
      return NULL;
    }

#if SOCK_NO_DELAY
    int enabled = 1;

    if (setsockopt(new_sock, IPPROTO_TCP, TCP_NODELAY, (char*)&enabled,
                   sizeof enabled) != 0)
    {
      errcode = WSAGetLastError();
      closesocket(new_sock);
      return NULL;
    }

#endif
#if SOCK_SNDBUF_SIZE>0
    int size = SOCK_SNDBUF_SIZE;

    setsockopt(s, SOL_SOCKET, SO_SNDBUF, (char*)&size, sizeof size);

#endif

    errcode = ok;

    return new win_socket(new_sock);
  }
}

bool win_socket::cancel_accept()
{
  bool result = close();
  // Wakeup listener
  delete socket_t::connect(address, sock_global_domain, 1, 0);
  return result;
}


bool win_socket::connect(int max_attempts, time_t timeout)
{
  char hostname[MAX_HOST_NAME];
  char *p;
  unsigned short port;

  assert(address != NULL);

  if ((p = strchr(address, ':')) == NULL
      || (size_t)(p - address) >= sizeof(hostname)
      || sscanf(p+1, "%hu", &port) != 1)
  {
    errcode = bad_address;
    return false;
  }

  memcpy(hostname, address, p - address);
  hostname[p - address] = '\0';

  struct sockaddr_in insock;  // inet socket address

  struct hostent*    hp;      // entry in hosts table

  if ((hp = gethostbyname(hostname)) == NULL || hp->h_addrtype != AF_INET)
  {
    errcode = bad_address;
    return false;
  }

  insock.sin_family = AF_INET;
  insock.sin_port = htons(port);

  while (true)
  {
    for (int i = 0; hp->h_addr_list[i] != NULL; i++)
    {
      memcpy(&insock.sin_addr, hp->h_addr_list[i],
             sizeof insock.sin_addr);

      if ((s = socket(AF_INET, SOCK_STREAM, 0)) == INVALID_SOCKET)
      {
        errcode = WSAGetLastError();
        return false;
      }

      if (::connect(s, (sockaddr*)&insock, sizeof insock) != 0)
      {
        errcode = WSAGetLastError();
        closesocket(s);

        if (errcode != WSAECONNREFUSED)
        {
          return false;
        }
      }
      else
      {
        int enabled = 1;

        if (setsockopt(s, IPPROTO_TCP, TCP_NODELAY, (char*)&enabled,
                       sizeof enabled) != 0)
        {
          errcode = WSAGetLastError();
          closesocket(s);
          return false;
        }

        errcode = ok;
        state = ss_open;
        return true;
      }
    }

    if (--max_attempts > 0)
    {
      Sleep(timeout*MILLISECOND);
    }
    else
    {
      errcode = connection_failed;
      return false;
    }
  }
}

int win_socket::read(void* buf, size_t min_size, size_t max_size,
                     time_t timeout)
{
  size_t size = 0;
  time_t start = 0;

  if (state != ss_open)
  {
    errcode = not_opened;
    return -1;
  }

  if (timeout != WAIT_FOREVER)
  {
    start = time(NULL);
  }

  do
  {
    int rc;

    if (timeout != WAIT_FOREVER)
    {
      fd_set events;

      struct timeval tm;
      FD_ZERO(&events);
      FD_SET(s, &events);
      tm.tv_sec = timeout;
      tm.tv_usec = 0;
      rc = select(s+1, &events, NULL, NULL, &tm);

      if (rc < 0)
      {
        errcode = WSAGetLastError();
        return -1;
      }

      if (rc == 0)
      {
        return size;
      }

      time_t now = time(NULL);
      timeout = start + timeout >= now ? timeout + start - now : 0;
    }

    rc = recv(s, (char*)buf + size, max_size - size, 0);

    if (rc < 0)
    {
      errcode = WSAGetLastError();
      return -1;
    }
    else if (rc == 0)
    {
      errcode = broken_pipe;
      return -1;
    }
    else
    {
      size += rc;
    }
  }
  while (size < min_size);

  return (int)size;
}

bool win_socket::write(void const* buf, size_t size)
{
  if (state != ss_open)
  {
    errcode = not_opened;
    return false;
  }

  do
  {
    int rc = send(s, (char*)buf, size, 0);

    if (rc < 0)
    {
      errcode = WSAGetLastError();
      return false;
    }
    else if (rc == 0)
    {
      errcode = broken_pipe;
      return false;
    }
    else
    {
      buf = (char*)buf + rc;
      size -= rc;
    }
  }
  while (size != 0);

  return true;
}

bool win_socket::shutdown()
{
  if (state == ss_open)
  {
    state = ss_shutdown;
    int rc = ::shutdown(s, 2);

    if (rc != 0)
    {
      errcode = WSAGetLastError();
      return false;
    }
  }

  errcode = ok;
  return true;
}


bool win_socket::close()
{
  if (state != ss_close)
  {
    state = ss_close;

    if (closesocket(s) == 0)
    {
      errcode = ok;
      return true;
    }
    else
    {
      errcode = WSAGetLastError();
      return false;
    }
  }

  return true;
}

char* win_socket::get_peer_name()
{
  if (state != ss_open)
  {
    errcode = not_opened;
    return NULL;
  }

  struct sockaddr_in insock;

  int len = sizeof(insock);

  if (getpeername(s, (struct sockaddr*)&insock, &len) != 0)
  {
    errcode = WSAGetLastError();
    return NULL;
  }

  char* addr = inet_ntoa(insock.sin_addr);

  if (addr == NULL)
  {
    errcode = WSAGetLastError();
    return NULL;
  }

  char* addr_copy = new char[strlen(addr)+1];
  strcpy(addr_copy, addr);
  errcode = ok;
  return addr_copy;
}

win_socket::~win_socket()
{
  close();
  delete[] address;
}

win_socket::win_socket(const char* addr)
{
  address = new char[strlen(addr)+1];
  strcpy(address, addr);
  errcode = ok;
  s = INVALID_SOCKET;
}

win_socket::win_socket(SOCKET new_sock)
{
  s = new_sock;
  address = NULL;
  state = ss_open;
  errcode = ok;
}

socket_t* socket_t::create_local(char const* address, int listen_queue_size)
{
  local_win_socket* sock = new local_win_socket(address);
  sock->open(listen_queue_size);
  return sock;
}

socket_t* socket_t::create_global(char const* address, int listen_queue_size)
{
  win_socket* sock = new win_socket(address);
  sock->open(listen_queue_size);
  return sock;
}

socket_t* socket_t::connect(char const* address,
                            socket_domain domain,
                            int max_attempts,
                            time_t timeout)
{
  char   hostname[MAX_HOST_NAME];
  size_t hostname_len;
  char const* port;

  if (domain == sock_local_domain
      || (domain == sock_any_domain
          && ((port = strchr(address, ':')) == NULL
              || ((hostname_len = port - address) == 9
                  && strncmp(address, "localhost", hostname_len) == 0)
              || (gethostname(hostname, sizeof hostname) != 0
                  && strlen(hostname) == hostname_len
                  && strncmp(address, hostname, hostname_len) == 0))))
  {
    local_win_socket* s = new local_win_socket(address);
    s->connect(max_attempts, timeout);
    return s;
  }
  else
  {
    win_socket* s = new win_socket(address);
    s->connect(max_attempts, timeout);
    return s;
  }
}

//
// Local windows sockets
//

int local_win_socket::read(void* buf, size_t min_size, size_t max_size,
                           time_t timeout)
{
  time_t start = 0;
  char* dst = (char*)buf;
  size_t size = 0;
  Error = ok;

  if (timeout != WAIT_FOREVER)
  {
    start = time(NULL);
    timeout *= 1000; // convert seconds to miliseconds
  }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产综合久久久久久久久久久久| 久久中文娱乐网| av在线不卡网| 欧美精品v国产精品v日韩精品| 欧美性做爰猛烈叫床潮| 欧美日韩中文字幕精品| 欧美日韩国产一区二区三区地区| 欧美日韩黄视频| 91精品欧美久久久久久动漫| 欧美大片在线观看一区二区| 欧美激情中文字幕| 香蕉久久夜色精品国产使用方法 | 国产亚洲精品资源在线26u| 黄色精品一二区| 中文字幕av在线一区二区三区| 成人福利视频在线| 亚洲国产成人av好男人在线观看| 欧美日本乱大交xxxxx| 九九视频精品免费| 中文字幕一区不卡| 777午夜精品免费视频| 国产99久久久国产精品免费看| 久久精品国产澳门| 天天操天天综合网| 免费av成人在线| 日韩精品中文字幕在线不卡尤物 | 亚洲欧美国产三级| 亚洲色图一区二区三区| 日韩av中文在线观看| 精品免费视频.| 久久丝袜美腿综合| 欧美一级片在线| 国产精品国产成人国产三级| 麻豆精品久久久| 欧美三级中文字幕| 日韩欧美国产综合一区 | 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲欧洲日产国码二区| 六月丁香婷婷久久| 91麻豆精品国产91久久久久久| 中文字幕一区二区日韩精品绯色| 亚洲电影第三页| 黄页视频在线91| 国产精品一区二区果冻传媒| 欧美aⅴ一区二区三区视频| 国产精品久久久久四虎| 亚洲激情av在线| 美女mm1313爽爽久久久蜜臀| 97精品国产97久久久久久久久久久久| 2欧美一区二区三区在线观看视频| 日产国产欧美视频一区精品| 欧美三级一区二区| 视频在线观看91| 欧美一区二区精品久久911| 日韩高清不卡在线| 久久亚洲精品小早川怜子| 91毛片在线观看| 91精品国产丝袜白色高跟鞋| www.成人网.com| 国模套图日韩精品一区二区| 视频一区在线播放| 一区二区三区中文在线观看| 国产精品久久免费看| 久久无码av三级| 日韩欧美国产电影| 91精品久久久久久蜜臀| 欧美三片在线视频观看| 91视频www| 91麻豆国产香蕉久久精品| 国产成人激情av| 亚洲精品午夜久久久| 亚洲免费视频成人| 久久夜色精品国产欧美乱极品| 麻豆精品一区二区av白丝在线| 亚洲精品日韩一| 国产日韩av一区二区| 亚洲免费观看视频| 中文字幕第一区二区| 精品播放一区二区| 欧美一区二区三区婷婷月色| 国产剧情在线观看一区二区 | 777亚洲妇女| 一区二区三区日韩欧美| 欧洲一区在线电影| 在线免费观看成人短视频| 久久久亚洲精品一区二区三区| 69久久99精品久久久久婷婷| 欧美日韩亚洲高清一区二区| 欧美精品免费视频| 日韩午夜中文字幕| 欧美精品一区二区三区蜜桃| 久久亚洲春色中文字幕久久久| 久久精品视频一区二区| 国产精品欧美综合在线| 亚洲青青青在线视频| 亚洲一区二区3| 天堂va蜜桃一区二区三区| 青青草97国产精品免费观看无弹窗版| 美女视频黄 久久| 国产精品66部| 99久久er热在这里只有精品66| 色综合久久综合网97色综合| 欧美日韩亚洲综合| 精品国产91亚洲一区二区三区婷婷| 久久久久久9999| 亚洲免费观看高清完整| 舔着乳尖日韩一区| 国产综合久久久久久久久久久久| 国产成人av电影免费在线观看| 91片黄在线观看| 欧美一区二区三区播放老司机| 国产视频911| 亚洲午夜免费电影| 免费久久99精品国产| 成人免费观看男女羞羞视频| 欧美三日本三级三级在线播放| 精品国偷自产国产一区| 亚洲天堂成人在线观看| 奇米综合一区二区三区精品视频| 成人手机在线视频| 7777精品伊人久久久大香线蕉的| 久久久精品2019中文字幕之3| 一区二区三区免费观看| 韩国av一区二区| 欧美亚洲动漫另类| 国产精品免费视频观看| 奇米影视一区二区三区| 96av麻豆蜜桃一区二区| 欧美电影免费观看高清完整版在 | 丝袜美腿亚洲一区| 成人av免费网站| 欧美一区二区三区视频在线| 最新中文字幕一区二区三区| 三级在线观看一区二区| 波多野结衣在线aⅴ中文字幕不卡| 欧美一区二区啪啪| 亚洲国产精品影院| 99视频精品在线| 久久久九九九九| 狂野欧美性猛交blacked| 欧美色图免费看| 成人欧美一区二区三区白人| 久久99精品久久久久久动态图 | 久久影院视频免费| 亚洲国产毛片aaaaa无费看| 国产精品亚洲午夜一区二区三区| 欧美日韩不卡视频| 亚洲欧美日韩电影| 国产成人在线观看免费网站| 欧美一区二区三区在线观看| 一区二区三区在线看| 成人福利视频网站| 国产丝袜在线精品| 韩国v欧美v日本v亚洲v| 欧美大片拔萝卜| 青青国产91久久久久久| 欧美美女一区二区在线观看| 亚洲综合无码一区二区| 一本色道久久综合狠狠躁的推荐| 国产精品视频你懂的| 国产精品一区二区x88av| 欧美白人最猛性xxxxx69交| 麻豆精品一区二区av白丝在线| 91麻豆精品国产91久久久更新时间| 亚洲午夜精品在线| 欧美无乱码久久久免费午夜一区| 亚洲精品国产精品乱码不99| 91香蕉视频污| 亚洲视频图片小说| 91麻豆产精品久久久久久 | 欧美亚洲国产一卡| 亚洲一区二区偷拍精品| 色婷婷av一区二区三区之一色屋| 亚洲精品乱码久久久久久久久 | 国产一区二区三区综合| 精品国产乱码久久久久久图片| 青娱乐精品视频在线| 欧美videossexotv100| 国产一区二区三区四区五区美女| 久久综合久久久久88| 国产一二精品视频| 国产精品毛片高清在线完整版| 99re热这里只有精品免费视频| 亚洲美女免费视频| 精品视频一区二区不卡| 人人狠狠综合久久亚洲| 欧美精品一区二区在线播放| 国产最新精品免费| 国产网站一区二区| 91在线观看免费视频| 亚洲国产成人av网| 欧美xxxxx裸体时装秀| 成人午夜碰碰视频| 亚洲精品亚洲人成人网| 欧美精品一二三| 国产在线播放一区三区四| 1024成人网色www| 欧美日韩不卡视频| 国产成人精品免费在线| 一区二区视频免费在线观看|