Fala XTibianos!
Vim disponibilizar e ensinar como usar a livraria xml em lua, desenvolvida por mim.
Ela foi desenvolvida para substituir a livraria padrão disponibilizada por lua para trabalhar com dados xml.
Essa livraria não requer a dll-xml necessária para a livraria padrão lua.
Aqui tem o tutorial criado por mim para demonstrar as funções e suas implementações da livraria luaxml.
Tutorial lua lib xml padrão
Vamos lá.
Primeiro, a livraria:
Vou ensinar como usar ela.
Vou usar como exemplo uma parte do arquivo vocations.xml:
Primeiro, carregar o arquivo.
Ele vai retornar um objeto para ser usado pelos metametodos ou uma string para outros fins como "print".
Buscar a tag desejada.
Ele vai retornar uma tabela contendo todos os parametros que foram lidos no arquivo.
O primeiro argumento da função, é o nome da tag requerida. exemplo: <tagNome ....>, tagNome seria o primeiro argumento da função.
O segundo elemento é usado para diferenciar um bloco de outro como no caso do arquivo vocations que contem varias vocations, mas apenas uma é a requerida.
O terceiro elemento é o que diferencia um bloco de outro similar. seguindo o exemplo do arquivo vocations, existe varias vocações, mas apenas uma delas tem o id de numero 2.
Imprime o que foi lido no arquivo.
a saida seria essa, nesse caso.
Mas, ela tambem é uma tabela, por isso, voce pode pegar os elementos dentro dela dessa forma.
As tags existentes dentro do bloco "vocation", tambem é uma tabela com indice numerico; portanto é valido pegar os dados dela dessa forma.
Cada tag que exista dentro do bloco, vem como uma tabela com indicie numerico.
Criando objetos para xml:
O argumento inserido , seria o nome do bloco. Ex -> <novo> </novo>
Adiciona tag's dentro do corpo do bloco.
Pode ser adicionado quantas tags quiser.
Cria uma tagbloco ou bloco dentro do bloco principal. Ex -> <tagBloco inserido="primer" ordem="2" face="not"> </tagBloco>
Essa função retorna um objeto para ser usado pelos metametodos ou uma string para outros fins como "print".
Dessa forma que foi declarada sem uma tabela contendo os parametros da tag, ela é criada como um bloco. Ex -> <newBloco> </newBloco>
Adiciona tag's ao corpo do novo bloco/tagbloco criado pela função append.
E por fim, salva os dados em um arquivo.
Nessa função, existe o argumento unico que é o destino do arquivo e seu nome, que nesse caso foi ocultado.
Esse é os dados dentro do arquivo gerador pelo script.
Devido as novas atualizações feitas a lib, agora podeis usar caracteres especial de busca e inserção de maiores informações para busca.
Vou usar como exemplo essa parte do arquivo items.xml e movements.xml para explicar essas mudanças.
items
movements
Na versão anterior da lib ela não poderia buscar informações no arquivo items.xml devido a um erro na ora de selecionar o bloco buscado.
O problema residia em que: ao encontrar uma tag ela busca o seu fechamento, sendo que, no exemplo da parte do arquivo items que postei acima, ela pegava todo esse bloco, dessa forma anulando o verdadeiro id buscado.
Isso foi resolvido. agora ela filtra o bloco encontrado antes de fazer a analise de que seja o dado requisitado.
Outro problema era quando se desejava buscar uma informação mais precisa, como no caso do arquivo movements.xml que existe duas tags com os mesmo ids equip e deequip; se eu colocasse o id de qualquer item ele me retornaria a primeira sentença encontrada que na maioria das vezes não era a que eu queria. isso também foi corrigido; agora podeis usar mais informações para melhorar a precisão da busca. Veja esse exemplo:
Obs. Os codigos estão codificados em utf8, converta para ansi antes de usa-los.
É isso ae pessoal, espero que gostem; qualquer erro ou sugestão serão bem vindas. obrigado.