/*
* TemplateToken.java
* Copyright 2006 (C) Aaron Divinsky <boomer70@yahoo.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Created on March 3, 2006
*
* Current Ver: $Revision$
*/
package plugin.lsttokens.kit;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;
import pcgen.cdom.base.Constants;
import pcgen.cdom.reference.CDOMSingleRef;
import pcgen.core.PCTemplate;
import pcgen.core.kit.KitTemplate;
import pcgen.rules.context.LoadContext;
import pcgen.rules.persistence.token.AbstractTokenWithSeparator;
import pcgen.rules.persistence.token.CDOMPrimaryToken;
import pcgen.rules.persistence.token.ParseResult;
/**
* This class parses a TEMPLATE line from a Kit file. It handles the TEMPLATE
* tag as well as all common tags.
* <p>
* <strong>Tag Name:</strong> TEMPLATE:x|x <br>
* <strong>Variables Used (x):</strong> Text (Name of template)<br>
* <strong>What it does:</strong><br>
* This is a | (pipe) delimited list of templates that are granted
* by the feat.<br>
* <strong>Example:</strong><br>
* {@code TEMPLATE:Celestial}<br>
* Adds the "Celestial" template to the character.<br>
* </p>
*/
public class TemplateToken extends AbstractTokenWithSeparator<KitTemplate>
implements CDOMPrimaryToken<KitTemplate>
{
private static final Class<PCTemplate> TEMPLATE_CLASS = PCTemplate.class;
/**
* Gets the name of the tag this class will parse.
*
* @return Name of the tag this class handles
*/
@Override
public String getTokenName()
{
return "TEMPLATE";
}
@Override
public Class<KitTemplate> getTokenClass()
{
return KitTemplate.class;
}
@Override
protected char separator()
{
return '|';
}
@Override
protected ParseResult parseTokenWithSeparator(LoadContext context,
KitTemplate kitTemplate, String value)
{
StringTokenizer tok = new StringTokenizer(value, Constants.PIPE);
while (tok.hasMoreTokens())
{
String tokText = tok.nextToken();
int openLoc = tokText.indexOf('[');
String name;
List<CDOMSingleRef<PCTemplate>> subList;
if (openLoc == -1)
{
name = tokText;
subList = null;
}
else
{
name = tokText.substring(0, openLoc);
subList = new ArrayList<>();
String rest = tokText.substring(openLoc + 1);
StringTokenizer subTok = new StringTokenizer(rest, "[]");
while (subTok.hasMoreTokens())
{
String subStr = subTok.nextToken();
if (subStr.startsWith("TEMPLATE:"))
{
String ownedTemplateName = subStr.substring(9);
CDOMSingleRef<PCTemplate> ref =
context.getReferenceContext().getCDOMReference(
TEMPLATE_CLASS, ownedTemplateName);
subList.add(ref);
}
else
{
return new ParseResult.Fail("Did not understand "
+ getTokenName() + " option: " + subStr
+ " in line: " + value, context);
}
}
}
CDOMSingleRef<PCTemplate> ref =
context.getReferenceContext().getCDOMReference(TEMPLATE_CLASS, name);
kitTemplate.addTemplate(ref, subList);
}
return ParseResult.SUCCESS;
}
@Override
public String[] unparse(LoadContext context, KitTemplate kitTemplate)
{
return kitTemplate.isEmpty() ? null : new String[] { kitTemplate
.toString() };
}
}