libxml2库使用示例

解析一个名位noname.xml的文件:



        
        

 解析以上文件的源文件:

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include "NDAttribute.h"
#include "NDAttributeList.h"
#include "PVAttribute.h"
#include 


int main()
{
        MAC_HANDLE * macHandle;
        char ** macPairs;
        int status = 0;
        std::ostringstream buff;
        std::string buffer;
        std::ifstream infile;
        std::string fileName;
        std::string macrodefs;
        int bufferSize;

        fileName = "noname.xml";

        infile.open(fileName.c_str());

        buff << infile.rdbuf();
        buffer = buff.str();

        printf("The name of a xml file to parse:\n ");
        printf("fileName: %s\n", fileName.c_str());
        printf("The file's content:\n");
        printf("%s\n", buffer.c_str());
        printf("--------------------------------------------------------------\n");

        macCreateHandle(&macHandle, 0);

        macrodefs = "P=BS:,R=SIM1:,T=TIFF1:";
        printf("The macro defination:  %s\n", macrodefs.c_str());

        status = macParseDefns(macHandle, macrodefs.c_str() ,&macPairs);

        if (status < 0){
                printf("macParseDefns call failed\n");
                return -1;
        }

        status = macInstallMacros(macHandle, macPairs);
        if (status < 0){
                printf("macInstallMacros call failed\n");
                return -1;
        }

        bufferSize = (int)(buffer.length() * 10);
        char * tmpBuffer = (char *)malloc(sizeof(char ) * bufferSize);

        status = macExpandString(macHandle, buffer.c_str(), tmpBuffer, bufferSize);

        if (status < 0){
                printf("macExpandString call failed\n");
                free(tmpBuffer);
                free(macPairs);
                return -1;
        }

        macrodefs = tmpBuffer;
        free(tmpBuffer);
        macDeleteHandle(macHandle);

        printf("Orignal file content: \n");
        printf("'%s'\n\n", buffer.c_str());
        printf("The expended file contenent\n");
        printf("'%s'\n\n", macrodefs.c_str());

        const char *pName, *pSource, *pAttrType, *pDescription, *pDBRType;
        xmlDocPtr doc;
        xmlNode *Attr, *Attrs;

        doc = xmlReadMemory(macrodefs.c_str(), (int)macrodefs.length(), NULL , NULL, 0);

        if (doc == NULL) {
                printf("xmlReadMemory call failed\n");
                return -1;
        }
        Attrs = xmlDocGetRootElement(doc);

        if ((!xmlStrEqual(Attrs->name, (const xmlChar *)"Attributes")))
        {
                printf("Cannot find the root 'Attriubtes\n'");
                return -1;
        }

        printf("-----------------------------------------------------------------------\n");
        printf("Parse the xml file: %s\n", fileName.c_str());
        PVAttribute * pAttribute;
        NDAttributeList * list = new NDAttributeList();

        for (Attr = xmlFirstElementChild(Attrs); Attr; Attr = xmlNextElementSibling(Attr)){
                pName = (const char *)xmlGetProp(Attr, (const xmlChar *)"name");
                if (!pName){
                        printf("xmlGetProp '%s' call failed\n", "name");
                        return -1;
                }

                pDescription = (const char *)xmlGetProp(Attr, (const xmlChar *)"description");
                if (!pDescription) pDescription ="";

                pSource = (const char *)xmlGetProp(Attr, (const xmlChar *)"source");
                if (!pSource){
                        printf("xmlGetProp '%s' call failed\n", "source");
                        return -1;
                }

                pAttrType = (const char *)xmlGetProp(Attr, (const xmlChar *)"type");
                if (!pAttrType){
                        printf("xmlGetProp '%s' call failed\n", "type");
                        return -1;
                }

                pDBRType = (const char *)xmlGetProp(Attr, (const xmlChar *)"dbrtype");
                if (!pDBRType){
                        printf("xmlGetProp '%s' call failed\n", "dbrtype");
                        return -1;
                }


                int dbrType = DBR_NATIVE;
                if (pDBRType) {
                        if      (!strcmp(pDBRType, "DBR_CHAR"))
                                dbrType = DBR_CHAR;
                        else if (!strcmp(pDBRType, "DBR_SHORT"))
                                dbrType = DBR_SHORT;
                        else if (!strcmp(pDBRType, "DBR_ENUM"))
                                dbrType = DBR_ENUM;
                        else if (!strcmp(pDBRType, "DBR_INT"))
                                dbrType = DBR_INT;
                        else if (!strcmp(pDBRType, "DBR_LONG"))
                                dbrType = DBR_LONG;
                        else if (!strcmp(pDBRType, "DBR_FLOAT"))
                                dbrType = DBR_FLOAT;
                        else if (!strcmp(pDBRType, "DBR_DOUBLE"))
                                dbrType = DBR_DOUBLE;
                        else if (!strcmp(pDBRType, "DBR_STRING"))
                                dbrType = DBR_STRING;
                        else
                                 dbrType = DBR_NATIVE;
                }

                printf("name: %s\tsource: %s\ttype: %s\tdbrtype: %s\tdescription: %s\n", pName, pSource, pAttrType, pDBRType, pDescription);

                pAttribute = new PVAttribute(pName, pDescription, pSource, dbrType );
                list->add(pAttribute);

        }

        epicsThreadSleep(1.0);
        printf("-----------------------------------------------------------------------\n");
        list->updateValues();
        epicsThreadSleep(1.0);
        printf("NDAttributeList and NDAttriubte's information: \n");
        list->report(stdout, 20);

        return 0;
}

先用通道访问测试以上此处用到的EPICS过程变量:

orangepi@orangepi5:~/C_program/host_program/hostApp$ caget BS:SIM1:cam1:AcquireTime
BS:SIM1:cam1:AcquireTime   5
orangepi@orangepi5:~/C_program/host_program/hostApp$ caget -S BS:SIM1:TIFF1:FilePath
BS:SIM1:TIFF1:FilePath /home/test_gap

编译以上程序,执行结果如下:

orangepi@orangepi5:~/C_program/host_program/hostApp$ O.linux-aarch64/testXml
The name of a xml file to parse:
 fileName: noname.xml
The file's content:


        
        


--------------------------------------------------------------
The macro defination:  P=BS:,R=SIM1:,T=TIFF1:
Orignal file content:
'

        
        

'

The expended file contenent
'

        
        

'

-----------------------------------------------------------------------
Parse the xml file: noname.xml
name: AcquireTime       source: BS:SIM1:cam1:AcquireTime    type: EPICS_PV  dbrtype: DBR_NATIVE     description: Camera acquire time
name: FilePath  source: BS:SIM1:TIFF1:FilePath      type: EPICS_PV  dbrtype: DBR_STRING     description: File Save Path
-----------------------------------------------------------------------
NDAttributeList and NDAttriubte's information:

NDAttributeList: address=0x556d1b5970:
  number of attributes=2

NDAttribute, address=0x556d1b7f90:
  name=AcquireTime
  description=Camera acquire time
  source type=2
  source type string=NDAttrSourceEPICSPV
  source=BS:SIM1:cam1:AcquireTime
  dataType=NDAttrFloat64
  value=5.000000
  PVAttribute
    dbrType=DBR_invalid
    chanId=0x556d1bf3c0
    eventId=0x7f80000b70

NDAttribute, address=0x556d1dff40:
  name=FilePath
  description=File Save Path
  source type=2
  source type string=NDAttrSourceEPICSPV
  source=BS:SIM1:TIFF1:FilePath
  dataType=NDAttrString
  value=/home/test_gap
  PVAttribute
    dbrType=DBR_STRING
    chanId=0x556d1bf3f8
    eventId=0x7f80000b98

你可能感兴趣的:(EPICS教程,Linux,C,EPICS,C语言)