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

com.helger.xml.serialize.write.XMLCharHelper Maven / Gradle / Ivy

There is a newer version: 11.1.8
Show newest version
/*
 * Copyright (C) 2014-2024 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * 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.helger.xml.serialize.write;

import java.util.BitSet;

import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.helger.commons.annotation.PresentForCodeCoverage;
import com.helger.commons.annotation.ReturnsMutableCopy;
import com.helger.commons.collection.impl.CommonsLinkedHashSet;
import com.helger.commons.collection.impl.ICommonsOrderedSet;

/**
 * This class contains XML utility methods for character handling.
 *
 * @author Philip Helger
 */
@Immutable
public final class XMLCharHelper
{
  // This is: Character.MAX_VALUE - Character.MIN_VALUE + 1
  private static final int BIT_SET_LENGTH = 0x10000;

  /**
   * This class is responsible for initializing the XML 1.0 character sets.
   *
   * @author Philip Helger
   */
  private static final class XML10
  {
    /**
     * This construct ensures, that this character set is only initialized when
     * accessed
     *
     * @author Philip Helger
     */
    private static final class Singleton
    {
      static final XML10 XML10_INSTANCE = new XML10 ();
    }

    private static final Logger LOGGER = LoggerFactory.getLogger (XMLCharHelper.XML10.class);

    private final BitSet INVALID_NAME_START_CHAR_XML10 = new BitSet (BIT_SET_LENGTH);
    private final BitSet INVALID_NAME_CHAR_XML10 = new BitSet (BIT_SET_LENGTH);
    /** This is used for XML 1.0 text, CDATA and attribute value */
    private final BitSet INVALID_VALUE_CHAR_XML10 = new BitSet (BIT_SET_LENGTH);

    private XML10 ()
    {
      if (LOGGER.isDebugEnabled ())
        LOGGER.debug ("Initializing XML 1.0 character table");
      for (int c = Character.MIN_VALUE; c <= Character.MAX_VALUE; ++c)
      {
        INVALID_NAME_START_CHAR_XML10.set (c,
                                           (c >= 0x0 && c <= 0x40) ||
                                              (c >= 0x5b && c <= 0x5e) ||
                                              (c == 0x60) ||
                                              (c >= 0x7b && c <= 0xbf) ||
                                              (c == 0xd7) ||
                                              (c == 0xf7) ||
                                              (c >= 0x132 && c <= 0x133) ||
                                              (c >= 0x13f && c <= 0x140) ||
                                              (c == 0x149) ||
                                              (c == 0x17f) ||
                                              (c >= 0x1c4 && c <= 0x1cc) ||
                                              (c >= 0x1f1 && c <= 0x1f3) ||
                                              (c >= 0x1f6 && c <= 0x1f9) ||
                                              (c >= 0x218 && c <= 0x24f) ||
                                              (c >= 0x2a9 && c <= 0x2ba) ||
                                              (c >= 0x2c2 && c <= 0x385) ||
                                              (c == 0x387) ||
                                              (c == 0x38b) ||
                                              (c == 0x38d) ||
                                              (c == 0x3a2) ||
                                              (c == 0x3cf) ||
                                              (c >= 0x3d7 && c <= 0x3d9) ||
                                              (c == 0x3db) ||
                                              (c == 0x3dd) ||
                                              (c == 0x3df) ||
                                              (c == 0x3e1) ||
                                              (c >= 0x3f4 && c <= 0x400) ||
                                              (c == 0x40d) ||
                                              (c == 0x450) ||
                                              (c == 0x45d) ||
                                              (c >= 0x482 && c <= 0x48f) ||
                                              (c >= 0x4c5 && c <= 0x4c6) ||
                                              (c >= 0x4c9 && c <= 0x4ca) ||
                                              (c >= 0x4cd && c <= 0x4cf) ||
                                              (c >= 0x4ec && c <= 0x4ed) ||
                                              (c >= 0x4f6 && c <= 0x4f7) ||
                                              (c >= 0x4fa && c <= 0x530) ||
                                              (c >= 0x557 && c <= 0x558) ||
                                              (c >= 0x55a && c <= 0x560) ||
                                              (c >= 0x587 && c <= 0x5cf) ||
                                              (c >= 0x5eb && c <= 0x5ef) ||
                                              (c >= 0x5f3 && c <= 0x620) ||
                                              (c >= 0x63b && c <= 0x640) ||
                                              (c >= 0x64b && c <= 0x670) ||
                                              (c >= 0x6b8 && c <= 0x6b9) ||
                                              (c == 0x6bf) ||
                                              (c == 0x6cf) ||
                                              (c == 0x6d4) ||
                                              (c >= 0x6d6 && c <= 0x6e4) ||
                                              (c >= 0x6e7 && c <= 0x904) ||
                                              (c >= 0x93a && c <= 0x93c) ||
                                              (c >= 0x93e && c <= 0x957) ||
                                              (c >= 0x962 && c <= 0x984) ||
                                              (c >= 0x98d && c <= 0x98e) ||
                                              (c >= 0x991 && c <= 0x992) ||
                                              (c == 0x9a9) ||
                                              (c == 0x9b1) ||
                                              (c >= 0x9b3 && c <= 0x9b5) ||
                                              (c >= 0x9ba && c <= 0x9db) ||
                                              (c == 0x9de) ||
                                              (c >= 0x9e2 && c <= 0x9ef) ||
                                              (c >= 0x9f2 && c <= 0xa04) ||
                                              (c >= 0xa0b && c <= 0xa0e) ||
                                              (c >= 0xa11 && c <= 0xa12) ||
                                              (c == 0xa29) ||
                                              (c == 0xa31) ||
                                              (c == 0xa34) ||
                                              (c == 0xa37) ||
                                              (c >= 0xa3a && c <= 0xa58) ||
                                              (c == 0xa5d) ||
                                              (c >= 0xa5f && c <= 0xa71) ||
                                              (c >= 0xa75 && c <= 0xa84) ||
                                              (c == 0xa8c) ||
                                              (c == 0xa8e) ||
                                              (c == 0xa92) ||
                                              (c == 0xaa9) ||
                                              (c == 0xab1) ||
                                              (c == 0xab4) ||
                                              (c >= 0xaba && c <= 0xabc) ||
                                              (c >= 0xabe && c <= 0xadf) ||
                                              (c >= 0xae1 && c <= 0xb04) ||
                                              (c >= 0xb0d && c <= 0xb0e) ||
                                              (c >= 0xb11 && c <= 0xb12) ||
                                              (c == 0xb29) ||
                                              (c == 0xb31) ||
                                              (c >= 0xb34 && c <= 0xb35) ||
                                              (c >= 0xb3a && c <= 0xb3c) ||
                                              (c >= 0xb3e && c <= 0xb5b) ||
                                              (c == 0xb5e) ||
                                              (c >= 0xb62 && c <= 0xb84) ||
                                              (c >= 0xb8b && c <= 0xb8d) ||
                                              (c == 0xb91) ||
                                              (c >= 0xb96 && c <= 0xb98) ||
                                              (c == 0xb9b) ||
                                              (c == 0xb9d) ||
                                              (c >= 0xba0 && c <= 0xba2) ||
                                              (c >= 0xba5 && c <= 0xba7) ||
                                              (c >= 0xbab && c <= 0xbad) ||
                                              (c == 0xbb6) ||
                                              (c >= 0xbba && c <= 0xc04) ||
                                              (c == 0xc0d) ||
                                              (c == 0xc11) ||
                                              (c == 0xc29) ||
                                              (c == 0xc34) ||
                                              (c >= 0xc3a && c <= 0xc5f) ||
                                              (c >= 0xc62 && c <= 0xc84) ||
                                              (c == 0xc8d) ||
                                              (c == 0xc91) ||
                                              (c == 0xca9) ||
                                              (c == 0xcb4) ||
                                              (c >= 0xcba && c <= 0xcdd) ||
                                              (c == 0xcdf) ||
                                              (c >= 0xce2 && c <= 0xd04) ||
                                              (c == 0xd0d) ||
                                              (c == 0xd11) ||
                                              (c == 0xd29) ||
                                              (c >= 0xd3a && c <= 0xd5f) ||
                                              (c >= 0xd62 && c <= 0xe00) ||
                                              (c == 0xe2f) ||
                                              (c == 0xe31) ||
                                              (c >= 0xe34 && c <= 0xe3f) ||
                                              (c >= 0xe46 && c <= 0xe80) ||
                                              (c == 0xe83) ||
                                              (c >= 0xe85 && c <= 0xe86) ||
                                              (c == 0xe89) ||
                                              (c >= 0xe8b && c <= 0xe8c) ||
                                              (c >= 0xe8e && c <= 0xe93) ||
                                              (c == 0xe98) ||
                                              (c == 0xea0) ||
                                              (c == 0xea4) ||
                                              (c == 0xea6) ||
                                              (c >= 0xea8 && c <= 0xea9) ||
                                              (c == 0xeac) ||
                                              (c == 0xeaf) ||
                                              (c == 0xeb1) ||
                                              (c >= 0xeb4 && c <= 0xebc) ||
                                              (c >= 0xebe && c <= 0xebf) ||
                                              (c >= 0xec5 && c <= 0xf3f) ||
                                              (c == 0xf48) ||
                                              (c >= 0xf6a && c <= 0x109f) ||
                                              (c >= 0x10c6 && c <= 0x10cf) ||
                                              (c >= 0x10f7 && c <= 0x10ff) ||
                                              (c == 0x1101) ||
                                              (c == 0x1104) ||
                                              (c == 0x1108) ||
                                              (c == 0x110a) ||
                                              (c == 0x110d) ||
                                              (c >= 0x1113 && c <= 0x113b) ||
                                              (c == 0x113d) ||
                                              (c == 0x113f) ||
                                              (c >= 0x1141 && c <= 0x114b) ||
                                              (c == 0x114d) ||
                                              (c == 0x114f) ||
                                              (c >= 0x1151 && c <= 0x1153) ||
                                              (c >= 0x1156 && c <= 0x1158) ||
                                              (c >= 0x115a && c <= 0x115e) ||
                                              (c == 0x1162) ||
                                              (c == 0x1164) ||
                                              (c == 0x1166) ||
                                              (c == 0x1168) ||
                                              (c >= 0x116a && c <= 0x116c) ||
                                              (c >= 0x116f && c <= 0x1171) ||
                                              (c == 0x1174) ||
                                              (c >= 0x1176 && c <= 0x119d) ||
                                              (c >= 0x119f && c <= 0x11a7) ||
                                              (c >= 0x11a9 && c <= 0x11aa) ||
                                              (c >= 0x11ac && c <= 0x11ad) ||
                                              (c >= 0x11b0 && c <= 0x11b6) ||
                                              (c == 0x11b9) ||
                                              (c == 0x11bb) ||
                                              (c >= 0x11c3 && c <= 0x11ea) ||
                                              (c >= 0x11ec && c <= 0x11ef) ||
                                              (c >= 0x11f1 && c <= 0x11f8) ||
                                              (c >= 0x11fa && c <= 0x1dff) ||
                                              (c >= 0x1e9c && c <= 0x1e9f) ||
                                              (c >= 0x1efa && c <= 0x1eff) ||
                                              (c >= 0x1f16 && c <= 0x1f17) ||
                                              (c >= 0x1f1e && c <= 0x1f1f) ||
                                              (c >= 0x1f46 && c <= 0x1f47) ||
                                              (c >= 0x1f4e && c <= 0x1f4f) ||
                                              (c == 0x1f58) ||
                                              (c == 0x1f5a) ||
                                              (c == 0x1f5c) ||
                                              (c == 0x1f5e) ||
                                              (c >= 0x1f7e && c <= 0x1f7f) ||
                                              (c == 0x1fb5) ||
                                              (c == 0x1fbd) ||
                                              (c >= 0x1fbf && c <= 0x1fc1) ||
                                              (c == 0x1fc5) ||
                                              (c >= 0x1fcd && c <= 0x1fcf) ||
                                              (c >= 0x1fd4 && c <= 0x1fd5) ||
                                              (c >= 0x1fdc && c <= 0x1fdf) ||
                                              (c >= 0x1fed && c <= 0x1ff1) ||
                                              (c == 0x1ff5) ||
                                              (c >= 0x1ffd && c <= 0x2125) ||
                                              (c >= 0x2127 && c <= 0x2129) ||
                                              (c >= 0x212c && c <= 0x212d) ||
                                              (c >= 0x212f && c <= 0x217f) ||
                                              (c >= 0x2183 && c <= 0x3006) ||
                                              (c >= 0x3008 && c <= 0x3020) ||
                                              (c >= 0x302a && c <= 0x3040) ||
                                              (c >= 0x3095 && c <= 0x30a0) ||
                                              (c >= 0x30fb && c <= 0x3104) ||
                                              (c >= 0x312d && c <= 0x4dff) ||
                                              (c >= 0x9fa6 && c <= 0xabff) ||
                                              (c >= 0xd7a4 && c < Character.MIN_SURROGATE) ||
                                              (c > Character.MAX_SURROGATE && c <= 0xffff));
        INVALID_NAME_CHAR_XML10.set (c,
                                     (c >= 0x0 && c <= 0x2c) ||
                                        (c == 0x2f) ||
                                        (c >= 0x3a && c <= 0x40) ||
                                        (c >= 0x5b && c <= 0x5e) ||
                                        (c == 0x60) ||
                                        (c >= 0x7b && c <= 0xb6) ||
                                        (c >= 0xb8 && c <= 0xbf) ||
                                        (c == 0xd7) ||
                                        (c == 0xf7) ||
                                        (c >= 0x132 && c <= 0x133) ||
                                        (c >= 0x13f && c <= 0x140) ||
                                        (c == 0x149) ||
                                        (c == 0x17f) ||
                                        (c >= 0x1c4 && c <= 0x1cc) ||
                                        (c >= 0x1f1 && c <= 0x1f3) ||
                                        (c >= 0x1f6 && c <= 0x1f9) ||
                                        (c >= 0x218 && c <= 0x24f) ||
                                        (c >= 0x2a9 && c <= 0x2ba) ||
                                        (c >= 0x2c2 && c <= 0x2cf) ||
                                        (c >= 0x2d2 && c <= 0x2ff) ||
                                        (c >= 0x346 && c <= 0x35f) ||
                                        (c >= 0x362 && c <= 0x385) ||
                                        (c == 0x38b) ||
                                        (c == 0x38d) ||
                                        (c == 0x3a2) ||
                                        (c == 0x3cf) ||
                                        (c >= 0x3d7 && c <= 0x3d9) ||
                                        (c == 0x3db) ||
                                        (c == 0x3dd) ||
                                        (c == 0x3df) ||
                                        (c == 0x3e1) ||
                                        (c >= 0x3f4 && c <= 0x400) ||
                                        (c == 0x40d) ||
                                        (c == 0x450) ||
                                        (c == 0x45d) ||
                                        (c == 0x482) ||
                                        (c >= 0x487 && c <= 0x48f) ||
                                        (c >= 0x4c5 && c <= 0x4c6) ||
                                        (c >= 0x4c9 && c <= 0x4ca) ||
                                        (c >= 0x4cd && c <= 0x4cf) ||
                                        (c >= 0x4ec && c <= 0x4ed) ||
                                        (c >= 0x4f6 && c <= 0x4f7) ||
                                        (c >= 0x4fa && c <= 0x530) ||
                                        (c >= 0x557 && c <= 0x558) ||
                                        (c >= 0x55a && c <= 0x560) ||
                                        (c >= 0x587 && c <= 0x590) ||
                                        (c == 0x5a2) ||
                                        (c == 0x5ba) ||
                                        (c == 0x5be) ||
                                        (c == 0x5c0) ||
                                        (c == 0x5c3) ||
                                        (c >= 0x5c5 && c <= 0x5cf) ||
                                        (c >= 0x5eb && c <= 0x5ef) ||
                                        (c >= 0x5f3 && c <= 0x620) ||
                                        (c >= 0x63b && c <= 0x63f) ||
                                        (c >= 0x653 && c <= 0x65f) ||
                                        (c >= 0x66a && c <= 0x66f) ||
                                        (c >= 0x6b8 && c <= 0x6b9) ||
                                        (c == 0x6bf) ||
                                        (c == 0x6cf) ||
                                        (c == 0x6d4) ||
                                        (c == 0x6e9) ||
                                        (c >= 0x6ee && c <= 0x6ef) ||
                                        (c >= 0x6fa && c <= 0x900) ||
                                        (c == 0x904) ||
                                        (c >= 0x93a && c <= 0x93b) ||
                                        (c >= 0x94e && c <= 0x950) ||
                                        (c >= 0x955 && c <= 0x957) ||
                                        (c >= 0x964 && c <= 0x965) ||
                                        (c >= 0x970 && c <= 0x980) ||
                                        (c == 0x984) ||
                                        (c >= 0x98d && c <= 0x98e) ||
                                        (c >= 0x991 && c <= 0x992) ||
                                        (c == 0x9a9) ||
                                        (c == 0x9b1) ||
                                        (c >= 0x9b3 && c <= 0x9b5) ||
                                        (c >= 0x9ba && c <= 0x9bb) ||
                                        (c == 0x9bd) ||
                                        (c >= 0x9c5 && c <= 0x9c6) ||
                                        (c >= 0x9c9 && c <= 0x9ca) ||
                                        (c >= 0x9ce && c <= 0x9d6) ||
                                        (c >= 0x9d8 && c <= 0x9db) ||
                                        (c == 0x9de) ||
                                        (c >= 0x9e4 && c <= 0x9e5) ||
                                        (c >= 0x9f2 && c <= 0xa01) ||
                                        (c >= 0xa03 && c <= 0xa04) ||
                                        (c >= 0xa0b && c <= 0xa0e) ||
                                        (c >= 0xa11 && c <= 0xa12) ||
                                        (c == 0xa29) ||
                                        (c == 0xa31) ||
                                        (c == 0xa34) ||
                                        (c == 0xa37) ||
                                        (c >= 0xa3a && c <= 0xa3b) ||
                                        (c == 0xa3d) ||
                                        (c >= 0xa43 && c <= 0xa46) ||
                                        (c >= 0xa49 && c <= 0xa4a) ||
                                        (c >= 0xa4e && c <= 0xa58) ||
                                        (c == 0xa5d) ||
                                        (c >= 0xa5f && c <= 0xa65) ||
                                        (c >= 0xa75 && c <= 0xa80) ||
                                        (c == 0xa84) ||
                                        (c == 0xa8c) ||
                                        (c == 0xa8e) ||
                                        (c == 0xa92) ||
                                        (c == 0xaa9) ||
                                        (c == 0xab1) ||
                                        (c == 0xab4) ||
                                        (c >= 0xaba && c <= 0xabb) ||
                                        (c == 0xac6) ||
                                        (c == 0xaca) ||
                                        (c >= 0xace && c <= 0xadf) ||
                                        (c >= 0xae1 && c <= 0xae5) ||
                                        (c >= 0xaf0 && c <= 0xb00) ||
                                        (c == 0xb04) ||
                                        (c >= 0xb0d && c <= 0xb0e) ||
                                        (c >= 0xb11 && c <= 0xb12) ||
                                        (c == 0xb29) ||
                                        (c == 0xb31) ||
                                        (c >= 0xb34 && c <= 0xb35) ||
                                        (c >= 0xb3a && c <= 0xb3b) ||
                                        (c >= 0xb44 && c <= 0xb46) ||
                                        (c >= 0xb49 && c <= 0xb4a) ||
                                        (c >= 0xb4e && c <= 0xb55) ||
                                        (c >= 0xb58 && c <= 0xb5b) ||
                                        (c == 0xb5e) ||
                                        (c >= 0xb62 && c <= 0xb65) ||
                                        (c >= 0xb70 && c <= 0xb81) ||
                                        (c == 0xb84) ||
                                        (c >= 0xb8b && c <= 0xb8d) ||
                                        (c == 0xb91) ||
                                        (c >= 0xb96 && c <= 0xb98) ||
                                        (c == 0xb9b) ||
                                        (c == 0xb9d) ||
                                        (c >= 0xba0 && c <= 0xba2) ||
                                        (c >= 0xba5 && c <= 0xba7) ||
                                        (c >= 0xbab && c <= 0xbad) ||
                                        (c == 0xbb6) ||
                                        (c >= 0xbba && c <= 0xbbd) ||
                                        (c >= 0xbc3 && c <= 0xbc5) ||
                                        (c == 0xbc9) ||
                                        (c >= 0xbce && c <= 0xbd6) ||
                                        (c >= 0xbd8 && c <= 0xbe6) ||
                                        (c >= 0xbf0 && c <= 0xc00) ||
                                        (c == 0xc04) ||
                                        (c == 0xc0d) ||
                                        (c == 0xc11) ||
                                        (c == 0xc29) ||
                                        (c == 0xc34) ||
                                        (c >= 0xc3a && c <= 0xc3d) ||
                                        (c == 0xc45) ||
                                        (c == 0xc49) ||
                                        (c >= 0xc4e && c <= 0xc54) ||
                                        (c >= 0xc57 && c <= 0xc5f) ||
                                        (c >= 0xc62 && c <= 0xc65) ||
                                        (c >= 0xc70 && c <= 0xc81) ||
                                        (c == 0xc84) ||
                                        (c == 0xc8d) ||
                                        (c == 0xc91) ||
                                        (c == 0xca9) ||
                                        (c == 0xcb4) ||
                                        (c >= 0xcba && c <= 0xcbd) ||
                                        (c == 0xcc5) ||
                                        (c == 0xcc9) ||
                                        (c >= 0xcce && c <= 0xcd4) ||
                                        (c >= 0xcd7 && c <= 0xcdd) ||
                                        (c == 0xcdf) ||
                                        (c >= 0xce2 && c <= 0xce5) ||
                                        (c >= 0xcf0 && c <= 0xd01) ||
                                        (c == 0xd04) ||
                                        (c == 0xd0d) ||
                                        (c == 0xd11) ||
                                        (c == 0xd29) ||
                                        (c >= 0xd3a && c <= 0xd3d) ||
                                        (c >= 0xd44 && c <= 0xd45) ||
                                        (c == 0xd49) ||
                                        (c >= 0xd4e && c <= 0xd56) ||
                                        (c >= 0xd58 && c <= 0xd5f) ||
                                        (c >= 0xd62 && c <= 0xd65) ||
                                        (c >= 0xd70 && c <= 0xe00) ||
                                        (c == 0xe2f) ||
                                        (c >= 0xe3b && c <= 0xe3f) ||
                                        (c == 0xe4f) ||
                                        (c >= 0xe5a && c <= 0xe80) ||
                                        (c == 0xe83) ||
                                        (c >= 0xe85 && c <= 0xe86) ||
                                        (c == 0xe89) ||
                                        (c >= 0xe8b && c <= 0xe8c) ||
                                        (c >= 0xe8e && c <= 0xe93) ||
                                        (c == 0xe98) ||
                                        (c == 0xea0) ||
                                        (c == 0xea4) ||
                                        (c == 0xea6) ||
                                        (c >= 0xea8 && c <= 0xea9) ||
                                        (c == 0xeac) ||
                                        (c == 0xeaf) ||
                                        (c == 0xeba) ||
                                        (c >= 0xebe && c <= 0xebf) ||
                                        (c == 0xec5) ||
                                        (c == 0xec7) ||
                                        (c >= 0xece && c <= 0xecf) ||
                                        (c >= 0xeda && c <= 0xf17) ||
                                        (c >= 0xf1a && c <= 0xf1f) ||
                                        (c >= 0xf2a && c <= 0xf34) ||
                                        (c == 0xf36) ||
                                        (c == 0xf38) ||
                                        (c >= 0xf3a && c <= 0xf3d) ||
                                        (c == 0xf48) ||
                                        (c >= 0xf6a && c <= 0xf70) ||
                                        (c == 0xf85) ||
                                        (c >= 0xf8c && c <= 0xf8f) ||
                                        (c == 0xf96) ||
                                        (c == 0xf98) ||
                                        (c >= 0xfae && c <= 0xfb0) ||
                                        (c == 0xfb8) ||
                                        (c >= 0xfba && c <= 0x109f) ||
                                        (c >= 0x10c6 && c <= 0x10cf) ||
                                        (c >= 0x10f7 && c <= 0x10ff) ||
                                        (c == 0x1101) ||
                                        (c == 0x1104) ||
                                        (c == 0x1108) ||
                                        (c == 0x110a) ||
                                        (c == 0x110d) ||
                                        (c >= 0x1113 && c <= 0x113b) ||
                                        (c == 0x113d) ||
                                        (c == 0x113f) ||
                                        (c >= 0x1141 && c <= 0x114b) ||
                                        (c == 0x114d) ||
                                        (c == 0x114f) ||
                                        (c >= 0x1151 && c <= 0x1153) ||
                                        (c >= 0x1156 && c <= 0x1158) ||
                                        (c >= 0x115a && c <= 0x115e) ||
                                        (c == 0x1162) ||
                                        (c == 0x1164) ||
                                        (c == 0x1166) ||
                                        (c == 0x1168) ||
                                        (c >= 0x116a && c <= 0x116c) ||
                                        (c >= 0x116f && c <= 0x1171) ||
                                        (c == 0x1174) ||
                                        (c >= 0x1176 && c <= 0x119d) ||
                                        (c >= 0x119f && c <= 0x11a7) ||
                                        (c >= 0x11a9 && c <= 0x11aa) ||
                                        (c >= 0x11ac && c <= 0x11ad) ||
                                        (c >= 0x11b0 && c <= 0x11b6) ||
                                        (c == 0x11b9) ||
                                        (c == 0x11bb) ||
                                        (c >= 0x11c3 && c <= 0x11ea) ||
                                        (c >= 0x11ec && c <= 0x11ef) ||
                                        (c >= 0x11f1 && c <= 0x11f8) ||
                                        (c >= 0x11fa && c <= 0x1dff) ||
                                        (c >= 0x1e9c && c <= 0x1e9f) ||
                                        (c >= 0x1efa && c <= 0x1eff) ||
                                        (c >= 0x1f16 && c <= 0x1f17) ||
                                        (c >= 0x1f1e && c <= 0x1f1f) ||
                                        (c >= 0x1f46 && c <= 0x1f47) ||
                                        (c >= 0x1f4e && c <= 0x1f4f) ||
                                        (c == 0x1f58) ||
                                        (c == 0x1f5a) ||
                                        (c == 0x1f5c) ||
                                        (c == 0x1f5e) ||
                                        (c >= 0x1f7e && c <= 0x1f7f) ||
                                        (c == 0x1fb5) ||
                                        (c == 0x1fbd) ||
                                        (c >= 0x1fbf && c <= 0x1fc1) ||
                                        (c == 0x1fc5) ||
                                        (c >= 0x1fcd && c <= 0x1fcf) ||
                                        (c >= 0x1fd4 && c <= 0x1fd5) ||
                                        (c >= 0x1fdc && c <= 0x1fdf) ||
                                        (c >= 0x1fed && c <= 0x1ff1) ||
                                        (c == 0x1ff5) ||
                                        (c >= 0x1ffd && c <= 0x20cf) ||
                                        (c >= 0x20dd && c <= 0x20e0) ||
                                        (c >= 0x20e2 && c <= 0x2125) ||
                                        (c >= 0x2127 && c <= 0x2129) ||
                                        (c >= 0x212c && c <= 0x212d) ||
                                        (c >= 0x212f && c <= 0x217f) ||
                                        (c >= 0x2183 && c <= 0x3004) ||
                                        (c == 0x3006) ||
                                        (c >= 0x3008 && c <= 0x3020) ||
                                        (c == 0x3030) ||
                                        (c >= 0x3036 && c <= 0x3040) ||
                                        (c >= 0x3095 && c <= 0x3098) ||
                                        (c >= 0x309b && c <= 0x309c) ||
                                        (c >= 0x309f && c <= 0x30a0) ||
                                        (c == 0x30fb) ||
                                        (c >= 0x30ff && c <= 0x3104) ||
                                        (c >= 0x312d && c <= 0x4dff) ||
                                        (c >= 0x9fa6 && c <= 0xabff) ||
                                        (c >= 0xd7a4 && c < Character.MIN_SURROGATE) ||
                                        (c > Character.MAX_SURROGATE && c <= 0xffff));
        INVALID_VALUE_CHAR_XML10.set (c,
                                      (c >= 0x0 && c <= 0x8) ||
                                         (c >= 0xb && c <= 0xc) ||
                                         (c >= 0xe && c <= 0x1f) ||
                                         // Surrogate chars
                                         // (c >= 0xd800 && c <= 0xdfff) ||
                                         (c >= 0xfffe && c <= 0xffff));
      }
    }
  }

  /**
   * This class is responsible for initializing the XML 1.1 character sets.
   *
   * @author Philip Helger
   */
  private static final class XML11
  {
    /**
     * This construct ensures, that this character set is only initialized when
     * accessed
     *
     * @author Philip Helger
     */
    private static final class Singleton
    {
      static final XML11 XML11_INSTANCE = new XML11 ();
    }

    private static final Logger LOGGER = LoggerFactory.getLogger (XMLCharHelper.XML11.class);

    private final BitSet INVALID_NAME_START_CHAR_XML11 = new BitSet (BIT_SET_LENGTH);
    private final BitSet INVALID_NAME_CHAR_XML11 = new BitSet (BIT_SET_LENGTH);
    /** This is used for XML 1.1 text values */
    private final BitSet INVALID_TEXT_VALUE_CHAR_XML11 = new BitSet (BIT_SET_LENGTH);
    /** This is used for XML 1.1 CDATA values */
    private final BitSet INVALID_CDATA_VALUE_CHAR_XML11 = new BitSet (BIT_SET_LENGTH);
    /** This is used for XML 1.1 CDATA and attribute values */
    private final BitSet INVALID_ATTR_VALUE_CHAR_XML11 = new BitSet (BIT_SET_LENGTH);

    private XML11 ()
    {
      if (LOGGER.isDebugEnabled ())
        LOGGER.debug ("Initializing XML 1.1 character table");
      for (int c = Character.MIN_VALUE; c <= Character.MAX_VALUE; ++c)
      {
        INVALID_NAME_START_CHAR_XML11.set (c,
                                           (c >= 0x0 && c <= 0x40) ||
                                              (c >= 0x5b && c <= 0x5e) ||
                                              (c == 0x60) ||
                                              (c >= 0x7b && c <= 0xbf) ||
                                              (c == 0xd7) ||
                                              (c == 0xf7) ||
                                              (c >= 0x300 && c <= 0x36f) ||
                                              (c == 0x37e) ||
                                              (c >= 0x2000 && c <= 0x200b) ||
                                              (c >= 0x200e && c <= 0x206f) ||
                                              (c >= 0x2190 && c <= 0x2bff) ||
                                              (c >= 0x2ff0 && c <= 0x3000) ||
                                              (c > Character.MAX_SURROGATE && c <= 0xf8ff) ||
                                              (c >= 0xfdd0 && c <= 0xfdef) ||
                                              (c >= 0xfffe && c <= 0xffff));
        INVALID_NAME_CHAR_XML11.set (c,
                                     (c >= 0x0 && c <= 0x2c) ||
                                        (c == 0x2f) ||
                                        (c >= 0x3a && c <= 0x40) ||
                                        (c >= 0x5b && c <= 0x5e) ||
                                        (c == 0x60) ||
                                        (c >= 0x7b && c <= 0xb6) ||
                                        (c >= 0xb8 && c <= 0xbf) ||
                                        (c == 0xd7) ||
                                        (c == 0xf7) ||
                                        (c == 0x37e) ||
                                        (c >= 0x2000 && c <= 0x200b) ||
                                        (c >= 0x200e && c <= 0x203e) ||
                                        (c >= 0x2041 && c <= 0x206f) ||
                                        (c >= 0x2190 && c <= 0x2bff) ||
                                        (c >= 0x2ff0 && c <= 0x3000) ||
                                        (c > Character.MAX_SURROGATE && c <= 0xf8ff) ||
                                        (c >= 0xfdd0 && c <= 0xfdef) ||
                                        (c >= 0xfffe && c <= 0xffff));
        INVALID_TEXT_VALUE_CHAR_XML11.set (c,
                                           (c == 0x0) ||
                                              (c > Character.MAX_SURROGATE && c <= 0xdfff) ||
                                              (c >= 0xfffe && c <= 0xffff));
        INVALID_CDATA_VALUE_CHAR_XML11.set (c,
                                            (c >= 0x0 && c <= 0x8) ||
                                               (c >= 0xb && c <= 0xc) ||
                                               (c >= 0xe && c <= 0x1f) ||
                                               (c >= 0x7f && c <= 0x9f) ||
                                               // Surrogate chars
                                               // (c >= 0xd800 && c <= 0xdfff)
                                               // ||
                                               (c >= 0xfffe && c <= 0xffff));
        INVALID_ATTR_VALUE_CHAR_XML11.set (c,
                                           (c == 0x0) ||
                                              (c >= 0x7f && c <= 0x84) ||
                                              (c >= 0x86 && c <= 0x9f) ||
                                              // Surrogate chars
                                              // (c >= 0xd800 && c <= 0xdfff) ||
                                              (c >= 0xfffe && c <= 0xffff));
      }
    }
  }

  /**
   * This class is responsible for initializing the HTML character sets.
   *
   * @author Philip Helger
   */
  private static final class HTML
  {
    /**
     * This construct ensures, that this character set is only initialized when
     * accessed
     *
     * @author Philip Helger
     */
    private static final class Singleton
    {
      static final HTML HTML_INSTANCE = new HTML ();
    }

    private static final Logger LOGGER = LoggerFactory.getLogger (XMLCharHelper.HTML.class);

    /** For all HTML values */
    private final BitSet INVALID_CHAR_HTML = new BitSet (BIT_SET_LENGTH);

    private HTML ()
    {
      if (LOGGER.isDebugEnabled ())
        LOGGER.debug ("Initializing HTML character table");
      for (int c = Character.MIN_VALUE; c <= Character.MAX_VALUE; ++c)
      {
        /**
         * Source: http://www.w3.org/TR/REC-html40/sgml/sgmldecl.html with
         * sanity handling for 0x80 - 0x9f
         */
        INVALID_CHAR_HTML.set (c,
                               (c >= 0x0 && c <= 0x8) ||
                                  (c >= 0xb && c <= 0xc) ||
                                  (c >= 0xe && c <= 0x1f) ||
                                  (c == 0x7f) ||
                                  // (c >= 0x80 && c <= 0x9f) ||
                                  // Surrogate chars
                                  // (c >= 0xd800 && c <= 0xdfff) ||
                                  (c >= 0xfffe && c <= 0xffff));
      }
    }
  }

  @PresentForCodeCoverage
  private static final XMLCharHelper INSTANCE = new XMLCharHelper ();

  private XMLCharHelper ()
  {}

  /**
   * Check if the passed character is invalid for an element or attribute name
   * on the first position
   *
   * @param eXMLVersion
   *        XML version to be used. May not be null.
   * @param c
   *        char to check
   * @return true if the char is invalid
   */
  public static boolean isInvalidXMLNameStartChar (@Nonnull final EXMLSerializeVersion eXMLVersion, final int c)
  {
    switch (eXMLVersion)
    {
      case XML_10:
        return XML10.Singleton.XML10_INSTANCE.INVALID_NAME_START_CHAR_XML10.get (c);
      case XML_11:
        return XML11.Singleton.XML11_INSTANCE.INVALID_NAME_START_CHAR_XML11.get (c);
      case HTML:
        return HTML.Singleton.HTML_INSTANCE.INVALID_CHAR_HTML.get (c);
      default:
        throw new IllegalArgumentException ("Unsupported XML version " + eXMLVersion + "!");
    }
  }

  /**
   * Check if the passed character is invalid for an element or attribute name
   * after the first position
   *
   * @param eXMLVersion
   *        XML version to be used. May not be null.
   * @param c
   *        char to check
   * @return true if the char is invalid
   */
  public static boolean isInvalidXMLNameChar (@Nonnull final EXMLSerializeVersion eXMLVersion, final int c)
  {
    switch (eXMLVersion)
    {
      case XML_10:
        return XML10.Singleton.XML10_INSTANCE.INVALID_NAME_CHAR_XML10.get (c);
      case XML_11:
        return XML11.Singleton.XML11_INSTANCE.INVALID_NAME_CHAR_XML11.get (c);
      case HTML:
        return HTML.Singleton.HTML_INSTANCE.INVALID_CHAR_HTML.get (c);
      default:
        throw new IllegalArgumentException ("Unsupported XML version " + eXMLVersion + "!");
    }
  }

  public static boolean containsInvalidXMLNameChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final String s)
  {
    return s != null && s.length () > 0 && containsInvalidXMLNameChar (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  public static boolean containsInvalidXMLNameChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final char [] aChars)
  {
    return aChars != null && aChars.length > 0 && containsInvalidXMLNameChar (eXMLVersion, aChars, 0, aChars.length);
  }

  public static boolean containsInvalidXMLNameChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final char [] aChars,
                                                    @Nonnegative final int nOfs,
                                                    @Nonnegative final int nLen)
  {
    if (aChars != null && nLen > 0)
    {
      int nIndex = 0;
      for (int i = 0; i < nLen; ++i)
      {
        final char c = aChars[nOfs + i];
        final boolean bInvalid = nIndex == 0 ? isInvalidXMLNameStartChar (eXMLVersion, c)
                                             : isInvalidXMLNameChar (eXMLVersion, c);
        if (bInvalid)
          return true;
        ++nIndex;
      }
    }
    return false;
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLNameChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final String s)
  {
    return s == null || s.length () == 0 ? null : getAllInvalidXMLNameChars (eXMLVersion, s.toCharArray ());
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLNameChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final char [] aChars)
  {
    return aChars == null || aChars.length == 0 ? null
                                                : getAllInvalidXMLNameChars (eXMLVersion, aChars, 0, aChars.length);
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLNameChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final char [] aChars,
                                                                          @Nonnegative final int nOfs,
                                                                          @Nonnegative final int nLen)
  {
    if (aChars == null || nLen <= 0)
      return null;

    final ICommonsOrderedSet  ret = new CommonsLinkedHashSet <> ();
    int nIndex = 0;
    for (int i = 0; i < nLen; ++i)
    {
      final char c = aChars[nOfs + i];
      final boolean bInvalid = nIndex == 0 ? isInvalidXMLNameStartChar (eXMLVersion, c)
                                           : isInvalidXMLNameChar (eXMLVersion, c);
      if (bInvalid)
        ret.add (Character.valueOf (c));
      ++nIndex;
    }
    return ret;
  }

  /**
   * Check if the passed character is invalid for a text node.
   *
   * @param eXMLVersion
   *        XML version to be used. May not be null.
   * @param c
   *        char to check
   * @return true if the char is invalid
   */
  public static boolean isInvalidXMLTextChar (@Nonnull final EXMLSerializeVersion eXMLVersion, final int c)
  {
    switch (eXMLVersion)
    {
      case XML_10:
        return XML10.Singleton.XML10_INSTANCE.INVALID_VALUE_CHAR_XML10.get (c);
      case XML_11:
        return XML11.Singleton.XML11_INSTANCE.INVALID_TEXT_VALUE_CHAR_XML11.get (c);
      case HTML:
        return HTML.Singleton.HTML_INSTANCE.INVALID_CHAR_HTML.get (c);
      default:
        throw new IllegalArgumentException ("Unsupported XML version " + eXMLVersion + "!");
    }
  }

  public static boolean containsInvalidXMLTextChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final String s)
  {
    return s != null && s.length () > 0 && containsInvalidXMLTextChar (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  public static boolean containsInvalidXMLTextChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final char [] aChars)
  {
    return aChars != null && aChars.length > 0 && containsInvalidXMLTextChar (eXMLVersion, aChars, 0, aChars.length);
  }

  public static boolean containsInvalidXMLTextChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                    @Nullable final char [] aChars,
                                                    @Nonnegative final int nOfs,
                                                    @Nonnegative final int nLen)
  {
    if (aChars != null && nLen > 0)
      for (int i = 0; i < nLen; ++i)
      {
        final char c = aChars[nOfs + i];
        if (isInvalidXMLTextChar (eXMLVersion, c))
          return true;
      }
    return false;
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLTextChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final String s)
  {
    return s == null || s.length () == 0 ? null
                                         : getAllInvalidXMLTextChars (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLTextChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final char [] aChars)
  {
    return aChars == null || aChars.length == 0 ? null
                                                : getAllInvalidXMLTextChars (eXMLVersion, aChars, 0, aChars.length);
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLTextChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                          @Nullable final char [] aChars,
                                                                          @Nonnegative final int nOfs,
                                                                          @Nonnegative final int nLen)
  {
    if (aChars == null || nLen <= 0)
      return null;

    final ICommonsOrderedSet  ret = new CommonsLinkedHashSet <> ();
    for (int i = 0; i < nLen; ++i)
    {
      final char c = aChars[nOfs + i];
      if (isInvalidXMLTextChar (eXMLVersion, c))
        ret.add (Character.valueOf (c));
    }
    return ret;
  }

  /**
   * Check if the passed character is invalid for a CDATA node.
   *
   * @param eXMLVersion
   *        XML version to be used. May not be null.
   * @param c
   *        char to check
   * @return true if the char is invalid
   */
  public static boolean isInvalidXMLCDATAChar (@Nonnull final EXMLSerializeVersion eXMLVersion, final int c)
  {
    switch (eXMLVersion)
    {
      case XML_10:
        return XML10.Singleton.XML10_INSTANCE.INVALID_VALUE_CHAR_XML10.get (c);
      case XML_11:
        return XML11.Singleton.XML11_INSTANCE.INVALID_CDATA_VALUE_CHAR_XML11.get (c);
      case HTML:
        return HTML.Singleton.HTML_INSTANCE.INVALID_CHAR_HTML.get (c);
      default:
        throw new IllegalArgumentException ("Unsupported XML version " + eXMLVersion + "!");
    }
  }

  public static boolean containsInvalidXMLCDATAChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                     @Nullable final String s)
  {
    return s != null && s.length () > 0 && containsInvalidXMLCDATAChar (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  public static boolean containsInvalidXMLCDATAChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                     @Nullable final char [] aChars)
  {
    return aChars != null && aChars.length > 0 && containsInvalidXMLCDATAChar (eXMLVersion, aChars, 0, aChars.length);
  }

  public static boolean containsInvalidXMLCDATAChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                     @Nullable final char [] aChars,
                                                     @Nonnegative final int nOfs,
                                                     @Nonnegative final int nLen)
  {
    if (aChars != null && nLen > 0)
      for (int i = 0; i < nLen; ++i)
      {
        final char c = aChars[nOfs + i];
        if (isInvalidXMLCDATAChar (eXMLVersion, c))
          return true;
      }
    return false;
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLCDATAChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                           @Nullable final String s)
  {
    return s == null || s.length () == 0 ? null
                                         : getAllInvalidXMLCDATAChars (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLCDATAChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                           @Nullable final char [] aChars)
  {
    return aChars == null || aChars.length == 0 ? null
                                                : getAllInvalidXMLCDATAChars (eXMLVersion, aChars, 0, aChars.length);
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLCDATAChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                           @Nullable final char [] aChars,
                                                                           @Nonnegative final int nOfs,
                                                                           @Nonnegative final int nLen)
  {
    if (aChars == null || nLen <= 0)
      return null;

    final ICommonsOrderedSet  ret = new CommonsLinkedHashSet <> ();
    for (int i = 0; i < nLen; ++i)
    {
      final char c = aChars[nOfs + i];
      if (isInvalidXMLCDATAChar (eXMLVersion, c))
        ret.add (Character.valueOf (c));
    }
    return ret;
  }

  /**
   * Check if the passed character is invalid for a attribute value node.
   *
   * @param eXMLVersion
   *        XML version to be used. May not be null.
   * @param c
   *        char to check
   * @return true if the char is invalid
   */
  public static boolean isInvalidXMLAttributeValueChar (@Nonnull final EXMLSerializeVersion eXMLVersion, final int c)
  {
    switch (eXMLVersion)
    {
      case XML_10:
        return XML10.Singleton.XML10_INSTANCE.INVALID_VALUE_CHAR_XML10.get (c);
      case XML_11:
        return XML11.Singleton.XML11_INSTANCE.INVALID_ATTR_VALUE_CHAR_XML11.get (c);
      case HTML:
        return HTML.Singleton.HTML_INSTANCE.INVALID_CHAR_HTML.get (c);
      default:
        throw new IllegalArgumentException ("Unsupported XML version " + eXMLVersion + "!");
    }
  }

  public static boolean containsInvalidXMLAttributeValueChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                              @Nullable final String s)
  {
    return s != null &&
           s.length () > 0 &&
           containsInvalidXMLAttributeValueChar (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  public static boolean containsInvalidXMLAttributeValueChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                              @Nullable final char [] aChars)
  {
    return aChars != null &&
           aChars.length > 0 &&
           containsInvalidXMLAttributeValueChar (eXMLVersion, aChars, 0, aChars.length);
  }

  public static boolean containsInvalidXMLAttributeValueChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                              @Nullable final char [] aChars,
                                                              @Nonnegative final int nOfs,
                                                              @Nonnegative final int nLen)
  {
    if (aChars != null && nLen > 0)
      for (int i = 0; i < nLen; ++i)
      {
        final char c = aChars[nOfs + i];
        if (isInvalidXMLAttributeValueChar (eXMLVersion, c))
          return true;
      }
    return false;
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLAttributeValueChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                                    @Nullable final String s)
  {
    return s == null ||
           s.length () == 0 ? null
                            : getAllInvalidXMLAttributeValueChars (eXMLVersion, s.toCharArray (), 0, s.length ());
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLAttributeValueChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                                    @Nullable final char [] aChars)
  {
    return aChars == null ||
           aChars.length == 0 ? null : getAllInvalidXMLAttributeValueChars (eXMLVersion, aChars, 0, aChars.length);
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLAttributeValueChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                                    @Nullable final char [] aChars,
                                                                                    @Nonnegative final int nOfs,
                                                                                    @Nonnegative final int nLen)
  {
    if (aChars == null || nLen <= 0)
      return null;

    final ICommonsOrderedSet  ret = new CommonsLinkedHashSet <> ();
    for (int i = 0; i < nLen; ++i)
    {
      final char c = aChars[nOfs + i];
      if (isInvalidXMLAttributeValueChar (eXMLVersion, c))
        ret.add (Character.valueOf (c));
    }
    return ret;
  }

  public static boolean containsInvalidXMLChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                @Nonnull final EXMLCharMode eXMLCharMode,
                                                @Nullable final String s)
  {
    return s != null &&
           s.length () > 0 &&
           containsInvalidXMLChar (eXMLVersion, eXMLCharMode, s.toCharArray (), 0, s.length ());
  }

  public static boolean containsInvalidXMLChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                @Nonnull final EXMLCharMode eXMLCharMode,
                                                @Nullable final char [] aChars)
  {
    return aChars != null &&
           aChars.length > 0 &&
           containsInvalidXMLChar (eXMLVersion, eXMLCharMode, aChars, 0, aChars.length);
  }

  public static boolean containsInvalidXMLChar (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                @Nonnull final EXMLCharMode eXMLCharMode,
                                                @Nullable final char [] aChars,
                                                @Nonnegative final int nOfs,
                                                @Nonnegative final int nLen)
  {
    switch (eXMLCharMode)
    {
      case ELEMENT_NAME:
      case ATTRIBUTE_NAME:
        return containsInvalidXMLNameChar (eXMLVersion, aChars, nOfs, nLen);
      case ATTRIBUTE_VALUE_DOUBLE_QUOTES:
      case ATTRIBUTE_VALUE_SINGLE_QUOTES:
        return containsInvalidXMLAttributeValueChar (eXMLVersion, aChars, nOfs, nLen);
      case TEXT:
        return containsInvalidXMLTextChar (eXMLVersion, aChars, nOfs, nLen);
      case CDATA:
        return containsInvalidXMLCDATAChar (eXMLVersion, aChars, nOfs, nLen);
      default:
        throw new IllegalArgumentException ("Unsupported XML character mode " + eXMLCharMode + "!");
    }
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                      @Nonnull final EXMLCharMode eXMLCharMode,
                                                                      @Nullable final String s)
  {
    return s == null ||
           s.length () == 0 ? null
                            : getAllInvalidXMLChars (eXMLVersion, eXMLCharMode, s.toCharArray (), 0, s.length ());
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                      @Nonnull final EXMLCharMode eXMLCharMode,
                                                                      @Nullable final char [] aChars)
  {
    return aChars == null ||
           aChars.length == 0 ? null : getAllInvalidXMLChars (eXMLVersion, eXMLCharMode, aChars, 0, aChars.length);
  }

  @Nullable
  @ReturnsMutableCopy
  public static ICommonsOrderedSet  getAllInvalidXMLChars (@Nonnull final EXMLSerializeVersion eXMLVersion,
                                                                      @Nonnull final EXMLCharMode eXMLCharMode,
                                                                      @Nullable final char [] aChars,
                                                                      @Nonnegative final int nOfs,
                                                                      @Nonnegative final int nLen)
  {
    switch (eXMLCharMode)
    {
      case ELEMENT_NAME:
      case ATTRIBUTE_NAME:
        return getAllInvalidXMLNameChars (eXMLVersion, aChars, nOfs, nLen);
      case ATTRIBUTE_VALUE_DOUBLE_QUOTES:
      case ATTRIBUTE_VALUE_SINGLE_QUOTES:
        return getAllInvalidXMLAttributeValueChars (eXMLVersion, aChars, nOfs, nLen);
      case TEXT:
        return getAllInvalidXMLTextChars (eXMLVersion, aChars, nOfs, nLen);
      case CDATA:
        return getAllInvalidXMLCDATAChars (eXMLVersion, aChars, nOfs, nLen);
      default:
        throw new IllegalArgumentException ("Unsupported XML character mode " + eXMLCharMode + "!");
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy