/* * Copyright 2009 Mike Cumings * * 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. */ package com.kenai.jbosh; /** * Data type representing the getValue of the {@code charsets} attribute of the * {@code bosh} element. */ final class AttrCharsets extends AbstractAttr<String> { /** * Array of the accepted character sets. */ private final String[] charsets; /** * Creates a new attribute object. * * @param val attribute getValue */ private AttrCharsets(final String val) { super(val); charsets = val.split("\\ +"); } /** * Creates a new attribute instance from the provided String. * * @param str string representation of the attribute * @return attribute instance or {@code null} if provided string is * {@code null} */ static AttrCharsets createFromString(final String str) { if (str == null) { return null; } else { return new AttrCharsets(str); } } /** * Determines whether or not the specified charset is supported. * * @param name encoding name * @result {@code true} if the encoding is accepted, {@code false} * otherwise */ boolean isAccepted(final String name) { for (String str : charsets) { if (str.equalsIgnoreCase(name)) { return true; } } return false; } }