/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ /** * ATOM data conversion functions. */ /** * Convert a list of elements to a list of values representing an ATOM entry. */ function entryElementsToValues(e) { var lt = filter(selector(mklist(element, "'title")), e); var t = isNil(lt)? '' : elementValue(car(lt)); var li = filter(selector(mklist(element, "'id")), e); var i = isNil(li)? '' : elementValue(car(li)); var lc = filter(selector(mklist(element, "'content")), e); return mklist(t, i, elementValue(car(lc))); } /** * Convert a list of elements to a list of values representing ATOM entries. */ function entriesElementsToValues(e) { if (isNil(e)) return e; return cons(entryElementsToValues(car(e)), entriesElementsToValues(cdr(e))); } /** * Convert a list of strings to a list of values representing an ATOM entry. */ function readATOMEntry(l) { var e = readXML(l); if (isNil(e)) return mklist(); return entryElementsToValues(car(e)); } /** * Convert a list of values representy an ATOM entry to a value. */ function entryValue(e) { var v = elementsToValues(mklist(caddr(e))); return cons(car(e), (cadr(e), cdr(car(v)))); } /** * Return true if a list of strings represents an ATOM feed. */ function isATOMFeed(l) { if (isNil(l)) return false; if (car(l).substring(0, 5) != "