Páginas filhas
  • LGX - LXMLOBJECT

Classe que permite manipular conteúdos XML utilizando expressão XPATH.


Hierarquia


Métodos GET


Métodos acessíveis através da função _ADVPL_get_property que permite recuperar e manipular os valores do componente: 


Método GET: ACTIVATE

Valida e efetua a interpretação de um determinado conteúdo XML.

Sintaxe


_ADVPL_get_property(< l_reference >,"GET", "HOST" ) => CHAR

Parâmetros


Tipo

Descrição

CHAR
Conteúdo XML.

Retorno


Tipo

Descrição

SMALLINT

TRUE ou 1 - Leitura e interpretação do conteúdo XML realizado com sucesso.

FALSE ou 0 - Falha na leitura e interpretação do conteúdo XML.


Observação


  • Para recuperar a mensagem de erro, no caso de ocorrer falha, utilize o método ERROR_MESSAGE.


Método GET: ATTR_VALUE

Retorna o valor de um atributo do nó informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"ATTR_VALUE", < l_Xpath >, < l_attributeName >) => CHAR

Parâmetros


NomeTipoDescriçãoObrigatório?Padrão
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim
l_attributeNameCHARNome do atributo desejado.Sim

Retorno


TipoDescrição
CHARRetorna uma string vazia, se obteve erro. Caso contrário, o conteúdo do atributo informado.




Método GET: ERROR_MESSAGE 

Retorna a mensagem de erro resultante de falha na execução do método ACTIVATE.

Sintaxe


_ADVPL_get_property(< l_reference >,"ERROR_MESSAGE") => CHAR

Retorno


TipoDescrição
CHARMensagem de erro detalhando a inconsistência ocorrida na execução do método ACTIVATE.




Método GET: NODE_LENGTH

Retorna a quantidade de nós filhos do nó pai informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"NODE_LENGTH", < l_Xpath >) => INTEGER

Parâmetros


NomeTipoDescriçãoObrigatório?
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim

Retorno


TipoDescrição
INTEGERQuantidade de nós filhos do nó pai informado.




Método GET: NODE_VALUE

Retorna o valor de um caminho de nó informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"NODE_VALUE", < l_Xpath >) => CHAR

Parâmetros


NomeTipoDescriçãoObrigatório?
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim

Retorno


TipoDescrição
CHARRetorna uma string vazia, se obteve erro. Caso contrário, o conteúdo do nó informado.




Método GET: SERIALIZE

Serializa o conteúdo XML, ou seja, retorna o XML no formato STRING.

Sintaxe


_ADVPL_get_property(< l_reference >,"SERIALIZE") => CHAR

Retorno


TipoDescrição
CHARConteúdo XML serializado com todas as alterações realizadas.





Métodos SET


Métodos acessíveis através da função _ADVPL_set_property que permite alterar e manipular os valores do componente.


Método SET: ADD_ATTR

Adiciona um novo atributo para o nó informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"ADD_ATTR", < l_Xpath >, < l_attributeName >, < l_attributeValue> ) 

Parâmetros


NomeTipoDescriçãoObrigatório?Padrão
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim
l_attributeNameCHARNome do atributo desejado.Sim
l_attributeValueCHARValor do atributo.Sim




Método SET: ADD_NODE

Adiciona um novo nó filho para o nó pai informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"ADD_NODE", < l_Xpath >, < l_nodeName >, < l_nodeValue> ) 

Parâmetros


NomeTipoDescriçãoObrigatório?Padrão
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim
l_nodeNameCHARNome do nó filho.Sim
l_nodeValueCHARValor do nó filho.Sim




Método SET: ATTR_VALUE

Alterar o valor de um determinado atributo do nó informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"ATTR_VALUE", < l_Xpath >, < l_attributeName >, < l_attributeValue> ) 

Parâmetros


NomeTipoDescriçãoObrigatório?Padrão
l_XpathCHARCaminho do nó desejado (Expressão XPATH).Sim
l_attributeNameCHARNome do atributo desejado.Sim
l_attributeValueCHARNovo valor para o atributo.Sim




Método SET: DEACTIVATE

Desativa/destrói a instância do componente LXMLOBJECT obtido na execução do método ACTIVATE.

Sintaxe


_ADVPL_set_property(< l_reference >,"DEACTIVATE")



Método SET: NODE_VALUE

Altera o valor de um determinado nó filho para um nó pai informado.

Sintaxe


_ADVPL_get_property(< l_reference >,"NODE_VALUE", < l_Xpath >, < l_nodeName >, < l_nodeValue> ) 

Parâmetros


NomeTipoDescriçãoObrigatório?Padrão
l_XpathCHARCaminho do nó pai desejado (Expressão XPATH).Sim
l_nodeNameCHARNome do nó filho desejado.Sim
l_nodeValueCHARNovo valor para o nó filho.Sim




Sintaxe


LET m_xmlobject_reference = _ADVPL_create_component(NULL,"LXMLOBJECT")

Exemplo


Clique no link na lateral direita para expandir o código de exemplo.

Código de exemplo do componente LXMLObject
#------------------------------#
 FUNCTION LXMLObjectTest()
#------------------------------#
    DEFINE l_xml         TEXT
    DEFINE l_xml_obj_ref VARCHAR(10)
    DEFINE l_break       CHAR(002)
    DEFINE l_value       CHAR(100)
    DEFINE l_status      SMALLINT

    IF LOG_isSrvUnix() = "U" THEN
       LET l_break = ASCII(10)
    ELSE
       LET l_break = ASCII(13)
       LET l_break = l_break CLIPPED, ASCII(10)
    END IF

    LET l_xml = '<?xml version="1.0"?>' || l_break
    LET l_xml = l_xml CLIPPED || '<bookStore name="Saraiva" country="BR">' || l_break
    LET l_xml = l_xml CLIPPED || '  <foundation>' || l_break
    LET l_xml = l_xml CLIPPED || '    <founder>Seu Saraiva</founder>' || l_break
    LET l_xml = l_xml CLIPPED || '    <year>1914</year>' || l_break
    LET l_xml = l_xml CLIPPED || '  </foundation>' || l_break
    LET l_xml = l_xml CLIPPED || '  <books>' || l_break
    LET l_xml = l_xml CLIPPED || '    <book isNew="true">' || l_break
    LET l_xml = l_xml CLIPPED || '      <title>A Game of Thrones</title>' || l_break
    LET l_xml = l_xml CLIPPED || '      <author>George R. R. Martin</author>' || l_break
    LET l_xml = l_xml CLIPPED || '      <price>9.99</price>' || l_break
    LET l_xml = l_xml CLIPPED || '      <origin>US</origin>' || l_break
    LET l_xml = l_xml CLIPPED || '    </book>' || l_break
    LET l_xml = l_xml CLIPPED || '    <book isNew="false">' || l_break
    LET l_xml = l_xml CLIPPED || '      <title>A Clash of Kings</title>' || l_break
    LET l_xml = l_xml CLIPPED || '      <author>George R. R. Martin</author>' || l_break
    LET l_xml = l_xml CLIPPED || '      <price>9.99</price>' || l_break
    LET l_xml = l_xml CLIPPED || '      <origin>US</origin>' || l_break
    LET l_xml = l_xml CLIPPED || '    </book>' || l_break
    LET l_xml = l_xml CLIPPED || '  </books>' || l_break
    LET l_xml = l_xml CLIPPED || '</bookStore>' || l_break

    LET l_xml_obj_ref = _ADVPL_create_component(NULL,"LXMLOBJECT")

    # GET ACTIVATE: valida e inicia a interpretação do XML.
    LET l_status = _ADVPL_get_property(l_xml_obj_ref,"ACTIVATE",l_xml)

    IF  l_status THEN
        CALL CONOUT("LXMLOBJECT GET ACTIVATE1    OK")
    ELSE
        CALL CONOUT("LXMLOBJECT GET ACTIVATE1   NOK")
        CALL CONOUT("ERROR = "+_ADVPL_get_property(l_xml_obj_ref,"ERROR_MESSAGE"))
        RETURN FALSE
    END IF

    # GET ATTR_VALUE: Recupera o valor de determinado atributo de um nó informado.
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"ATTR_VALUE","/bookStore/books/book[1]","isNew")

    IF  l_value = "true" THEN
        CALL CONOUT("LXMLOBJECT ATTR_VALUE (/bookStore/books/book[1] isNew)     OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT ATTR_VALUE (/bookStore/books/book[1] isNew)     NOK " || l_value CLIPPED)
    END IF

    # GET ATTR_VALUE: Recupera o valor de determinado atributo de um nó informado.
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"ATTR_VALUE","/bookStore/books/book[2]","isNew")

    IF  l_value = "false" THEN
        CALL CONOUT("LXMLOBJECT ATTR_VALUE (/bookStore/books/book[2] isNew)      OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT ATTR_VALUE (/bookStore/books/book[2] isNew)     NOK " || l_value CLIPPED)
    END IF

    # GET NODE_VALUE: Recupera o valor de determinado nó filho de um nó pai informado.
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"NODE_VALUE","/bookStore/books/book[1]/title")

    IF  l_value = "A Game of Thrones" THEN
        CALL CONOUT("LXMLOBJECT GET NODE_VALUE /bookStore/books/book[1]/title  OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT GET NODE_VALUE /bookStore/books/book[1]/title NOK " || l_value CLIPPED)
    END IF

    # GET NODE_VALUE: Recupera o valor de determinado nó filho de um nó pai informado.
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"NODE_VALUE","/bookStore/books/book[2]/title")

    IF  l_value = "A Clash of Kings" THEN
        CALL CONOUT("LXMLOBJECT GET NODE_VALUE /bookStore/books/book[2]/title  OK" || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT GET NODE_VALUE /bookStore/books/book[2]/title NOK " || l_value CLIPPED)
    END IF

    # GET NODE_VALUE: Recupera o valor de determinado nó filho de um nó pai informado.
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"NODE_LENGTH","/bookStore/books")

    IF  l_value = 2 THEN
        CALL CONOUT("LXMLOBJECT GET NODE_LENGTH (/bookStore/books)  OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT GET NODE_LENGTH (/bookStore/books) NOK " || l_value CLIPPED)
    END IF

    # SET ADD_ATTR: Adiciona um novo atributo no nó informado.
    CALL _ADVPL_set_property(l_xml_obj_ref,"ADD_ATTR","/bookStore/books/book[1]","isOld","true")
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"ATTR_VALUE","/bookStore/books/book[1]","isOld")

    IF  l_value = "true" THEN
        CALL CONOUT("LXMLOBJECT SET ADD_ATTR (/bookStore/books/book[1] isOld=true)    OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT SET ADD_ATTR (/bookStore/books/book[1] isOld=true)   NOK " || l_value CLIPPED)
    END IF

    # SET ADD_NODE: Adiciona um novo no nó filho no nó pai informado.
    CALL _ADVPL_set_property(l_xml_obj_ref,"ADD_NODE","/bookStore/books/book[2]","year","1999")
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"NODE_VALUE","/bookStore/books/book[2]/year")

    IF  l_value = "1999" THEN
        CALL CONOUT("LXMLOBJECT SET ADD_NODE (/bookStore/books/book[2] year=1999)    OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT SET ADD_NODE (/bookStore/books/book[2] year=1999)   NOK " || l_value CLIPPED)
    END IF

    # SET ATTR_VALUE: Altera o valor de um atributo do nó informado.
    CALL _ADVPL_set_property(l_xml_obj_ref,"ATTR_VALUE","/bookStore/books/book[1]","isOld","false")
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"ATTR_VALUE","/bookStore/books/book[1]","isOld")

    IF  l_value = "false" THEN
        CALL CONOUT("LXMLOBJECT SET ATTR_VALUE (/bookStore/books/book[1] isOld=false)  OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT SET ATTR_VALUE (/bookStore/books/book[1] isOld=false) NOK " || l_value CLIPPED)
    END IF

    # SET NODE_VALUE: Altera o valor de um atributo do nó informado.
    CALL _ADVPL_set_property(l_xml_obj_ref,"NODE_VALUE","/bookStore/books/book[2]/title","O Alquimista 2")
    LET l_value = _ADVPL_get_property(l_xml_obj_ref,"NODE_VALUE","/bookStore/books/book[2]/title")

    IF  l_value = "O Alquimista 2" THEN
        CALL CONOUT("LXMLOBJECT SET NODE_VALUE (/bookStore/books/book[2]/title = 'O Alquimista 2')  OK " || l_value CLIPPED)
    ELSE
        CALL CONOUT("LXMLOBJECT SET NODE_VALUE (/bookStore/books/book[2]/title = 'O Alquimista 2') NOK " || l_value CLIPPED)
    END IF

    # GET SERIALIZE: Tranfere todo conteúdo DO XML para um STRING
    LET l_xml = _ADVPL_get_property(l_xml_obj_ref,"SERIALIZE")
    CALL CONOUT("LXMLOBJECT GET SERIALIZE: " || l_xml CLIPPED)

    RETURN TRUE
END FUNCTION

Informações


Componente disponível a partir do LOGIX 12.1.29.