/*******************************************************************************
* Copyright (c) 2000, 2008 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.che.ide.ext.java.jdt.templates.api;
import org.eclipse.che.ide.runtime.Assert;
/**
* A template buffer is a container for a string and variables.
* <p>
* Clients may instantiate this class.
* </p>
*
* @since 3.0
*/
public final class TemplateBuffer {
/** The string of the template buffer */
private String fString;
/** The variable positions of the template buffer */
private TemplateVariable[] fVariables;
/**
* Creates a template buffer.
*
* @param string
* the string
* @param variables
* the variable positions
*/
public TemplateBuffer(String string, TemplateVariable[] variables) {
setContent(string, variables);
}
/**
* Sets the content of the template buffer.
*
* @param string
* the string
* @param variables
* the variable positions
*/
public final void setContent(String string, TemplateVariable[] variables) {
Assert.isNotNull(string);
Assert.isNotNull(variables);
// XXX: assert non-overlapping variable properties
fString = string;
fVariables = copy(variables);
}
/**
* Returns a copy of the given array.
*
* @param array
* the array to be copied
* @return a copy of the given array or <code>null</code> when <code>array</code> is <code>null</code>
* @since 3.1
*/
private static TemplateVariable[] copy(TemplateVariable[] array) {
if (array != null) {
TemplateVariable[] copy = new TemplateVariable[array.length];
System.arraycopy(array, 0, copy, 0, array.length);
return copy;
}
return null;
}
/**
* Returns the string of the template buffer.
*
* @return the string representation of the template buffer
*/
public final String getString() {
return fString;
}
/**
* Returns the variable positions of the template buffer. The returned array is owned by this variable and must not be
* modified.
*
* @return the variable positions of the template buffer
*/
public final TemplateVariable[] getVariables() {
return fVariables;
}
}