All Downloads are FREE. Search and download functionalities are using the official Maven repository.

es.rickyepoderi.wbxml.document.OpaqueAttributePlugin Maven / Gradle / Ivy

/*
 * 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 program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *    
 * Linking this library statically or dynamically with other modules 
 * is making a combined work based on this library. Thus, the terms and
 * conditions of the GNU General Public License cover the whole
 * combination.
 *    
 * As a special exception, the copyright holders of this library give 
 * you permission to link this library with independent modules to 
 * produce an executable, regardless of the license terms of these 
 * independent modules, and to copy and distribute the resulting 
 * executable under terms of your choice, provided that you also meet, 
 * for each linked independent module, the terms and conditions of the 
 * license of that module.  An independent module is a module which 
 * is not derived from or based on this library.  If you modify this 
 * library, you may extend this exception to your version of the 
 * library, but you are not obligated to do so.  If you do not wish 
 * to do so, delete this exception statement from your version.
 *
 * Project: github.com/rickyepoderi/wbxml-stream
 * 
 */
package es.rickyepoderi.wbxml.document;

import java.io.IOException;

/**
 * 

WBXML defines that attribute and content can have a special kind * of opaque data (an array of bytes in length). Usually the language * definitions use those opaque tags to encode special information * (for example SI encodes in an opaque data date formats, or WV uses * opaques to encode integers and datetime data). Obviously opaque data * is unique in every language and special plugins should parse or encode * that data

* *

This interface let the user to develop special treatment for attreibute. * The definition loads the attr plugins and the parser and the encoder * call the specified method if such attribute is found. The parser * obviously only calls the parse method if it finds an opaque data. The * encoder always calls the encode method, the implementation can encode the * attribute value vas an opaque or not.

* *

This interface is used for attributes. There is another very similar * interface for tags / contents.

* * @author ricky */ public interface OpaqueAttributePlugin { /** * Encode method that encodes a opaque data. All the elements in the current * encoding are passed. There opaques so weird that is better to have all * the possible status of the encoding. * * @param encoder The encoder used in the encoding process * @param element The element which content or attribute is being encoded * @param attr The attribute which is being encoded * @param value The value string is being encoded * @throws IOException Some error in the encoding process */ public void encode(WbXmlEncoder encoder, WbXmlElement element, WbXmlAttribute attr, String value) throws IOException; /** * Parse method that parses an opaque data. The opaque data is read from * the WBXML stream and passed in the byte array argument. In this case * the parser only calls the plugin if real opaque data is found. * * @param parser The parser doing the parsing * @param data The data read from the opaque * @return The string value the opaque represents * @throws IOException Some error in the parsing */ public String parse(WbXmlParser parser, byte[] data) throws IOException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy