Mercurial > hg > dml-open-cliopatria
diff cpack/dml/lib/xmltraverse.pl @ 0:718306e29690 tip
commiting public release
author | Daniel Wolff |
---|---|
date | Tue, 09 Feb 2016 21:05:06 +0100 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cpack/dml/lib/xmltraverse.pl Tue Feb 09 21:05:06 2016 +0100 @@ -0,0 +1,50 @@ +/* Part of DML (Digital Music Laboratory) + Copyright 2014-2015 Samer Abdallah, University of London + + This program is free software; you can redistribute it and/or + modify it under the terms of the GNU General Public License + as published by the Free Software Foundation; either version 2 + of the License, or (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +:- module(xmltraverse, [traverse/3, op(720,xfx,@), op(750,xfy,~), op(750,xfy,..) ]). +% for traverse/3 paths +:- op(720,xfx,@). +:- op(750,xfy,~). +:- op(750,xfy,..). + +%% traverse(+Dir:oneof([f,b]), +Doc:xml_element, -P:xml_path) is nondet. +% +% Succeeds once for each path through an XML element starting at the top +% and travelling all or part of the way down through the tree structure. +traverse(f,El,Path) :- traverse_f(El,Path). +traverse(b,El,Path) :- traverse_b([],El,Path). + +traverse_f(Other,{Other}) :- atomic(Other), !. +traverse_f(Element,\Element). +traverse_f(element(Name,_,_), n(Name)). +traverse_f(element(Name,Attribs,_),Name @ A) :- member(A,Attribs). +traverse_f(element(Name,_,Content),Name .. Path1) :- + ( Path1 = \Content + ; Path1 = (I~Path2), + nth1(I,Content,SubE), + traverse_f(SubE,Path2) + ). + + +traverse_b(L,Other,{Other}..L) :- atomic(Other), !. +traverse_b(L,element(Name,Attribs,Content),Path) :- !, + ( Path = (A @ Name .. L), member(A,Attribs) + ; nth1(N,Content,SubE), + traverse_b(N ~ Name..L,SubE,Path) + ). +