TransService.cpp
上传用户:zhuqijet
上传日期:2013-06-25
资源大小:10074k
文件大小:22k
源码类别:

词法分析

开发平台:

Visual C++

  1. /*
  2.  * The Apache Software License, Version 1.1
  3.  *
  4.  * Copyright (c) 1999-2002 The Apache Software Foundation.  All rights
  5.  * reserved.
  6.  *
  7.  * Redistribution and use in source and binary forms, with or without
  8.  * modification, are permitted provided that the following conditions
  9.  * are met:
  10.  *
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer.
  13.  *
  14.  * 2. Redistributions in binary form must reproduce the above copyright
  15.  *    notice, this list of conditions and the following disclaimer in
  16.  *    the documentation and/or other materials provided with the
  17.  *    distribution.
  18.  *
  19.  * 3. The end-user documentation included with the redistribution,
  20.  *    if any, must include the following acknowledgment:
  21.  *       "This product includes software developed by the
  22.  *        Apache Software Foundation (http://www.apache.org/)."
  23.  *    Alternately, this acknowledgment may appear in the software itself,
  24.  *    if and wherever such third-party acknowledgments normally appear.
  25.  *
  26.  * 4. The names "Xerces" and "Apache Software Foundation" must
  27.  *    not be used to endorse or promote products derived from this
  28.  *    software without prior written permission. For written
  29.  *    permission, please contact apache@apache.org.
  30.  *
  31.  * 5. Products derived from this software may not be called "Apache",
  32.  *    nor may "Apache" appear in their name, without prior written
  33.  *    permission of the Apache Software Foundation.
  34.  *
  35.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36.  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38.  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39.  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41.  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42.  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43.  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44.  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45.  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46.  * SUCH DAMAGE.
  47.  * ====================================================================
  48.  *
  49.  * This software consists of voluntary contributions made by many
  50.  * individuals on behalf of the Apache Software Foundation, and was
  51.  * originally based on software copyright (c) 1999, International
  52.  * Business Machines, Inc., http://www.ibm.com .  For more information
  53.  * on the Apache Software Foundation, please see
  54.  * <http://www.apache.org/>.
  55.  */
  56. /*
  57.  * $Id: TransService.cpp,v 1.12 2003/05/15 19:07:45 knoaman Exp $
  58.  */
  59. // ---------------------------------------------------------------------------
  60. //  Includes
  61. // ---------------------------------------------------------------------------
  62. #include <xercesc/util/Janitor.hpp>
  63. #include <xercesc/util/RefHashTableOf.hpp>
  64. #include <xercesc/util/RefVectorOf.hpp>
  65. #include <xercesc/util/XML88591Transcoder.hpp>
  66. #include <xercesc/util/XMLASCIITranscoder.hpp>
  67. #include <xercesc/util/XMLChTranscoder.hpp>
  68. #include <xercesc/util/XMLEBCDICTranscoder.hpp>
  69. #include <xercesc/util/XMLIBM1140Transcoder.hpp>
  70. #include <xercesc/util/XMLUCS4Transcoder.hpp>
  71. #include <xercesc/util/XMLUTF8Transcoder.hpp>
  72. #include <xercesc/util/XMLUTF16Transcoder.hpp>
  73. #include <xercesc/util/XMLWin1252Transcoder.hpp>
  74. #include <xercesc/util/XMLUniDefs.hpp>
  75. #include <xercesc/util/XMLUni.hpp>
  76. #include <xercesc/util/TransENameMap.hpp>
  77. #include <xercesc/util/EncodingValidator.hpp>
  78. #include <xercesc/util/XMLRegisterCleanup.hpp>
  79. #include <xercesc/util/PlatformUtils.hpp>
  80. XERCES_CPP_NAMESPACE_BEGIN
  81. // ---------------------------------------------------------------------------
  82. //  Local, static data
  83. //
  84. //  gMappings
  85. //      This is a hash table of ENameMap objects. It is created and filled
  86. //      in when the platform init calls our initTransService() method.
  87. //
  88. //  gMappingsRecognizer
  89. //      This is an array of ENameMap objects, predefined for those
  90. //      already recognized by XMLRecognizer::Encodings.
  91. //
  92. //  gStrictIANAEncoding
  93. //      A flag to control whether strict IANA encoding names checking should
  94. //      be done
  95. //
  96. // ---------------------------------------------------------------------------
  97. static RefHashTableOf<ENameMap>*    gMappings = 0;
  98. static RefVectorOf<ENameMap>*       gMappingsRecognizer = 0;
  99. static bool gStrictIANAEncoding = false;
  100. // -----------------------------------------------------------------------
  101. //  Notification that lazy data has been deleted
  102. // -----------------------------------------------------------------------
  103. static void reinitMappings() {
  104.     delete gMappings;    // The contents of the gMappings hash table are owned by
  105.     gMappings = 0;       //   the it, and so will be deleted by gMapping's destructor.
  106. }
  107. static void reinitMappingsRecognizer() {
  108.     delete gMappingsRecognizer;
  109.     gMappingsRecognizer = 0;
  110. }
  111. // ---------------------------------------------------------------------------
  112. //  XMLTransService: Constructors and destructor
  113. // ---------------------------------------------------------------------------
  114. XMLTransService::XMLTransService()
  115. {
  116.     static XMLRegisterCleanup mappingsCleanup;
  117.     static XMLRegisterCleanup mappingsRecognizerCleanup;
  118.     if (!gMappings) {
  119.         RefHashTableOf<ENameMap>* t = new RefHashTableOf<ENameMap>(103);
  120.         if (XMLPlatformUtils::compareAndSwap((void **)&gMappings, t, 0) != 0)
  121.         {
  122.             delete t;
  123.         }
  124.         else
  125.         {
  126.             mappingsCleanup.registerCleanup(reinitMappings);
  127.         }
  128.     }
  129.     if (!gMappingsRecognizer) {
  130.         RefVectorOf<ENameMap>* t = new RefVectorOf<ENameMap>(XMLRecognizer::Encodings_Count);
  131.         if (XMLPlatformUtils::compareAndSwap((void **)&gMappingsRecognizer, t, 0) != 0)
  132.         {
  133.             delete t;
  134.         }
  135.         else
  136.         {
  137.             mappingsRecognizerCleanup.registerCleanup(reinitMappingsRecognizer);
  138.         }
  139.     }
  140. }
  141. XMLTransService::~XMLTransService()
  142. {
  143. }
  144. // ---------------------------------------------------------------------------
  145. // Allow user specific encodings to be added to the mappings table.
  146. // Should be called after platform init
  147. // ---------------------------------------------------------------------------
  148. void XMLTransService::addEncoding(const XMLCh* const encoding,
  149.   ENameMap* const ownMapping)
  150. {
  151.     gMappings->put((void *) encoding, ownMapping);
  152. }
  153. // ---------------------------------------------------------------------------
  154. //  XMLTransService: Non-virtual API
  155. // ---------------------------------------------------------------------------
  156. XMLTranscoder*
  157. XMLTransService::makeNewTranscoderFor(  const   char* const             encodingName
  158.                                         ,       XMLTransService::Codes& resValue
  159.                                         , const unsigned int            blockSize
  160.                                         ,       MemoryManager* const    manager)
  161. {
  162.     XMLCh* tmpName = XMLString::transcode(encodingName, manager);
  163.     ArrayJanitor<XMLCh> janName(tmpName, manager);
  164.     return makeNewTranscoderFor(tmpName, resValue, blockSize, manager);
  165. }
  166. XMLTranscoder*
  167. XMLTransService::makeNewTranscoderFor(  const   XMLCh* const            encodingName
  168.                                         ,       XMLTransService::Codes& resValue
  169.                                         , const unsigned int            blockSize
  170.                                         ,       MemoryManager* const    manager)
  171. {
  172.     //
  173.     // If strict IANA encoding flag is set, validate encoding name
  174.     //
  175.     if (gStrictIANAEncoding)
  176.     {
  177.         if (!EncodingValidator::instance()->isValidEncoding(encodingName))
  178.         {
  179.             resValue = XMLTransService::UnsupportedEncoding;
  180.             return 0;
  181.         }
  182.     }
  183.     //
  184.     //  First try to find it in our list of mappings to intrinsically
  185.     //  supported encodings. We have to upper case the passed encoding
  186.     //  name because we use a hash table and we stored all our mappings
  187.     //  in all uppercase.
  188.     //
  189.     const unsigned int bufSize = 2048;
  190.     XMLCh upBuf[bufSize + 1];
  191.     if (!XMLString::copyNString(upBuf, encodingName, bufSize))
  192.     {
  193.         resValue = XMLTransService::InternalFailure;
  194.         return 0;
  195.     }
  196.     XMLString::upperCase(upBuf);
  197.     ENameMap* ourMapping = gMappings->get(upBuf);
  198.     // If we found it, then call the factory method for it
  199.     if (ourMapping)
  200. {
  201.        XMLTranscoder* temp = ourMapping->makeNew(blockSize, manager);
  202.        resValue = temp ? XMLTransService::Ok : XMLTransService::InternalFailure;
  203.        return temp;
  204.     }
  205.     //
  206.     //  It wasn't an intrinsic and it wasn't disallowed, so pass it on
  207.     //  to the trans service to see if he can make anything of it.
  208.     //
  209.     XMLTranscoder* temp =  makeNewXMLTranscoder(encodingName, resValue, blockSize, manager);
  210.     // if successful, set resValue to OK
  211.     // if failed, the makeNewXMLTranscoder has already set the proper failing resValue
  212.     if (temp) resValue =  XMLTransService::Ok;
  213.     return temp;
  214. }
  215. XMLTranscoder*
  216. XMLTransService::makeNewTranscoderFor(  XMLRecognizer::Encodings        encodingEnum
  217.                                         ,       XMLTransService::Codes& resValue
  218.                                         , const unsigned int            blockSize
  219.                                         ,       MemoryManager* const    manager)
  220. {
  221.     //
  222.     // We can only make transcoder if the passed encodingEnum is under this range
  223.     //
  224.     if (encodingEnum < XMLRecognizer::Encodings_Min || encodingEnum > XMLRecognizer::Encodings_Max) {
  225.         resValue = XMLTransService::InternalFailure;
  226.         return 0;
  227.     }
  228.     ENameMap* ourMapping = gMappingsRecognizer->elementAt(encodingEnum);
  229.     // If we found it, then call the factory method for it
  230.     if (ourMapping) {
  231.        XMLTranscoder* temp = ourMapping->makeNew(blockSize, manager);
  232.        resValue = temp ? XMLTransService::Ok : XMLTransService::InternalFailure;
  233.        return temp;
  234.     }
  235.     else {
  236.         XMLTranscoder* temp =  makeNewXMLTranscoder(XMLRecognizer::nameForEncoding(encodingEnum), resValue, blockSize, manager);
  237.         // if successful, set resValue to OK
  238.         // if failed, the makeNewXMLTranscoder has already set the proper failing resValue
  239.         if (temp) resValue =  XMLTransService::Ok;
  240.         return temp;
  241.     }
  242. }
  243. // ---------------------------------------------------------------------------
  244. //  XMLTransTransService: Hidden Init Method
  245. //
  246. //  This is called by platform utils during startup.
  247. // ---------------------------------------------------------------------------
  248. void XMLTransService::initTransService()
  249. {
  250.     //
  251.     //  A stupid way to increment the fCurCount inside the RefVectorOf
  252.     //
  253.     for (unsigned int i = 0; i < XMLRecognizer::Encodings_Count; i++)
  254.         gMappingsRecognizer->addElement(0);
  255.     //
  256.     //  Add in the magical mapping for the native XMLCh transcoder. This
  257.     //  is used for internal entities.
  258.     //
  259.     gMappingsRecognizer->setElementAt(new ENameMapFor<XMLChTranscoder>(XMLUni::fgXMLChEncodingString), XMLRecognizer::XERCES_XMLCH);
  260.     gMappings->put((void*)XMLUni::fgXMLChEncodingString, new ENameMapFor<XMLChTranscoder>(XMLUni::fgXMLChEncodingString));
  261.     //
  262.     //  Add in our mappings for ASCII.
  263.     //
  264.     gMappingsRecognizer->setElementAt(new ENameMapFor<XMLASCIITranscoder>(XMLUni::fgUSASCIIEncodingString), XMLRecognizer::US_ASCII);
  265.     gMappings->put((void*)XMLUni::fgUSASCIIEncodingString, new ENameMapFor<XMLASCIITranscoder>(XMLUni::fgUSASCIIEncodingString));
  266.     gMappings->put((void*)XMLUni::fgUSASCIIEncodingString2, new ENameMapFor<XMLASCIITranscoder>(XMLUni::fgUSASCIIEncodingString2));
  267.     gMappings->put((void*)XMLUni::fgUSASCIIEncodingString3, new ENameMapFor<XMLASCIITranscoder>(XMLUni::fgUSASCIIEncodingString3));
  268.     gMappings->put((void*)XMLUni::fgUSASCIIEncodingString4, new ENameMapFor<XMLASCIITranscoder>(XMLUni::fgUSASCIIEncodingString4));
  269.     //
  270.     //  Add in our mappings for UTF-8
  271.     //
  272.     gMappingsRecognizer->setElementAt(new ENameMapFor<XMLUTF8Transcoder>(XMLUni::fgUTF8EncodingString), XMLRecognizer::UTF_8);
  273.     gMappings->put((void*)XMLUni::fgUTF8EncodingString, new ENameMapFor<XMLUTF8Transcoder>(XMLUni::fgUTF8EncodingString));
  274.     gMappings->put((void*)XMLUni::fgUTF8EncodingString2, new ENameMapFor<XMLUTF8Transcoder>(XMLUni::fgUTF8EncodingString2));
  275.     //
  276.     //  Add in our mappings for Latin1
  277.     //
  278.     gMappings->put((void*)XMLUni::fgISO88591EncodingString, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString));
  279.     gMappings->put((void*)XMLUni::fgISO88591EncodingString2, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString2));
  280.     gMappings->put((void*)XMLUni::fgISO88591EncodingString3, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString3));
  281.     gMappings->put((void*)XMLUni::fgISO88591EncodingString4, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString4));
  282.     gMappings->put((void*)XMLUni::fgISO88591EncodingString5, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString5));
  283.     gMappings->put((void*)XMLUni::fgISO88591EncodingString6, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString6));
  284.     gMappings->put((void*)XMLUni::fgISO88591EncodingString7, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString7));
  285.     gMappings->put((void*)XMLUni::fgISO88591EncodingString8, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString8));
  286.     gMappings->put((void*)XMLUni::fgISO88591EncodingString9, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString9));
  287.     gMappings->put((void*)XMLUni::fgISO88591EncodingString10, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString10));
  288.     gMappings->put((void*)XMLUni::fgISO88591EncodingString11, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString11));
  289.     gMappings->put((void*)XMLUni::fgISO88591EncodingString12, new ENameMapFor<XML88591Transcoder>(XMLUni::fgISO88591EncodingString12));
  290.     //
  291.     //  Add in our mappings for UTF-16 and UCS-4, little endian
  292.     //
  293.     bool swapped = false;
  294.     #if defined(ENDIANMODE_BIG)
  295.     swapped = true;
  296.     #endif
  297.     gMappingsRecognizer->setElementAt(new EEndianNameMapFor<XMLUTF16Transcoder>(XMLUni::fgUTF16LEncodingString, swapped), XMLRecognizer::UTF_16L);
  298.     gMappings->put
  299.     (
  300. (void*)XMLUni::fgUTF16LEncodingString,
  301.         new EEndianNameMapFor<XMLUTF16Transcoder>
  302.         (
  303.             XMLUni::fgUTF16LEncodingString
  304.             , swapped
  305.         )
  306.     );
  307.     gMappings->put
  308.     (
  309. (void*)XMLUni::fgUTF16LEncodingString2,
  310.         new EEndianNameMapFor<XMLUTF16Transcoder>
  311.         (
  312.             XMLUni::fgUTF16LEncodingString2
  313.             , swapped
  314.         )
  315.     );
  316.     gMappingsRecognizer->setElementAt(new EEndianNameMapFor<XMLUCS4Transcoder>(XMLUni::fgUCS4LEncodingString, swapped), XMLRecognizer::UCS_4L);
  317.     gMappings->put
  318.     (
  319. (void*)XMLUni::fgUCS4LEncodingString,
  320.         new EEndianNameMapFor<XMLUCS4Transcoder>
  321.         (
  322.             XMLUni::fgUCS4LEncodingString
  323.             , swapped
  324.         )
  325.     );
  326.     gMappings->put
  327.     (
  328. (void*)XMLUni::fgUCS4LEncodingString2,
  329.         new EEndianNameMapFor<XMLUCS4Transcoder>
  330.         (
  331.             XMLUni::fgUCS4LEncodingString2
  332.             , swapped
  333.         )
  334.     );
  335.     //
  336.     //  Add in our mappings for UTF-16 and UCS-4, big endian
  337.     //
  338.     swapped = false;
  339.     #if defined(ENDIANMODE_LITTLE)
  340.     swapped = true;
  341.     #endif
  342.     gMappingsRecognizer->setElementAt(new EEndianNameMapFor<XMLUTF16Transcoder>(XMLUni::fgUTF16BEncodingString, swapped), XMLRecognizer::UTF_16B);
  343.     gMappings->put
  344.     (
  345. (void*)XMLUni::fgUTF16BEncodingString,
  346.         new EEndianNameMapFor<XMLUTF16Transcoder>
  347.         (
  348.             XMLUni::fgUTF16BEncodingString
  349.             , swapped
  350.         )
  351.     );
  352.     gMappings->put
  353.     (
  354. (void*)XMLUni::fgUTF16BEncodingString2,
  355.         new EEndianNameMapFor<XMLUTF16Transcoder>
  356.         (
  357.             XMLUni::fgUTF16BEncodingString2
  358.             , swapped
  359.         )
  360.     );
  361.     gMappingsRecognizer->setElementAt(new EEndianNameMapFor<XMLUCS4Transcoder>(XMLUni::fgUCS4BEncodingString, swapped), XMLRecognizer::UCS_4B);
  362.     gMappings->put
  363.     (
  364. (void*)XMLUni::fgUCS4BEncodingString,
  365.         new EEndianNameMapFor<XMLUCS4Transcoder>
  366.         (
  367.             XMLUni::fgUCS4BEncodingString
  368.             , swapped
  369.         )
  370.     );
  371.     gMappings->put
  372.     (
  373. (void*)XMLUni::fgUCS4BEncodingString2,
  374.         new EEndianNameMapFor<XMLUCS4Transcoder>
  375.         (
  376.             XMLUni::fgUCS4BEncodingString2
  377.             , swapped
  378.         )
  379.     );
  380.     //
  381.     //  Add in our mappings for UTF-16 and UCS-4 which does not indicate endian
  382.     //  assumes the same endian encoding as the OS
  383.     //
  384.     gMappings->put
  385.     (
  386. (void*)XMLUni::fgUTF16EncodingString,
  387.         new EEndianNameMapFor<XMLUTF16Transcoder>
  388.         (
  389.             XMLUni::fgUTF16EncodingString
  390.             , false
  391.         )
  392.     );
  393.     gMappings->put
  394.     (
  395. (void*)XMLUni::fgUTF16EncodingString2,
  396.         new EEndianNameMapFor<XMLUTF16Transcoder>
  397.         (
  398.             XMLUni::fgUTF16EncodingString2
  399.             , false
  400.         )
  401.     );
  402.     gMappings->put
  403.     (
  404. (void*)XMLUni::fgUTF16EncodingString3,
  405.         new EEndianNameMapFor<XMLUTF16Transcoder>
  406.         (
  407.             XMLUni::fgUTF16EncodingString3
  408.             , false
  409.         )
  410.     );
  411.     gMappings->put
  412.     (
  413. (void*)XMLUni::fgUTF16EncodingString4,
  414.         new EEndianNameMapFor<XMLUTF16Transcoder>
  415.         (
  416.             XMLUni::fgUTF16EncodingString4
  417.             , false
  418.         )
  419.     );
  420.     gMappings->put
  421.     (
  422. (void*)XMLUni::fgUCS4EncodingString,
  423.         new EEndianNameMapFor<XMLUCS4Transcoder>
  424.         (
  425.             XMLUni::fgUCS4EncodingString
  426.             , false
  427.         )
  428.     );
  429.     gMappings->put
  430.     (
  431. (void*)XMLUni::fgUCS4EncodingString2,
  432.         new EEndianNameMapFor<XMLUCS4Transcoder>
  433.         (
  434.             XMLUni::fgUCS4EncodingString2
  435.             , false
  436.         )
  437.     );
  438.     gMappings->put
  439.     (
  440. (void*)XMLUni::fgUCS4EncodingString3,
  441.         new EEndianNameMapFor<XMLUCS4Transcoder>
  442.         (
  443.             XMLUni::fgUCS4EncodingString3
  444.             , false
  445.         )
  446.     );
  447.     //
  448.     //  Add in our mappings for IBM037, and the one alias we support for
  449.     //  it, which is EBCDIC-CP-US.
  450.     //
  451.     gMappingsRecognizer->setElementAt(new ENameMapFor<XMLEBCDICTranscoder>(XMLUni::fgEBCDICEncodingString), XMLRecognizer::EBCDIC);
  452.     gMappings->put((void*)XMLUni::fgIBM037EncodingString, new ENameMapFor<XMLEBCDICTranscoder>(XMLUni::fgIBM037EncodingString));
  453.     gMappings->put((void*)XMLUni::fgIBM037EncodingString2, new ENameMapFor<XMLEBCDICTranscoder>(XMLUni::fgIBM037EncodingString2));
  454.     //
  455.     //  Add in our mappings for IBM037 with Euro update, i.e. IBM1140. It
  456.     //  has alias IBM01140, the one suggested by IANA
  457.     //
  458.     gMappings->put((void*)XMLUni::fgIBM1140EncodingString, new ENameMapFor<XMLIBM1140Transcoder>(XMLUni::fgIBM1140EncodingString));
  459.     gMappings->put((void*)XMLUni::fgIBM1140EncodingString2, new ENameMapFor<XMLIBM1140Transcoder>(XMLUni::fgIBM1140EncodingString2));
  460.     gMappings->put((void*)XMLUni::fgIBM1140EncodingString3, new ENameMapFor<XMLIBM1140Transcoder>(XMLUni::fgIBM1140EncodingString3));
  461.     gMappings->put((void*)XMLUni::fgIBM1140EncodingString4, new ENameMapFor<XMLIBM1140Transcoder>(XMLUni::fgIBM1140EncodingString4));
  462.     //
  463.     //  Add in our mappings for Windows-1252. We don't have any aliases for
  464.     //  this one, so there is just one mapping.
  465.     //
  466.     gMappings->put((void*)XMLUni::fgWin1252EncodingString, new ENameMapFor<XMLWin1252Transcoder>(XMLUni::fgWin1252EncodingString));
  467. }
  468. // ---------------------------------------------------------------------------
  469. //  XMLTransService: IANA encoding setting
  470. // ---------------------------------------------------------------------------
  471. void XMLTransService::strictIANAEncoding(const bool newState)
  472. {
  473.     gStrictIANAEncoding = newState;
  474. }
  475. bool XMLTransService::isStrictIANAEncoding()
  476. {
  477.     return gStrictIANAEncoding;
  478. }
  479. // ---------------------------------------------------------------------------
  480. //  XMLTranscoder: Public Destructor
  481. // ---------------------------------------------------------------------------
  482. XMLTranscoder::~XMLTranscoder()
  483. {
  484.     fMemoryManager->deallocate(fEncodingName);//delete [] fEncodingName;
  485. }
  486. // ---------------------------------------------------------------------------
  487. //  XMLTranscoder: Hidden Constructors
  488. // ---------------------------------------------------------------------------
  489. XMLTranscoder::XMLTranscoder(const  XMLCh* const    encodingName
  490.                             , const unsigned int    blockSize
  491.                             , MemoryManager* const  manager) :
  492.     fEncodingName(0)
  493.     , fBlockSize(blockSize)
  494.     , fMemoryManager(manager)
  495. {
  496.     fEncodingName = XMLString::replicate(encodingName, fMemoryManager);
  497. }
  498. // ---------------------------------------------------------------------------
  499. //  XMLTranscoder: Protected helpers
  500. // ---------------------------------------------------------------------------
  501. void XMLTranscoder::checkBlockSize(const unsigned int toCheck)
  502. {
  503. //    if (toCheck > fBlockSize)
  504. //        ThrowXML(TranscodingException, XMLExcepts::Trans_BadBlockSize);
  505. }
  506. // ---------------------------------------------------------------------------
  507. //  XMLLCPTranscoder: Public Destructor
  508. // ---------------------------------------------------------------------------
  509. XMLLCPTranscoder::XMLLCPTranscoder()
  510. {
  511. }
  512. // ---------------------------------------------------------------------------
  513. //  XMLLCPTranscoder: Hidden Constructors
  514. // ---------------------------------------------------------------------------
  515. XMLLCPTranscoder::~XMLLCPTranscoder()
  516. {
  517. }
  518. XERCES_CPP_NAMESPACE_END