/**
* (The MIT License)
*
* Copyright (c) 2008 - 2011:
*
* * {Aaron Patterson}[http://tenderlovemaking.com]
* * {Mike Dalessio}[http://mike.daless.io]
* * {Charles Nutter}[http://blog.headius.com]
* * {Sergio Arbeo}[http://www.serabe.com]
* * {Patrick Mahoney}[http://polycrystal.org]
* * {Yoko Harada}[http://yokolet.blogspot.com]
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* 'Software'), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package nokogiri;
import static nokogiri.internals.NokogiriHelpers.getNokogiriClass;
import org.jruby.Ruby;
import org.jruby.RubyArray;
import org.jruby.RubyClass;
import org.jruby.anno.JRubyClass;
import org.jruby.anno.JRubyMethod;
import org.jruby.runtime.ThreadContext;
import org.jruby.runtime.builtin.IRubyObject;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
/**
* DTD attribute declaration.
*
* @author Patrick Mahoney <pat@polycrystal.org>
*/
@JRubyClass(name="Nokogiri::XML::AttributeDecl", parent="Nokogiri::XML::Node")
public class XmlAttributeDecl extends XmlNode {
public XmlAttributeDecl(Ruby ruby, RubyClass klass) {
super(ruby, klass);
throw ruby.newRuntimeError("node required");
}
/**
* Initialize based on an attributeDecl node from a NekoDTD parsed
* DTD.
*
* Internally, XmlAttributeDecl combines these into a single node.
*/
public XmlAttributeDecl(Ruby ruby, RubyClass klass, Node attrDeclNode) {
super(ruby, klass, attrDeclNode);
}
public static IRubyObject create(ThreadContext context, Node attrDeclNode) {
XmlAttributeDecl self =
new XmlAttributeDecl(context.getRuntime(),
getNokogiriClass(context.getRuntime(), "Nokogiri::XML::AttributeDecl"),
attrDeclNode);
return self;
}
@Override
@JRubyMethod
public IRubyObject node_name(ThreadContext context) {
return attribute_name(context);
}
@Override
@JRubyMethod(name = "node_name=")
public IRubyObject node_name_set(ThreadContext context, IRubyObject name) {
throw context.getRuntime()
.newRuntimeError("cannot change name of DTD decl");
}
public IRubyObject element_name(ThreadContext context) {
return getAttribute(context, "ename");
}
public IRubyObject attribute_name(ThreadContext context) {
return getAttribute(context, "aname");
}
@JRubyMethod
public IRubyObject attribute_type(ThreadContext context) {
return getAttribute(context, "atype");
}
@JRubyMethod(name="default")
public IRubyObject default_value(ThreadContext context) {
return getAttribute(context, "default");
}
/**
* FIXME: will enumerations all be of the simple (val1|val2|val3)
* type string?
*/
@JRubyMethod
public IRubyObject enumeration(ThreadContext context) {
RubyArray enumVals = RubyArray.newArray(context.getRuntime());
String atype = ((Element)node).getAttribute("atype");
if (atype != null && atype.length() != 0 && atype.charAt(0) == '(') {
// removed enclosing parens
String valueStr = atype.substring(1, atype.length() - 1);
String[] values = valueStr.split("\\|");
for (int i = 0; i < values.length; i++) {
enumVals.append(context.getRuntime().newString(values[i]));
}
}
return enumVals;
}
}