~ubuntu-branches/ubuntu/raring/sunpinyin/raring

« back to all changes in this revision

Viewing changes to src/ime-core/imi_funcobjs.cpp

  • Committer: Package Import Robot
  • Author(s): YunQiang Su
  • Date: 2012-03-30 15:31:55 UTC
  • mfrom: (1.1.3) (1.2.7 sid)
  • Revision ID: package-import@ubuntu.com-20120330153155-qgls77sogzgtg9zp
Tags: 2.0.3+git20120222-1
* Team upload: git snapshot 20120222.
   - fix breaks if LDFLAGS in environment contains
       multiple words (Closese #646001).
   - rm patches merged to upstream:
       append-os-environ-toenv.patch
       fix-ftbfs-on-sh.patch
       remove-10-candidate-words-limitation.patch
   - refresh disable-lm-dict-compile.patch.
* Bump stardard version to 3.9.3: no modify needed.
* add libsunpinyin3-dbg and python-sunpinyin packages.
* debian/compat to 9, multiarch it.
* rewrite debian/rules with dh 7 format.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/*
2
2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
3
 
 * 
 
3
 *
4
4
 * Copyright (c) 2007 Sun Microsystems, Inc. All Rights Reserved.
5
 
 * 
 
5
 *
6
6
 * The contents of this file are subject to the terms of either the GNU Lesser
7
7
 * General Public License Version 2.1 only ("LGPL") or the Common Development and
8
8
 * Distribution License ("CDDL")(collectively, the "License"). You may not use this
9
9
 * file except in compliance with the License. You can obtain a copy of the CDDL at
10
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 
 
11
 * http://www.opensource.org/licenses/lgpl-license.php. See the License for the
12
12
 * specific language governing permissions and limitations under the License. When
13
13
 * distributing the software, include this License Header Notice in each file and
14
14
 * include the full text of the License in the License file as well as the
15
15
 * following notice:
16
 
 * 
 
16
 *
17
17
 * NOTICE PURSUANT TO SECTION 9 OF THE COMMON DEVELOPMENT AND DISTRIBUTION LICENSE
18
18
 * (CDDL)
19
19
 * For Covered Software in this distribution, this License shall be governed by the
21
21
 * Any litigation relating to this License shall be subject to the jurisdiction of
22
22
 * the Federal Courts of the Northern District of California and the state courts
23
23
 * of the State of California, with venue lying in Santa Clara County, California.
24
 
 * 
 
24
 *
25
25
 * Contributor(s):
26
 
 * 
 
26
 *
27
27
 * If you wish your version of this file to be governed by only the CDDL or only
28
28
 * the LGPL Version 2.1, indicate your decision by adding "[Contributor]" elects to
29
29
 * include this software in this distribution under the [CDDL or LGPL Version 2.1]
32
32
 * Version 2.1, or to extend the choice of license to its licensees as provided
33
33
 * above. However, if you add LGPL Version 2.1 code and therefore, elected the LGPL
34
34
 * Version 2 license, then the option applies only if the new code is made subject
35
 
 * to such option by the copyright holder. 
 
35
 * to such option by the copyright holder.
36
36
 */
37
37
 
38
38
#include "imi_funcobjs.h"
39
39
 
40
 
void CGetFullSymbolOp::initSymbolMap ()
 
40
void
 
41
CGetFullSymbolOp::initSymbolMap()
41
42
{
42
 
    m_symbolMap.clear ();
 
43
    m_symbolMap.clear();
43
44
 
44
45
    TWCHAR cwstr[256];
45
46
    static const char half_symbol[] = "azAZ";
50
51
    MBSTOWCS(&cwstr[0], src, (sizeof(cwstr) / sizeof(TWCHAR)) - 1);
51
52
 
52
53
    TWCHAR wch = cwstr[0];
53
 
    for (char h=half_symbol[0], t=half_symbol[1]; h <= t; ++h, ++wch)
 
54
    for (char h = half_symbol[0], t = half_symbol[1]; h <= t; ++h, ++wch)
54
55
        m_symbolMap[h] = wch;
55
56
 
56
57
    wch = cwstr[2];
57
 
    for (char h=half_symbol[2], t=half_symbol[3]; h <= t; ++h, ++wch)
 
58
    for (char h = half_symbol[2], t = half_symbol[3]; h <= t; ++h, ++wch)
58
59
        m_symbolMap[h] = wch;
59
60
}
60
61
 
61
 
const wstring& CGetFullSymbolOp::operator () (unsigned ch)
 
62
const wstring&
 
63
CGetFullSymbolOp::operator ()(unsigned ch)
62
64
{
63
65
    static wstring ret;
64
66
 
65
67
    if (m_symbolMap.empty())
66
 
        initSymbolMap ();
 
68
        initSymbolMap();
67
69
 
68
 
    CSymbolMap::iterator it1 = m_symbolMap.find (ch);
 
70
    CSymbolMap::iterator it1 = m_symbolMap.find(ch);
69
71
    if (it1 != m_symbolMap.end())
70
72
        return it1->second;
71
73
 
73
75
}
74
76
 
75
77
CGetFullPunctOp::CGetFullPunctOp()
76
 
{}
 
78
{
 
79
}
77
80
 
78
 
void CGetFullPunctOp::initPunctMap (const string_pairs& punc_map)
 
81
void
 
82
CGetFullPunctOp::initPunctMap(const string_pairs& punc_map)
79
83
{
80
84
    TWCHAR cwstr[256];
81
 
    
 
85
 
82
86
    m_punctMap.clear();
83
87
    m_punctClosingSts.clear();
84
 
    
85
 
    string_pairs::const_iterator it  = punc_map.begin();
 
88
 
 
89
    string_pairs::const_iterator it = punc_map.begin();
86
90
    string_pairs::const_iterator ite = punc_map.end();
87
 
    
88
 
    for (; it != ite; ++it)
89
 
    {
 
91
 
 
92
    for (; it != ite; ++it) {
90
93
        const char *k = it->first.c_str();
91
94
        const char *v = it->second.c_str();
92
95
 
93
96
        if (!v) continue;
94
 
        
 
97
 
95
98
        memset(cwstr, 0, sizeof(cwstr));
96
99
        MBSTOWCS(&cwstr[0], v, (sizeof(cwstr) / sizeof(TWCHAR)) - 1);
97
 
        
 
100
 
98
101
        unsigned key = *k;
99
 
        if (m_punctMap.find(*k) != m_punctMap.end ()) {
100
 
            m_punctClosingSts.insert (std::make_pair (key, false));
 
102
        if (m_punctMap.find(*k) != m_punctMap.end()) {
 
103
            m_punctClosingSts.insert(std::make_pair(key, false));
101
104
            key |= 0x80000000;
102
105
        }
103
 
        
104
 
        m_punctMap[key] = wstring (cwstr);
 
106
 
 
107
        m_punctMap[key] = wstring(cwstr);
105
108
    }
106
109
}
107
110
 
108
 
const wstring& CGetFullPunctOp::operator () (unsigned ch)
 
111
const wstring&
 
112
CGetFullPunctOp::operator ()(unsigned ch)
109
113
{
110
114
    static wstring ret;
111
 
    CPunctClosingStates::iterator it = m_punctClosingSts.find (ch);
112
 
    if (it != m_punctClosingSts.end ()) {
 
115
    CPunctClosingStates::iterator it = m_punctClosingSts.find(ch);
 
116
    if (it != m_punctClosingSts.end()) {
113
117
        if (it->second) ch |= 0x80000000;
114
118
        it->second = !it->second;
115
119
    }
116
120
 
117
 
    CPunctMap::iterator it1 = m_punctMap.find (ch);
 
121
    CPunctMap::iterator it1 = m_punctMap.find(ch);
118
122
    if (it1 != m_punctMap.end())
119
123
        return it1->second;
120
124