2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
4 * Copyright (c) 2007 Sun Microsystems, Inc. All Rights Reserved.
6 * The contents of this file are subject to the terms of either the GNU Lesser
7 * General Public License Version 2.1 only ("LGPL") or the Common Development and
8 * Distribution License ("CDDL")(collectively, the "License"). You may not use this
9 * file except in compliance with the License. You can obtain a copy of the CDDL at
10 * http://www.opensource.org/licenses/cddl1.php and a copy of the LGPLv2.1 at
11 * http://www.opensource.org/licenses/lgpl-license.php. See the License for the
12 * specific language governing permissions and limitations under the License. When
13 * distributing the software, include this License Header Notice in each file and
14 * include the full text of the License in the License file as well as the
17 * NOTICE PURSUANT TO SECTION 9 OF THE COMMON DEVELOPMENT AND DISTRIBUTION LICENSE
19 * For Covered Software in this distribution, this License shall be governed by the
20 * laws of the State of California (excluding conflict-of-law provisions).
21 * Any litigation relating to this License shall be subject to the jurisdiction of
22 * the Federal Courts of the Northern District of California and the state courts
23 * of the State of California, with venue lying in Santa Clara County, California.
27 * If you wish your version of this file to be governed by only the CDDL or only
28 * the LGPL Version 2.1, indicate your decision by adding "[Contributor]" elects to
29 * include this software in this distribution under the [CDDL or LGPL Version 2.1]
30 * license." If you don't indicate a single choice of license, a recipient has the
31 * option to distribute your version of this file under either the CDDL or the LGPL
32 * Version 2.1, or to extend the choice of license to its licensees as provided
33 * above. However, if you add LGPL Version 2.1 code and therefore, elected the LGPL
34 * Version 2 license, then the option applies only if the new code is made subject
35 * to such option by the copyright holder.
38 #include "imi_funcobjs.h"
41 CGetFullSymbolOp::initSymbolMap()
46 static const char half_symbol[] = "azAZ";
47 static const char full_symbol[] = "azAZ";
49 char * src = (char*)full_symbol;
50 memset(&cwstr[0], 0, sizeof(cwstr));
51 MBSTOWCS(&cwstr[0], src, (sizeof(cwstr) / sizeof(TWCHAR)) - 1);
53 TWCHAR wch = cwstr[0];
54 for (char h = half_symbol[0], t = half_symbol[1]; h <= t; ++h, ++wch)
58 for (char h = half_symbol[2], t = half_symbol[3]; h <= t; ++h, ++wch)
63 CGetFullSymbolOp::operator ()(unsigned ch)
67 if (m_symbolMap.empty())
70 CSymbolMap::iterator it1 = m_symbolMap.find(ch);
71 if (it1 != m_symbolMap.end())
77 CGetFullPunctOp::CGetFullPunctOp()
82 CGetFullPunctOp::initPunctMap(const string_pairs& punc_map)
87 m_punctClosingSts.clear();
89 string_pairs::const_iterator it = punc_map.begin();
90 string_pairs::const_iterator ite = punc_map.end();
92 for (; it != ite; ++it) {
93 const char *k = it->first.c_str();
94 const char *v = it->second.c_str();
98 memset(cwstr, 0, sizeof(cwstr));
99 MBSTOWCS(&cwstr[0], v, (sizeof(cwstr) / sizeof(TWCHAR)) - 1);
102 if (m_punctMap.find(*k) != m_punctMap.end()) {
103 m_punctClosingSts.insert(std::make_pair(key, false));
107 m_punctMap[key] = wstring(cwstr);
112 CGetFullPunctOp::operator ()(unsigned ch)
115 CPunctClosingStates::iterator it = m_punctClosingSts.find(ch);
116 if (it != m_punctClosingSts.end()) {
117 if (it->second) ch |= 0x80000000;
118 it->second = !it->second;
121 CPunctMap::iterator it1 = m_punctMap.find(ch);
122 if (it1 != m_punctMap.end())