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

com.github.sviperll.meta.TextFormat Maven / Gradle / Ivy

Go to download

Metaprogramming tools. Useful for annotation processors implementation. Part of chicory.

There is a newer version: 0.36
Show newest version
/*
 * Copyright (c) 2014, Victor Nazarov 
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 *  1. Redistributions of source code must retain the above copyright notice,
 *     this list of conditions and the following disclaimer.
 *
 *  2. Redistributions in binary form must reproduce the above copyright notice,
 *     this list of conditions and the following disclaimer in the documentation and/or
 *     other materials provided with the distribution.
 *
 *  3. Neither the name of the copyright holder nor the names of its contributors
 *     may be used to endorse or promote products derived from this software
 *     without specific prior written permission.
 *
 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 *  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 *  THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 *  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
 *  ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 *  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 *   LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 *  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 *  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package com.github.sviperll.meta;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Marks classes defining text format.
 * 

* Each text format should be represented as a stand-alone class. * Each class should define pecularities specific for each text format. * Such classes should all be marked with TextFormat annotation. *

* There two requirements for marked class *

    *
  • it should have no type variables *
  • it should provide method with the following signature: *
    {@code
     *     public static Appendable createEscapingAppendable(Appendable appendable)
     * }
    *
* * An implementation of createEscapingAppendable method should decorate given appendable argument * to create new appendable that will escape any special characters, specific to given format. *

* Decorated appendable should never buffer any data. * Escaped text should be written to original appendable immediately. *

* For example, HTML implementation should escape '&', '<' and '>' characters. *

*

{@code
 *     Appendable htmlAppendable = Html.createEscapingAppendable(System.out);
 *     htmlAppendable.append(" if a < b & b < c then a < c ");
 * }
*

* The result when running code above should be *

*

{@code
 *  if a < b & b < c then a < c
 * }
* * @author Victor Nazarov */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) @Documented public @interface TextFormat { String createEscapingAppendableMethodName() default "createEscapingAppendable"; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy