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

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

?? nxml.c

?? libnxml-no-curl-簡化版2007-07-01,一個別很不錯的XML生成和解析程序。
?? C
?? 第 1 頁 / 共 4 頁
字號:
    str[0] = (ch >> 18) | 0xf0;    str[1] = ((ch >> 12) & 0x2f);    str[2] = ((ch >> 6) & 0x2f);    str[3] = (ch & 0x2f);    return 4;  }  /* 26bit:  xxxxx100 xx000000 xx000000 xx000000 xx000000  *         100 0000 0000 0000 0000 0000 0000  *      0x 4   0    0    0    0    0    0  */  else if (ch < 0x4000000)  {    /* 21bits:  111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx */    str[0] = (ch >> 24) | 0xf8;    str[1] = ((ch >> 18) & 0x2f);    str[2] = ((ch >> 12) & 0x2f);    str[3] = ((ch >> 6) & 0x2f);    str[4] = (ch & 0x2f);    return 5;  }  return 0;}
//************************************************************
// PARSER FUNTION
//************************************************************
static int__nxml_parse_unique_attribute (nxml_attr_t * attr, char *name){  /*   * Rule [40] - Well-formedness contraint: Unique Att Spec  */  while (attr)  {    if (!strcmp (attr->name, name))      return 1;    attr = attr->next;  }  return 0;}//---------------------------------static int__nxml_atoi (char *str){  int ret;  sscanf (str, "%x", &ret);  return ret;}//---------------------------------static char *__nxml_parse_string (nxml_t * doc, char *buffer, int size){  char *ret, *real;  int i, j;  int q;  if (!(ret = (char *) malloc (sizeof (char) * ((size * 4) + 1))))    return NULL;  for (q = i = j = 0; i < size; i++)  {    if (*(buffer + i) == 0xd)      continue;    if (*(buffer + i) == 0xa || *(buffer + i) == 0x9      || *(buffer + i) == 0x20)    {      if (!q)      {        q = 1;        ret[j++] = *(buffer + i);      }    }    else if (*(buffer + i) == '&')    {      if (!strncmp (buffer + i, "&lt;", 4))      {        ret[j++] = '<';        i += 3;        q = 0;      }      else if (!strncmp (buffer + i, "&gt;", 4))      {        ret[j++] = '>';        i += 3;        q = 0;      }      else if (!strncmp (buffer + i, "&amp;", 5))      {        ret[j++] = '&';        i += 4;        q = 0;      }      else if (!strncmp (buffer + i, "&apos;", 6))      {        ret[j++] = '\'';        i += 5;        q = 0;      }      else if (!strncmp (buffer + i, "&quot;", 6))      {        ret[j++] = '"';        i += 5;        q = 0;      }      else if (*(buffer + i + 1) == '#')      {        char buf[1024];        int k = i;        int last;        while (*(buffer + k) != ';')          k++;        last = k - (i + 2) > sizeof (buf) ? sizeof (buf) : k - (i + 2);        strncpy (buf, buffer + i + 2, last);        buf[last] = 0;        if (buf[0] != 'x')          last = atoi (buf);        else          last = __nxml_atoi (&buf[1]);        if ((last =          __nxml_int_charset (last, (unsigned char *) (ret + j),          doc->encoding)) > 0)          j += last;        i += k - i;        q = 0;      }      else      {        q = 0;        ret[j++] = *(buffer + i);      }    }    else    {      q = 0;      ret[j++] = *(buffer + i);    }  }  ret[j] = 0;  real = strdup (ret);  free (ret);  return real;}//---------------------------------static char *__nxml_parse_get_attr (nxml_t * doc, char **buffer, size_t * size){  char attr[1024];  int i;  int byte;  int64_t ch;  if (!*size)    return NULL;  if (!__NXML_NAMESTARTCHARS)    return NULL;  memcpy (&attr[0], *buffer, byte);  i = byte;  (*buffer) += byte;  (*size) -= byte;  while (__NXML_NAMECHARS && *size && i < sizeof (attr) - 1)  {    memcpy (&attr[i], *buffer, byte);    i += byte;    (*buffer) += byte;    (*size) -= byte;  }  if (**buffer != 0x20 && **buffer != 0x9 && **buffer != 0xa    && **buffer != 0xd && **buffer != '=')  {    (*buffer) -= i;    (*size) += i;    return NULL;  }  i += __nxml_escape_spaces (doc, buffer, size);  if (**buffer != '=')  {    (*buffer) -= i;    (*size) += i;    return NULL;  }  (*buffer)++;  (*size)--;  __nxml_escape_spaces (doc, buffer, size);  attr[i] = 0;  return strdup (attr);}//---------------------------------static nxml_error_t__nxml_parse_get_attribute (nxml_t * doc, char **buffer, size_t * size,                            nxml_attr_t ** attr){  /*   * Rule [41] - Attribute ::= Name Eq AttValue  * Rule [25] - Eq ::= S? '=' S?  * Rule [5]  - Name ::= NameStartChar (NameChar)*  * Rule [4]  - NameStartChar ::= ":" | [A-Z] | ["_"] | [a-z] | Unicode...  * Rule [4a] - NameChar ::= NameStarChar | "-" | "." | [0-9] | Unicode...  * Rule [10] - AttValue ::= '"' ([^<&"] | Reference)* '"' |  *                          "'" ([^<&'] | Reference)* "'"  */  char *tag, *value;  if (!*size)    return NXML_OK;  *attr = NULL;  __nxml_escape_spaces (doc, buffer, size);  if (!(tag = __nxml_parse_get_attr (doc, buffer, size)))    return NXML_OK;  if (!(value = __nxml_get_value (doc, buffer, size)))  {    free (tag);    if (doc->priv.func)      doc->priv.func ("%s: expected value of attribute (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }  __nxml_escape_spaces (doc, buffer, size);  if (!(*attr = (nxml_attr_t *) malloc (sizeof (nxml_attr_t))))  {    free (tag);    free (value);    return NXML_ERR_POSIX;  }  memset (*attr, 0, sizeof (nxml_attr_t));  (*attr)->name = tag;  (*attr)->value = value;  return NXML_OK;}//---------------------------------static nxml_error_t__nxml_parse_cdata (nxml_t * doc, char **buffer, size_t * size,                    nxml_data_t ** data){  /*  * Rule [18] - CDSect ::= CDStart CData CDEnd   * Rule [19] - CDStart ::= '<![CDATA['  * Rule [20] - CData ::= (Char * - (Char * ']]>' Char *))  * Rule [21] - CDEnd ::= ']]>'  */  int i = 0;  nxml_data_t *t;  char *value;  while (i < *size)  {    if (!strncmp (*buffer + i, "]]>", 3))      break;    if (*(*buffer + i) == 0xa && doc->priv.func)      doc->priv.line++;    i++;  }  if (strncmp (*buffer + i, "]]>", 3))  {    if (doc->priv.func)      doc->priv.func ("%s: expected ']]>' as close of a CDATA (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }  if (!(t = (nxml_data_t *) malloc (sizeof (nxml_data_t))))    return NXML_ERR_POSIX;  memset (t, 0, sizeof (nxml_data_t));  t->doc = doc;  if (!(value = (char *) malloc (sizeof (char) * (i + 1))))  {    free (t);    return NXML_ERR_POSIX;  }  strncpy (value, *buffer, i);  value[i] = 0;  t->value = value;  t->type = NXML_TYPE_TEXT;  (*buffer) += i + 3;  (*size) -= i + 3;  *data = t;  return NXML_OK;}//---------------------------------static nxml_error_t__nxml_parse_doctype (nxml_t * doc, char **buffer, size_t * size,                      int *doctype){  /*  * Rule [28] - doctypedecl ::= '<!DOCTYPE' S Name (S ExternalID)? S?   *                             ('[' intSubset '] S?)? '>'  */  nxml_doctype_t *t;  nxml_doctype_t *tmp;  char str[1024];  char *value;  int i;  int byte;  int64_t ch;  int q = 0;  __nxml_escape_spaces (doc, buffer, size);  if (!__NXML_NAMESTARTCHARS)  {    if (doc->priv.func)      doc->priv.func ("%s: abnormal char '%c' (line %d)\n",      doc->file ? doc->file : "", **buffer, doc->priv.line);    return NXML_ERR_PARSER;  }  memcpy (&str[0], *buffer, byte);  i = byte;  (*buffer) += byte;  (*size) -= byte;  while (__NXML_NAMECHARS && *size && i < sizeof (str) - 1)  {    memcpy (&str[i], *buffer, byte);    i += byte;    (*buffer) += byte;    (*size) -= byte;  }  str[i] = 0;  if (!(t = (nxml_doctype_t *) malloc (sizeof (nxml_doctype_t))))    return NXML_ERR_POSIX;  memset (t, 0, sizeof (nxml_doctype_t));  t->doc = doc;  if (!(t->name = strdup (str)))  {    free (t);    return NXML_ERR_POSIX;  }  __nxml_escape_spaces (doc, buffer, size);  i = 0;  while ((*(*buffer + i) != '>' || q) && i < *size)  {    if (*(*buffer + i) == '<')      q++;    else if (*(*buffer + i) == '>')      q--;    if (*(*buffer + i) == 0xa && doc->priv.func)      doc->priv.line++;    i++;  }  if (*(*buffer + i) != '>')  {    if (doc->priv.func)      doc->priv.func ("%s: expected '>' as close of a doctype (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    free (t->value);    free (t);    return NXML_ERR_PARSER;  }  if (!(value = (char *) malloc (sizeof (char) * (i + 1))))  {    free (t->value);    free (t);    return NXML_ERR_POSIX;  }  strncpy (value, *buffer, i);  value[i] = 0;  t->value = value;  (*buffer) += i + 1;  (*size) -= i + 1;  tmp = doc->doctype;  if (!tmp)    doc->doctype = t;  else  {    while (tmp->next)      tmp = tmp->next;    tmp->next = t;  }  *doctype = 1;  return NXML_OK;}//---------------------------------static nxml_error_t__nxml_parse_comment (nxml_t * doc, char **buffer, size_t * size,                      nxml_data_t ** data){  /*   * Rule [15] - Comment ::= '<!--' ((Char - '-') | ('-' (Char - '-')))* '-->'  */  int i = 0;  nxml_data_t *t;  char *value;  while (strncmp (*buffer + i, "-->", 3) && i < *size)  {    if (*(*buffer + i) == 0xa && doc->priv.func)      doc->priv.line++;    i++;  }  if (strncmp (*buffer + i, "-->", 3))  {    if (doc->priv.func)      doc->priv.func ("%s: expected '--' as close comment (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }  if (!(t = (nxml_data_t *) malloc (sizeof (nxml_data_t))))    return NXML_ERR_POSIX;  memset (t, 0, sizeof (nxml_data_t));  t->doc = doc;  if (!(value = (char *) malloc (sizeof (char) * (i + 1))))  {    free (t);    return NXML_ERR_POSIX;  }  strncpy (value, *buffer, i);  value[i] = 0;  t->value = value;  (*buffer) += i + 3;  (*size) -= i + 3;  t->type = NXML_TYPE_COMMENT;  *data = t;  return NXML_OK;}//---------------------------------static nxml_error_t__nxml_parse_pi (nxml_t * doc, char **buffer, size_t * size,                 nxml_data_t ** data){  /*   * Rule [16] - PI ::= '<?' PITarget (S (Char * - (Char * '?>' Char *)))?   *                    '?>'  * Rule [17] - PITarget ::= Name - (('X' | 'x') ('M' | 'm') ('L' | 'l'))  */  int i = 0;  nxml_data_t *t;  char *value;  if (!*size)    return NXML_OK;  *data = NULL;  (*buffer) += 1;  (*size) -= 1;  while (strncmp (*buffer + i, "?>", 2) && i < *size)  {    if (*(*buffer + i) == 0xa && doc->priv.func)      doc->priv.line++;    i++;  }  if (strncmp (*buffer + i, "?>", 2))  {    if (doc->priv.func)      doc->priv.func ("%s: expected '?' as close pi tag (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }  if (!strncasecmp (*buffer, "?xml", 4))  {    if (doc->priv.func)      doc->priv.func ("%s: pi xml is reserved! (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }  if (!(t = (nxml_data_t *) malloc (sizeof (nxml_data_t))))    return NXML_ERR_POSIX;  memset (t, 0, sizeof (nxml_data_t));  t->doc = doc;  if (!(value = (char *) malloc (sizeof (char) * (i + 1))))  {    free (t);    return NXML_ERR_POSIX;  }  strncpy (value, *buffer, i);  value[i] = 0;  t->value = value;  (*buffer) += i + 2;  (*size) -= i + 2;  t->type = NXML_TYPE_PI;  *data = t;  return NXML_OK;}//---------------------------------static nxml_error_t__nxml_parse_other (nxml_t * doc, char **buffer, size_t * size,                    nxml_data_t ** data, int *doctype){  /* Tags '<!'... */  *data = NULL;  *doctype = 0;  if (!*size)    return NXML_OK;  (*buffer) += 1;  (*size) -= 1;  __nxml_escape_spaces (doc, buffer, size);  if (!strncmp (*buffer, "[CDATA[", 7))  {    (*buffer) += 7;    (*size) -= 7;    return __nxml_parse_cdata (doc, buffer, size, data);  }  else if (!strncmp (*buffer, "--", 2))  {    (*buffer) += 2;    (*size) -= 2;    return __nxml_parse_comment (doc, buffer, size, data);  }  else if (!strncmp (*buffer, "DOCTYPE", 7))  {    (*buffer) += 7;    (*size) -= 7;    return __nxml_parse_doctype (doc, buffer, size, doctype);  }  else  {    if (doc->priv.func)      doc->priv.func ("%s: abnormal tag (line %d)\n",      doc->file ? doc->file : "", doc->priv.line);    return NXML_ERR_PARSER;  }}//---------------------------------static nxml_error_t__nxml_parse_text (nxml_t * doc, char **buffer, size_t * size,                   nxml_data_t ** data){  int i = 0;  nxml_data_t *t;  char *value;  char *value_new;  *data = NULL;  if (!*size)    return NXML_OK;  while (*(*buffer + i) != '<' && i < *size)  {    if (*(*buffer + i) == 0xa && doc->priv.func)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美腿丝袜在线亚洲一区| 国产丶欧美丶日本不卡视频| 精品美女在线播放| 成年人网站91| 麻豆成人av在线| 亚洲制服丝袜一区| 国产精品每日更新| 久久综合九色综合欧美亚洲| 欧美喷潮久久久xxxxx| av激情综合网| 国产91精品在线观看| 精品在线观看视频| 午夜成人免费视频| 亚洲视频每日更新| 中文文精品字幕一区二区| 日韩精品中午字幕| 欧美精品久久久久久久多人混战| hitomi一区二区三区精品| 国产精品456| 裸体歌舞表演一区二区| 午夜精品久久一牛影视| 亚洲自拍另类综合| 亚洲黄色性网站| 中文字幕欧美一| 国产精品热久久久久夜色精品三区 | 色视频欧美一区二区三区| 国产伦精品一区二区三区免费迷 | 亚洲第四色夜色| 亚洲欧美日韩在线播放| 国产精品天美传媒| 中文字幕欧美激情| 欧美激情一区二区三区在线| 久久综合色播五月| 久久久电影一区二区三区| 久久免费偷拍视频| 国产色91在线| 久久久久久久综合色一本| 欧美大片国产精品| 日韩欧美aaaaaa| 日韩午夜在线播放| 欧美mv日韩mv国产网站app| 日韩视频不卡中文| 久久在线免费观看| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品成人在线观看| 亚洲视频在线一区观看| 亚洲精品成人在线| 亚瑟在线精品视频| 天堂va蜜桃一区二区三区漫画版| 午夜精品福利久久久| 日本va欧美va瓶| 在线国产亚洲欧美| 91麻豆精品久久久久蜜臀| 91精品国产手机| 精品国产99国产精品| 国产日产欧美一区| 亚洲色图欧美偷拍| 亚洲午夜精品在线| 久久精品国产99久久6| 国产美女精品一区二区三区| 国产1区2区3区精品美女| 成人免费va视频| 欧美视频在线不卡| 精品国产在天天线2019| 中文字幕精品一区二区三区精品| 亚洲欧美成aⅴ人在线观看 | 日本不卡一二三区黄网| 久久丁香综合五月国产三级网站| 国产揄拍国内精品对白| av一区二区不卡| 欧美精品日韩一本| 国产亚洲精品超碰| 一区二区三区在线观看网站| 日韩1区2区日韩1区2区| 成人午夜精品一区二区三区| 在线观看成人小视频| 欧美成人一区二区三区| 国产精品福利影院| 日本午夜精品一区二区三区电影 | 国产成人av一区二区三区在线 | www欧美成人18+| 亚洲欧美另类综合偷拍| 美女视频免费一区| 91日韩一区二区三区| 欧美一区二区三区系列电影| 国产精品嫩草影院com| 婷婷中文字幕一区三区| 成人av在线资源网站| 欧美一区二区性放荡片| 日韩理论片网站| 久久99精品一区二区三区| 欧洲一区二区三区在线| 欧美激情中文不卡| 蜜桃视频第一区免费观看| 色88888久久久久久影院野外| 精品噜噜噜噜久久久久久久久试看 | 成人国产精品免费观看动漫| 91精品综合久久久久久| 国产精品成人免费| 激情欧美一区二区三区在线观看| 在线视频你懂得一区| 国产校园另类小说区| 日韩av中文在线观看| 欧美中文字幕一区| 亚洲人成人一区二区在线观看| 久久精品99国产精品日本| 欧美日韩高清在线| 亚洲精品国产成人久久av盗摄| 国产成人免费视频网站| 日韩欧美综合在线| 丝袜a∨在线一区二区三区不卡| 波多野结衣中文字幕一区| 亚洲精品一区二区在线观看| 日本不卡视频一二三区| 欧美精品久久久久久久多人混战| 亚洲精品国产成人久久av盗摄| 成人黄页毛片网站| 国产欧美精品一区二区色综合| 精彩视频一区二区| 欧美不卡在线视频| 久久99久久99| 欧美成人综合网站| 美女网站色91| 欧美成人精品1314www| 免费一级欧美片在线观看| 欧美精品丝袜久久久中文字幕| 亚洲精品国产成人久久av盗摄| 91在线丨porny丨国产| 国产精品久久二区二区| 岛国一区二区三区| 中文一区二区在线观看| 成人爽a毛片一区二区免费| 久久精品一区蜜桃臀影院| 国产大陆亚洲精品国产| 亚洲国产成人午夜在线一区| 成人免费视频播放| 亚洲欧洲日韩av| 99久久99久久精品免费看蜜桃| 中文字幕人成不卡一区| 91一区一区三区| 伊人开心综合网| 欧美视频中文一区二区三区在线观看| 亚洲精品免费播放| 欧美精品乱码久久久久久| 在线观看国产日韩| 亚洲一二三四区不卡| 欧美日韩免费一区二区三区 | 亚洲精品在线免费播放| 国产久卡久卡久卡久卡视频精品| 久久久久久久网| 成人精品免费视频| 亚洲女同女同女同女同女同69| 日本精品一区二区三区高清 | 黄一区二区三区| 欧美激情中文字幕| 日本乱人伦aⅴ精品| 偷窥国产亚洲免费视频| 精品国产不卡一区二区三区| 国产精品一区久久久久| 最新国产精品久久精品| 色视频欧美一区二区三区| 日本成人在线网站| 久久精品免视看| 91久久香蕉国产日韩欧美9色| 五月天激情综合| 久久久欧美精品sm网站| 色呦呦一区二区三区| 天堂影院一区二区| 国产欧美一区二区三区鸳鸯浴 | 精品一区中文字幕| 国产精品免费观看视频| 欧美视频在线观看一区| 狠狠色综合日日| 亚洲精品久久久蜜桃| 日韩精品一区国产麻豆| 99在线精品视频| 日本aⅴ精品一区二区三区| 欧美国产1区2区| 亚洲精品国产精华液| 日韩三级电影网址| 91在线免费播放| 免费高清在线一区| 亚洲男同性视频| 精品免费一区二区三区| 91一区在线观看| 国产一区久久久| 亚洲国产另类av| 国产精品伦一区二区三级视频| 欧美日韩精品一区二区天天拍小说| 国产一级精品在线| 亚洲成人av电影在线| 国产精品午夜春色av| 日韩欧美国产三级| 欧美中文字幕一区二区三区 | 五月天激情小说综合| 国产精品国产三级国产专播品爱网| 欧洲精品在线观看| 丁香婷婷综合五月| 精油按摩中文字幕久久| 亚洲成人777|