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

org.radeox.macro.Preserved Maven / Gradle / Ivy

Go to download

This project generates and creates an appropriate radeox jar for the Sakai RWiki tool. The code here was developed by the Radeox project.

There is a newer version: 23.2
Show newest version
/*
 * This file is part of "SnipSnap Radeox Rendering Engine".
 *
 * Copyright (c) 2002 Stephan J. Schmidt, Matthias L. Jugel
 * All Rights Reserved.
 *
 * Please visit http://radeox.org/ for updates and contact.
 *
 * --LICENSE NOTICE--
 * Licensed 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.
 * --LICENSE NOTICE--
 */
package org.radeox.macro;

import java.util.HashMap;
import java.util.Map;
import java.util.StringTokenizer;

import org.radeox.util.Encoder;

/**
 * A specialized macro that allows to preserve certain special characters by
 * creating character entities. The subclassing macro may decide whether to call
 * replace() before or after executing the actual macro substitution.
 * 
 * @author Matthias L. Jugel
 * @version $Id$
 */

public abstract class Preserved extends BaseMacro
{
	private Map special = new HashMap();

	private String specialString = "";

	/**
	 * Encode special character c by replacing with it's hex character entity
	 * code.
	 */
	protected void addSpecial(char c)
	{
		addSpecial("" + c, Encoder.toEntity(c));
	}

	/**
	 * Add a replacement for the special character c which may be a string
	 * 
	 * @param c
	 *        the character to replace
	 * @param replacement
	 *        the new string
	 */
	protected void addSpecial(String c, String replacement)
	{
		specialString += c;
		special.put(c, replacement);
	}

	/**
	 * Actually replace specials in source. This method can be used by
	 * subclassing macros.
	 * 
	 * @param source
	 *        String to encode
	 * @return encoded Encoded string
	 */
	protected String replace(String source)
	{
		StringBuffer tmp = new StringBuffer();
		StringTokenizer stringTokenizer = new StringTokenizer(source,
				specialString, true);
		while (stringTokenizer.hasMoreTokens())
		{
			String current = stringTokenizer.nextToken();
			if (special.containsKey(current))
			{
				current = (String) special.get(current);
			}
			tmp.append(current);
		}
		return tmp.toString();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy