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

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

?? xml.cpp

?? 提供windows和unix下各種級別日志,包括 xml
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "stdafx.h"
#include "xml.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

#define XML_TOKEN_START    1  // <
#define XML_TOKEN_END      2  // >
#define XML_TOKEN_START2   3  // </
#define XML_TOKEN_END2     4  // />
#define XML_TOKEN_PI_START 5  // <?
#define XML_TOKEN_PI_END   6  // ?>
#define XML_TOKEN_TEXT     7
#define XML_TOKEN_NAME     8
#define XML_TOKEN_STRING   9  // "xxx" or 'xxx'
#define XML_TOKEN_EQUAL    10 // =
#define XML_TOKEN_EOF      11
#define XML_TOKEN_CDATA    12
#define XML_TOKEN_INVALID  13

char *tokenTypeStrings[] = 
{
   "", //base 0
   "<",
   ">",
   "</",
   "/>",
   "<?",
   "?>",
   "text",
   "tag/attrname",
   "string",
   "=",
   "EOF",
   "CDATA",
   "invalid",
};


void ASSERT_TOKEN(int x); 

static int bReadTag = 0;
static int tokenType = XML_TOKEN_EOF;
static char tokenValue[MAX_TOKEN_LEN+1];
static char textValue[MAX_TEXT_LEN+1];
static char *pCurrent = NULL;
static char *pBuffer = NULL;
static int lineNumber = 0;
static int colNumber = 0;

void strncpyx(char *dest, const char *src, int len)
{
    if(src==NULL)
    {
        dest[0]=0;
        return;
    } 
    strncpy(dest, src, len-1);
    dest[len-1] = 0;
}

TXMLAttr::TXMLAttr()
{
   m_strName[0]=0;
   m_strValue=NULL;
   brother = NULL;
   lineNo = 0;
}

TXMLAttr::~TXMLAttr()
{
    if(m_strValue)
        delete m_strValue;
}

void TXMLAttr::setName(const char* src)
{
   if(strlen(src) >ATTRNAME_LENGTH)
   {
      strncpy(m_strName,src,ATTRNAME_LENGTH);
      m_strName[ATTRNAME_LENGTH]=0;
   }
   else
   {
       strcpy(m_strName,src);
   }
}

char* TXMLAttr::getName()
{
   return m_strName;
}

void TXMLAttr::setValue(const char* src)
{
   if(m_strValue)
       delete m_strValue;
   m_strValue=new char[strlen(src)+1];
   strcpy(m_strValue,src);
}

char* TXMLAttr::getValue()
{
   return m_strValue;
}

TXMLAttr* TXMLAttr::dup()
{
   TXMLAttr* attr=new TXMLAttr;
   attr->setName(m_strName);
   attr->setValue(m_strValue);
         
   if(brother!=NULL)
      attr->brother=brother->dup();
   attr->lineNo=lineNo;
   return attr;
}
char* TXMLAttr::toStr()
{
   char* s=new char[strlen(m_strName) + strlen(m_strValue) + 4];
   sprintf(s,"%s=\"%s\"",m_strName,m_strValue);
   return s;
}

TXMLElem::TXMLElem()
{
   child=NULL;
   brother=NULL;
   parent=NULL;
   attr = NULL;
   lineNo = 0;

   m_strTag[0]=0;
   m_strContent=NULL;
}

TXMLElem::~TXMLElem()
{
   TXMLElem* p=child;
   while(p!=NULL)
   {
      TXMLElem *pNext = p->brother;
      delete p;
      p = pNext;
   }

   {
      TXMLAttr* p=attr;
      while(p!=NULL)
      {
         TXMLAttr *pNext = p->brother;
         delete p;
         p = pNext;
      }
   }

   if(m_strContent)
   {
       delete m_strContent;
       m_strContent=NULL;
   }

}

TXMLElem* TXMLElem::dup(TXMLElem* aParent)
{
   TXMLElem* elem=new TXMLElem;
   elem->setTag(m_strTag);
   elem->setContent(m_strContent);
  
   TXMLElem* pChild=child;
   while(pChild!=NULL)
   {
      TXMLElem* pDupChild=pChild->dup(elem);
      elem->addChild(pDupChild);
      pChild=pChild->brother;
   }
   elem->parent=aParent;

   if(attr!=NULL)
      elem->attr=attr->dup();
   elem->lineNo=lineNo;
   return elem;
}

void TXMLElem::setTag(const char* src)
{
   if(strlen(src) >TAG_LENGTH)
   {
      strncpy(m_strTag,src,TAG_LENGTH);
      m_strTag[TAG_LENGTH]=0;
   }
   else
   {
       strcpy(m_strTag,src);
   }
}

void TXMLElem::setContent(const char* src)
{
   if(m_strContent)
       delete m_strContent;

   m_strContent = new char[strlen(src)+1];
   strcpy(m_strContent,src);
}

char* TXMLElem::getTag()
{
   return m_strTag;
}
char* TXMLElem::getContent()
{
   return m_strContent;
}

static char *pLast = NULL;
void GetLocation(char *pCurr)
{
   char *p = pLast;
   while(p != pCurr)
   {
      if(*p == '\n')
      {
         lineNumber ++;
         colNumber = 1;
      }
      colNumber ++;
      p++;
   }
   pLast = pCurr;
}

#define TOKEN_HEAD 10

void GetToken()
{
   tokenValue[0] = 0;
   textValue[0] = 0;
   char *p = pCurrent;
   if(bReadTag)
   {
      //skip blank
      while(*p==' ' || *p=='\t' || *p=='\n' || *p=='\r')
      {
         p++;
      }
      //only handle NAME, STRING, EQUAL, END, END2
      GetLocation(p);
      if(*p==0)
      {
         tokenType = XML_TOKEN_EOF;
      }
      else if(strncmp(p, "/>", 2) == 0)
      {
         tokenType = XML_TOKEN_END2;
         strcpy(tokenValue, "/>");
         p+=2;
         bReadTag = 0;
      }
      else if(*p=='>')
      {
         tokenType = XML_TOKEN_END;
         strcpy(tokenValue, ">");
         p++;
         bReadTag = 0;
      }
      else if(*p=='=')
      {
         tokenType = XML_TOKEN_EQUAL;
         strcpy(tokenValue, "=");
         p++;
      }
      else if(*p=='"' || *p=='\'')
      {
         char beginChar=*p;
         p++;
         char *pBegin = p;
//         while(*p !=0  && *p !='\n' && *p != beginChar)
         while(*p !=0  && *p != beginChar)
            p++;
         if( *p != beginChar || p - pBegin+1 > MAX_TOKEN_LEN )
         {
            //too long string
            strncpyx(tokenValue, pBegin, TOKEN_HEAD);
            strcat(tokenValue, "(Too long)");
            tokenType = XML_TOKEN_INVALID;
         }
         else
         {
            tokenType = XML_TOKEN_STRING;
            strncpyx(tokenValue, pBegin, p - pBegin+1);
            xmlTextDecode(tokenValue);
            p++;
         }
      }
      else if(isalpha(*p))
      {
         char *pBegin = p;
         p++;
         while(isalpha(*p) || *p>='0' && *p<='9' || *p == '_' || *p == ':'||*p == '-')
         {
            p++;
         }
         if(p - pBegin+1 > MAX_TOKEN_LEN )
         {
            //too long name
            strncpyx(tokenValue, pBegin, TOKEN_HEAD);
            strcat(tokenValue, "(Too long)");
            tokenType = XML_TOKEN_INVALID;
         }
         else
         {
            tokenType = XML_TOKEN_NAME;
            strncpyx(tokenValue, pBegin, p - pBegin+1);
            
            //luojianmin add on 2004/05/13            
            char* tok=strchr(tokenValue,':');
            if(tok!=NULL && strchr(tok+1,':')!=NULL)
               tokenType = XML_TOKEN_INVALID;
         }
      }
      else
      {
            //unknown token
         strncpyx(tokenValue, p, TOKEN_HEAD);
         tokenType = XML_TOKEN_INVALID;
      }
   }
   else 
   {
restart:
      //skip blank
      while(*p==' ' || *p=='\t' || *p=='\n' || *p=='\r')
      {
         p++;
      }
      //only handle BEGIN, COMMENT, CDATA, PI, TEXT
      GetLocation(p);
      if(*p==0)
      {
         tokenType = XML_TOKEN_EOF;
      }
      else if(strncmp(p, "<!--", 4) == 0)
      {
         char *pTail = strstr(p, "-->");
         if(!pTail)
         {
            //invalid comment
            strcpy(tokenValue, "<!-- ... (NEED -->)");
            tokenType = XML_TOKEN_INVALID;
         }
         else 
         {
            p = pTail + 3;
            goto restart;
         }
      }
      else if(strncmp(p, "<?", 2) == 0)
      {
         char *pTail = strstr(p, "?>");
         if(!pTail)
         {
            //invalid Process Instrution
            strcpy(tokenValue, "<? ... (NEED ?>)");
            tokenType = XML_TOKEN_INVALID;
         }
         else 
         {
            p = pTail + 2;
            goto restart;
         }
      }
      else if(strncmp(p, "<![CDATA[", 9) == 0)
      {
         char *pTail = strstr(p, "]]>");
         if(!pTail)
         {
            //invalid Process Instrution
            strcpy(tokenValue, "<![CDATA ... (NEED ]]>)");
            tokenType = XML_TOKEN_INVALID;
         }
         else 
         {
            //don't check it's length?
            if(pTail - (p+9) >MAX_TEXT_LEN)
            {
               strncpyx(textValue, p, TOKEN_HEAD);
               strcat(textValue, "(Too long)");
               tokenType = XML_TOKEN_INVALID;
            }
            else
            {
               tokenType = XML_TOKEN_CDATA;
               strncpyx(textValue, p+9, pTail-(p+9)+1);
               p = pTail + 3;
            }
         }
      }
      else if(strncmp(p, "</", 2) == 0)
      {
         tokenType = XML_TOKEN_START2;
         strcpy(tokenValue, "</");
         p+=2;
         bReadTag = 1;
      }
      else if(*p=='<')
      {
         tokenType = XML_TOKEN_START;
         strcpy(tokenValue, "<");
         p++;
         bReadTag = 1;
      }
      else
      {
         //we think this is a text
         char *pBegin = p;
         while(*p !=0  && *p !='<')
            p++;
         if(p - pBegin+1 > MAX_TEXT_LEN )
         {
            //too long text
            strncpyx(textValue, pBegin, TOKEN_HEAD);
            strcat(textValue, "(Too long)");
            tokenType = XML_TOKEN_INVALID;
         }
         else
         {
            tokenType = XML_TOKEN_TEXT;
            strncpyx(textValue, pBegin, p - pBegin+1);
            xmlTextDecode(textValue);
         }
      }
   }
   pCurrent = p;
}

void TXMLElem::addAttr(TXMLAttr* pAttr)
{
   if(attr==NULL)
   {
      attr=pAttr;
      return;
   }
   TXMLAttr* p=attr;
   while(p->brother!=NULL)
      p=p->brother;
   p->brother=pAttr;
}

char* TXMLElem::GetAttrValue(const char *name)
{
   TXMLAttr* p=GetAttr(name);
   if(p)
   {
       return p->getValue();
   }
   else
      return NULL;
}

TXMLAttr *TXMLElem::GetAttr(const char *name)
{
   for(TXMLAttr* p=attr; p!=NULL; p=p->brother)
   {
      if(stricmp(name, p->getName()) == 0)
         return p;
   }
   return NULL;
}

int TXMLElem::GetAttrNum()
{
   int i=0;
   for(TXMLAttr* p=attr; p!=NULL; p=p->brother)
   {
      i++;
   }
   return i;
}


TXMLAttr *TXMLElem::GetAttr(int index)
{
   int i=0;
   for(TXMLAttr* p=attr; p!=NULL; p=p->brother)
   {
      if(i == index)
         return p;
      i++;
   }
   return NULL;
}

TXMLElem *TXMLElem::GetSubElem(const char *tag1)
{
   for(TXMLElem* p=child; p!=NULL; p=p->brother)
   {
      if(stricmp(tag1, p->getTag()) == 0)
         return p;
   }
   return NULL;
}

int TXMLElem::GetSubElemNum()
{
   int i=0;
   for(TXMLElem* p=child; p!=NULL; p=p->brother)
   {
      i++;
   }
   return i;
}

int TXMLElem::GetSubElemNumByTag(char* strTag)
{
   if (strTag==NULL) return 0;
   int i=0;
   for(TXMLElem* p=child; p!=NULL; p=p->brother)
   {
      if(p->getTag()!=NULL && stricmp(p->getTag(),strTag)==0)
         i++;
   }
   return i;
}

int TXMLElem::GetSubElemName(int index,char* name)
{
   TXMLElem* p=GetSubElem(index);
   if(p!=NULL)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美理论电影在线| 亚洲成人精品影院| 国产在线播放一区二区三区| 日韩一区二区在线观看视频| 蜜臀久久99精品久久久画质超高清| 欧美大片在线观看一区二区| 伦理电影国产精品| 久久午夜色播影院免费高清| 岛国精品一区二区| 国产一区高清在线| 国产精品三级视频| 91久久精品一区二区二区| 五月天国产精品| 久久免费视频一区| 色综合久久久久久久久久久| 亚洲午夜激情网站| 久久久精品免费免费| 色先锋aa成人| 久久精品国产亚洲a| 国产精品女人毛片| 91精品欧美综合在线观看最新| 国产一区二区三区国产| 亚洲国产视频a| 91精品国产福利| 国产主播一区二区三区| 成人免费在线观看入口| 4438x成人网最大色成网站| 成人在线综合网| 亚洲午夜激情网页| 中文字幕的久久| 欧美一区二区成人| 色综合久久综合中文综合网| 人人精品人人爱| 亚洲私人黄色宅男| 亚洲精品在线一区二区| 色94色欧美sute亚洲线路一ni | 欧美手机在线视频| 国产精品一线二线三线| 午夜私人影院久久久久| 国产精品免费av| 精品久久国产字幕高潮| 欧美三级乱人伦电影| 成人黄色国产精品网站大全在线免费观看 | 国产精品免费久久| 欧洲国内综合视频| 成人精品免费看| 毛片基地黄久久久久久天堂| 亚洲男同性视频| 国产精品伦理在线| 久久婷婷一区二区三区| 91精品一区二区三区久久久久久| 国产精品一区一区| 久久精品噜噜噜成人av农村| 亚洲va国产va欧美va观看| 一区二区中文视频| 国产日韩精品一区二区三区| 日韩欧美一二区| 91麻豆精品国产91久久久资源速度 | 亚洲一区二区三区在线播放| 久久久另类综合| 欧美成人高清电影在线| 337p亚洲精品色噜噜噜| 色域天天综合网| 91丨国产丨九色丨pron| 成人高清视频在线| 成人av在线网站| thepron国产精品| 国产91丝袜在线播放九色| 国产在线精品免费| 精品一区二区三区蜜桃| 美国精品在线观看| 国产综合色视频| 国产乱码精品一区二区三区五月婷 | 精品久久国产老人久久综合| 欧美一区二区三区四区在线观看 | 亚洲国产乱码最新视频| 一区二区三区免费观看| 一区二区三区不卡视频| 一区av在线播放| 日韩国产精品大片| 久久99国产精品免费| 极品销魂美女一区二区三区| 国产综合色产在线精品| 国产精品一二二区| 99re热视频这里只精品| 91国偷自产一区二区使用方法| 91久久精品午夜一区二区| 欧美日韩国产中文| 日韩欧美自拍偷拍| 久久久青草青青国产亚洲免观| 国产精品丝袜一区| 一区二区三区在线观看欧美| 日韩av一二三| 高清国产一区二区| 91蜜桃在线免费视频| 欧美日韩成人综合| 精品毛片乱码1区2区3区 | 亚洲精品免费播放| 亚洲国产精品久久人人爱蜜臀| 日韩av电影免费观看高清完整版在线观看 | 亚洲h精品动漫在线观看| 日韩av在线播放中文字幕| 国产麻豆视频一区二区| 99这里都是精品| 欧美性大战久久久久久久| 日韩欧美一级特黄在线播放| 久久久综合视频| 一级日本不卡的影视| 精品中文av资源站在线观看| 国产一区二区不卡在线| 91亚洲男人天堂| 精品久久久网站| 中文字幕一区二区三区不卡| 日本网站在线观看一区二区三区| 国产ts人妖一区二区| 欧美亚洲高清一区| 久久精品视频免费| 午夜av区久久| 99视频国产精品| 日韩一区二区在线观看视频播放| 国产精品国产自产拍高清av| 性欧美疯狂xxxxbbbb| 丁香六月综合激情| 欧美变态口味重另类| 亚洲国产综合91精品麻豆| 国内精品在线播放| 在线成人av影院| 亚洲欧美日韩国产综合| 国产福利精品导航| 538在线一区二区精品国产| 亚洲天天做日日做天天谢日日欢| 另类专区欧美蜜桃臀第一页| 色狠狠一区二区三区香蕉| 久久亚洲精华国产精华液| 亚洲国产aⅴ成人精品无吗| 岛国av在线一区| 欧美精品一区二| 日产精品久久久久久久性色| 一本大道综合伊人精品热热| 久久免费的精品国产v∧| 日韩精品三区四区| 欧美色视频在线| 亚洲免费观看在线视频| 处破女av一区二区| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 视频一区国产视频| 91欧美一区二区| 国产精品久久三区| 国产激情视频一区二区在线观看| 欧美日韩色一区| 亚洲一区二区三区不卡国产欧美| 99久久精品国产麻豆演员表| 国产无遮挡一区二区三区毛片日本| 美女mm1313爽爽久久久蜜臀| 欧美日韩一区二区三区高清| 亚洲精品视频免费看| 一本久久精品一区二区| 成人免费小视频| 99久久精品免费| 自拍av一区二区三区| 99久精品国产| 亚洲精品国产精华液| 91亚洲精品久久久蜜桃网站| 自拍av一区二区三区| 色综合久久99| 亚洲国产中文字幕| 欧美猛男超大videosgay| 日韩精品欧美成人高清一区二区| 欧美日韩国产另类一区| 日韩经典中文字幕一区| 日韩一区二区免费视频| 久久精品噜噜噜成人av农村| 26uuu久久综合| 国产黑丝在线一区二区三区| 久久久久久影视| 成人免费看黄yyy456| 亚洲欧美日韩人成在线播放| 91国产免费观看| 亚洲国产精品麻豆| 欧美电影免费观看完整版| 九一九一国产精品| 日本一区二区三区在线观看| 99在线精品视频| 亚洲一区二区精品3399| 在线电影院国产精品| 久久国产精品99精品国产| 精品国产乱码久久久久久夜甘婷婷| 国产在线观看免费一区| 国产精品女上位| 欧美精品乱码久久久久久| 麻豆91精品视频| 国产精品乱码一区二区三区软件| 91成人在线精品| 美女任你摸久久| 国产精品久久久久久久久晋中| 日本久久电影网| 激情另类小说区图片区视频区| 中文在线免费一区三区高中清不卡| 在线视频综合导航| 久久国产精品99久久人人澡|