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

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

?? parse_headers.cpp

?? 一個開源的網絡開發庫ACE
?? CPP
字號:
// Parse_Headers.cpp,v 1.1 2000/04/27 23:43:22 jxh Exp

#include "JAWS/Parse_Headers.h"

#define ACCESSOR(T,C,x) \
T C##::##x (void) const { return this->##x##_; }\
void C##::##x (T t) { this->##x##_ = t; }

int
JAWS_Parse_Headers::parse_headers (JAWS_Header_Info *info,
                                   ACE_Message_Block &mb)
{
  for (;;)
    {
      if (mb.rd_ptr () == mb.wr_ptr ())
          break;

      char *p = mb.rd_ptr ();

      if (info->end_of_line ()
          && (*p != ' ' && *p != '\t'))
        {
          int r = this->parse_header_name (info, mb);
          if (r == 1)
            return info->end_of_headers ();
          continue;
        }
      else
        {
          int r = this->parse_header_value (info, mb);
          if (r == 1)
            {
              if (info->end_of_headers ())
                return 1;
              break;
            }
          continue;
        }
    }

  // If we arrive here, it means either there is nothing more to read,
  // or parse_header_value ran into difficulties (like maybe the
  // header value was too long).

  if (mb.rd_ptr () != mb.base ())
    {
      mb.crunch ();
      return 0;
    }
  else if (mb.length () < mb.size ())
    {
      return 0;
    }
  else if (mb.length () == mb.size ())
    {
      // This is one of those cases that should rarely ever happen.
      // If we get here, the header type name is over 8K long.  We
      // flag this as a bad thing.

      // In HTTP/1.1, I have to remember that a bad request means the
      // connection needs to be closed and the client has to
      // reinitiate the connection.

      info->status (JAWS_Header_Info::TOO_LONG);
      return 1;
    }
  else if (mb.length () > mb.size ())
    {
      ACE_DEBUG ((LM_DEBUG, "JAWS_Parse_Headers: buffer overrun!!\n"));
      info->status (JAWS_Header_Info::TOO_LONG);
      return 1;
    }

  ACE_DEBUG ((LM_DEBUG, "JAWS_Parse_Headers -- shouldn't be here!\n"));
  return 1;
}

char *
JAWS_Parse_Headers::skipset (const char *set, char *start, char *end)
{
  char *p = start;
  while (p < end)
    {
      if (ACE_OS::strchr (set, *p) != NULL)
        break;
      p++;
    }
  return p;
}

char *
JAWS_Parse_Headers::skipcset (const char *set, char *start, char *end)
{
  char *p = start;
  while (p < end)
    {
      if (ACE_OS::strchr (set, *p) == NULL)
        break;
      p++;
    }
  return p;
}

int
JAWS_Parse_Headers::parse_header_name (JAWS_Header_Info *info,
                                       ACE_Message_Block &mb)
{
  char *p = mb.rd_ptr ();
  char *q;

  q = this->skipset (":\n", p, mb.wr_ptr ());
  if (q == mb.wr_ptr ())
    {
      // no more progress can be made until we find a ':'
      return 1;
    }
  if (*q != '\n' && q == p)
    {
      // Ignore empty header type names
      info->finish_last_header_value ();
      info->create_next_header_value (0);
      info->end_of_line (0);
      mb.rd_ptr (q+1);
      return 0;
    }
  if (*q == '\n')
    {
      // ignore this line
      mb.rd_ptr (q+1);
      if (q == p || ((q-1) == p && q[-1] == '\r'))
        {
          // blank line means end of headers
          info->finish_last_header_value ();
          info->create_next_header_value (0);
          info->end_of_headers (1);
          if (mb.rd_ptr () == mb.wr_ptr ())
            mb.crunch ();
          return 1;
        }

      // not a blank line, but no ':', so ignore it
      info->finish_last_header_value ();
      info->create_next_header_value (0);
      return 0;
    }

  // otherwise, we have a header type name!
  *q = '\0';
  info->create_next_header_value (p);
  info->end_of_line (0);

  mb.rd_ptr (q+1);
  return 0;
}

int
JAWS_Parse_Headers::parse_header_value (JAWS_Header_Info *info,
                                        ACE_Message_Block &mb)
{
  // break --> return 1;
  // continue --> return 0;

  char *q = mb.rd_ptr ();

  if (info->last_header_data () == 0)
    {
      // Ignoring this header (it is too long or something).

      q = this->skipset ("\n", mb.rd_ptr (), mb.wr_ptr ());
      if (q == mb.wr_ptr ())
        {
          info->end_of_line (0);
          mb.rd_ptr (q);

          // Move the rd_ptr back one character if the last thing we
          // see is a carriage return.  Assert: wr_ptr > rd_ptr.
          if (q[-1] == '\r')
            mb.rd_ptr (q-1);

          return 1;
        }

      if (*q == '\0')
        {
          // We are in the middle of binary data.  Get out!
          mb.rd_ptr (q);
          info->end_of_line (1);
          info->end_of_headers (1);
          return 1;
        }

      // Move past the newline, set the end of line flag
      if (*q == '\n')
        {
          info->end_of_line (1);
          q++;
        }
      mb.rd_ptr (q);

      return 0;
    }
  else
    {
      if (info->end_of_line ())
        {
          // Skip over leading linear white space
          q = this->skipcset (" \t", mb.rd_ptr (), mb.wr_ptr ());
          if (q == mb.wr_ptr ())
            {
              // need more input
              info->end_of_line (1);
              mb.rd_ptr (q-1);
              return 1;
            }

          if (*q != '\n')
            info->append_last_header_value (' ');
        }

      // Append to last header value character by character
      while (q < mb.wr_ptr ())
        {
          if (*q == '\n')
            break;
          info->append_last_header_value (*q);
          q++;
        }

      // Need more input
      if (q == mb.wr_ptr ())
        {
          mb.rd_ptr (q);
          info->end_of_line (0);
          return 1;
        }

      // Reached a newline
      if (*q == '\n')
        {
          // Reduce by one character if line discipline is "\r\n"
          if (info->append_last_header_value () == '\r')
            info->reduce_last_header_value ();

          // Move past newline, set end of line flag
          mb.rd_ptr (q+1);
          info->end_of_line (1);

          return 0;
        }
    }

  // NOT REACHED
  return 1;
}


JAWS_Header_Info::JAWS_Header_Info (void)
  : end_of_headers_ (0),
    end_of_line_ (1),
    last_header_data_ (0),
    last_header_length_ (0),
    status_ (0)
{
}

JAWS_Header_Info::~JAWS_Header_Info (void)
{
  JAWS_Header_Table_Iterator iter (this->table_);
  JAWS_Header_Data *data_ptr;

  for (iter.first (); !iter.done (); iter.advance ())
    {
      data_ptr = iter.next ();
      if (data_ptr)
        delete data_ptr;
    }
}

void
JAWS_Header_Info::dump (void)
{
  JAWS_Header_Table_Iterator iter (this->table_);

  ACE_DEBUG ((LM_DEBUG, "== BEGIN HEADER INFO DUMP ==\n"));
  for (iter.first (); ! iter.done (); iter.advance ())
    {
      JAWS_Header_Data *data;
      data = iter.next ();
      if (data != 0)
        ACE_DEBUG ((LM_DEBUG,
                    "%s -- %s\n",
                    data->header_name (), data->header_value ()));
      else
        ACE_DEBUG ((LM_DEBUG, "NULL ENTRY\n"));
    }
  ACE_DEBUG ((LM_DEBUG, "== END HEADER INFO DUMP ==\n"));
}

JAWS_Headers *
JAWS_Header_Info::table (void)
{
  return &(this->table_);
}

void
JAWS_Header_Info::append_last_header_value (char c)
{
  if (this->last_header_data_ == 0)
    return;

  if (this->last_header_length_ == 0 && (c == ' ' || c == '\t'))
    return;

  if (this->last_header_length_ < MAX_HEADER_LENGTH-1)
    {
      this->header_buf_[this->last_header_length_] = c;
      this->last_header_length_++;
      this->header_buf_[this->last_header_length_] = '\0';
    }

}

int
JAWS_Header_Info::append_last_header_value (void)
{
  if (this->last_header_data_ == 0 || this->last_header_length_ == 0)
    return -1;

  return this->header_buf_[this->last_header_length_-1];
}

void
JAWS_Header_Info::append_last_header_value (const char *begin, const char *end)
{
  if (this->last_header_data_ == 0)
    return;

  while (this->last_header_length_ < MAX_HEADER_LENGTH-1)
    {
      if (begin == end)
        break;

      this->header_buf_[this->last_header_length_] = *begin;
      this->last_header_length_++;
      begin++;
    }

  this->header_buf_[this->last_header_length_] = '\0';
}

void
JAWS_Header_Info::reduce_last_header_value (void)
{
  if (this->last_header_data_ == 0) return;

  if (this->last_header_length_ > 0)
    {
      this->last_header_length_--;
      this->header_buf_[this->last_header_length_] = '\0';
    }
}

void
JAWS_Header_Info::create_next_header_value (char *ht)
{
  if (ht == 0)
    {
      // discard last header data

      delete this->last_header_data_;
      this->last_header_data_ = 0;
      this->last_header_length (0);
      return;
    }

  this->finish_last_header_value ();

  if (this->status () == JAWS_Header_Info::OK)
    {
      // create a new last_header_data_ node

      this->last_header_data_ = new JAWS_Header_Data (ht, 0);
      // The above performs a strdup.

      if (this->last_header_data_ == 0 || this->last_header_name () == 0)
        {
          this->status (JAWS_Header_Info::NO_MEMORY);
          delete this->last_header_data_;
          this->last_header_data_ = 0;
        }
      this->last_header_length (0);
      this->header_buf_[0] = '\0';
    }
}

void
JAWS_Header_Info::finish_last_header_value (void)
{
  if (this->last_header_data_ != 0)
    {
      // prepare to insert last header data into the table.

      this->last_header_data_->header_value (this->header_buf ());
      // The above performs a strdup.

      if (this->status () == JAWS_Header_Info::OK)
        this->table_.insert (this->last_header_data_);
      else
        delete this->last_header_data_;
      this->last_header_data_ = 0;
    }
}

char *
JAWS_Header_Info::header_buf (void)
{
  return this->header_buf_;
}

const char *
JAWS_Header_Info::last_header_name (void) const
{
  return this->last_header_data_ ? this->last_header_data_->header_name () : 0;
}

const JAWS_Header_Data *
JAWS_Header_Info::last_header_data (void) const
{
  return this->last_header_data_;
}

ACCESSOR(int,JAWS_Header_Info,last_header_length)
ACCESSOR(int,JAWS_Header_Info,end_of_line)
ACCESSOR(int,JAWS_Header_Info,end_of_headers)
ACCESSOR(int,JAWS_Header_Info,status)

#if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION)
  template class ACE_Singleton<JAWS_Parse_Headers, ACE_SYNCH_MUTEX>;
#elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA)
# pragma instantiate  ACE_Singleton<JAWS_Parse_Headers, ACE_SYNCH_MUTEX>
#endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
婷婷成人激情在线网| 国产日韩欧美麻豆| 成人app网站| 国产伦精品一区二区三区免费迷| 亚洲国产日韩在线一区模特| 亚洲欧美日韩国产综合在线 | 视频一区国产视频| 亚洲福利视频三区| 亚洲已满18点击进入久久| 亚洲精品国产品国语在线app| 亚洲人123区| 亚洲国产精品嫩草影院| 亚洲123区在线观看| 亚洲国产毛片aaaaa无费看 | 欧美亚洲一区二区三区四区| 色综合久久九月婷婷色综合| 在线精品视频免费观看| 欧美美女一区二区在线观看| 欧美午夜电影在线播放| 69堂成人精品免费视频| 日韩欧美亚洲一区二区| 国产欧美日韩综合精品一区二区| 国产精品午夜免费| 一区二区三区四区国产精品| 偷拍一区二区三区四区| 久久99国产精品久久| 成人精品在线视频观看| 欧美在线观看禁18| 日韩精品一区二区三区四区 | 韩国av一区二区三区四区| 国产精品99久久久久久宅男| 91麻豆swag| 欧美电影免费观看完整版| 欧美激情中文字幕一区二区| 亚洲黄色在线视频| 激情久久久久久久久久久久久久久久| 成人动漫视频在线| 91麻豆精品国产91久久久更新时间| 日韩欧美一区二区免费| 日韩理论片网站| 日本成人在线网站| 99久久精品免费看国产免费软件| 欧美日韩视频在线一区二区| 久久九九久久九九| 亚洲成人一区二区| 成人精品视频一区二区三区| 678五月天丁香亚洲综合网| 久久久久国产精品麻豆ai换脸| 亚洲精品第1页| 国产福利一区二区三区| 欧美丰满美乳xxx高潮www| 国产女人18毛片水真多成人如厕| 午夜精品久久一牛影视| 成人免费观看视频| 久久久久99精品一区| 天堂在线一区二区| 色网站国产精品| 国产三级一区二区| 毛片一区二区三区| 欧美人狂配大交3d怪物一区| 国产精品动漫网站| 粉嫩aⅴ一区二区三区四区五区| 在线电影一区二区三区| 一区二区三区精品视频| 成人av动漫网站| 欧美国产激情一区二区三区蜜月| 奇米精品一区二区三区在线观看一| 一本大道久久a久久精品综合| 国产亚洲精品精华液| 日韩高清一级片| 欧美性一级生活| 一区二区三区在线播放| 在线精品视频一区二区三四| 亚洲精品中文在线观看| 色天天综合色天天久久| 亚洲少妇30p| 成人av电影在线| 中文字幕一区二区在线播放| 成人免费看视频| 国产精品免费av| 波多野结衣的一区二区三区| 国产免费久久精品| 成人福利视频网站| 亚洲免费观看高清| 色天使色偷偷av一区二区| 亚洲天堂福利av| 色拍拍在线精品视频8848| 亚洲一卡二卡三卡四卡无卡久久| 欧美性三三影院| 视频一区视频二区中文| 日韩免费高清视频| 成人性色生活片免费看爆迷你毛片| 久久久久久99精品| 99久久精品国产毛片| 一区二区三区色| 欧美日韩aaaaa| 久久国产精品区| 中文字幕国产一区二区| 日本福利一区二区| 香蕉久久夜色精品国产使用方法| 欧美电影一区二区| 国产精品一区二区在线观看不卡| 国产精品免费丝袜| 精品视频免费看| 久久国产精品区| 亚洲欧美一区二区三区久本道91| 欧美日韩国产一区| 国产专区综合网| 亚洲激情在线播放| 日韩欧美电影一区| 99国产精品国产精品久久| 亚洲一二三区在线观看| 久久综合久久综合久久| 91蜜桃免费观看视频| 免费美女久久99| 自拍偷拍欧美激情| 精品日韩在线观看| 欧美在线视频全部完| 狠狠色丁香九九婷婷综合五月| 国产精品久久久久久亚洲毛片 | 欧美美女视频在线观看| 成人一区二区三区视频在线观看| 亚洲成人av一区二区| 欧美国产视频在线| 91精品国产综合久久婷婷香蕉| 成人av集中营| 国产精品99久久久久久有的能看| 亚洲午夜精品在线| 国产精品欧美久久久久一区二区 | 首页国产丝袜综合| 国产精品久久三区| 精品少妇一区二区三区在线视频| 一本久久综合亚洲鲁鲁五月天 | 亚洲图片欧美色图| 国产精品久久久久久久久免费樱桃| 日韩免费高清电影| 欧美精品乱码久久久久久按摩 | 日韩av不卡一区二区| 一区二区三区**美女毛片| 国产女人aaa级久久久级| 精品欧美乱码久久久久久 | 久久免费午夜影院| 日韩你懂的电影在线观看| 欧美日韩美少妇| 欧美日韩在线播放| 色婷婷综合久久久中文一区二区 | 美女视频黄频大全不卡视频在线播放 | 在线观看91精品国产麻豆| 91小视频免费观看| 97国产一区二区| 99视频热这里只有精品免费| 国产91精品精华液一区二区三区 | 91啪在线观看| 99久久婷婷国产综合精品电影| 国产成人av电影免费在线观看| 国内欧美视频一区二区| 激情图片小说一区| 国产精品99久| 国产91精品一区二区麻豆网站 | 3751色影院一区二区三区| 欧美性大战xxxxx久久久| 欧美亚洲综合在线| 欧美日韩dvd在线观看| 884aa四虎影成人精品一区| 在线播放欧美女士性生活| 老司机一区二区| 99国产精品视频免费观看| 国产一区二区三区在线观看精品| 日韩国产在线一| 免费黄网站欧美| 久久99精品国产麻豆不卡| 国产一区二区三区四区五区入口 | caoporn国产一区二区| 99精品一区二区三区| 色系网站成人免费| 欧美日韩成人激情| 久久综合给合久久狠狠狠97色69| 久久久精品免费免费| 亚洲精品亚洲人成人网 | 美日韩一区二区三区| 美女视频一区二区三区| 99久久精品一区二区| 欧美熟乱第一页| 日韩免费观看高清完整版在线观看| 久久中文字幕电影| 中文字幕一区二区三区在线观看 | 4438x成人网最大色成网站| 久久午夜羞羞影院免费观看| 国产精品欧美经典| 亚洲v中文字幕| 国产精品白丝av| 欧美日韩卡一卡二| 欧美激情自拍偷拍| 午夜伊人狠狠久久| 国产二区国产一区在线观看| 欧美性大战久久久久久久 | 欧美系列在线观看| 精品国产一区二区三区av性色| 国产精品盗摄一区二区三区| 日韩成人精品在线观看|