xref: /trunk/main/autodoc/source/tools/tkpchars.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #include <precomp.h>
29*cdf0e10cSrcweir #include <tools/tkpchars.hxx>
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir // NOT FULLY DECLARED SERVICES
32*cdf0e10cSrcweir #include <cosv/bstream.hxx>
33*cdf0e10cSrcweir #include <cosv/x.hxx>
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir 
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir CharacterSource::CharacterSource()
38*cdf0e10cSrcweir     :   dpSource(new char[2]),
39*cdf0e10cSrcweir         nSourceSize(0),
40*cdf0e10cSrcweir         nCurPos(0),
41*cdf0e10cSrcweir         nLastCut(0),
42*cdf0e10cSrcweir         nLastTokenStart(0),
43*cdf0e10cSrcweir         cCharAtLastCut(0)
44*cdf0e10cSrcweir {
45*cdf0e10cSrcweir     dpSource[nSourceSize] = NULCH;
46*cdf0e10cSrcweir     dpSource[nSourceSize+1] = NULCH;
47*cdf0e10cSrcweir }
48*cdf0e10cSrcweir 
49*cdf0e10cSrcweir CharacterSource::~CharacterSource()
50*cdf0e10cSrcweir {
51*cdf0e10cSrcweir     delete [] dpSource;
52*cdf0e10cSrcweir }
53*cdf0e10cSrcweir 
54*cdf0e10cSrcweir void
55*cdf0e10cSrcweir CharacterSource::LoadText(csv::bstream & io_rSource)
56*cdf0e10cSrcweir {
57*cdf0e10cSrcweir     if (dpSource != 0)
58*cdf0e10cSrcweir         delete [] dpSource;
59*cdf0e10cSrcweir 
60*cdf0e10cSrcweir     io_rSource.seek(0, csv::end);
61*cdf0e10cSrcweir     nSourceSize = intt(io_rSource.position());
62*cdf0e10cSrcweir     io_rSource.seek(0);
63*cdf0e10cSrcweir 
64*cdf0e10cSrcweir     dpSource = new char[nSourceSize+1];
65*cdf0e10cSrcweir 
66*cdf0e10cSrcweir     intt nCount = (intt) io_rSource.read(dpSource,nSourceSize);
67*cdf0e10cSrcweir     if (nCount != nSourceSize)
68*cdf0e10cSrcweir         throw csv::X_Default("IO-Error: Could not load file completely.");
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir     dpSource[nSourceSize] = NULCH;
71*cdf0e10cSrcweir 
72*cdf0e10cSrcweir     BeginSource();
73*cdf0e10cSrcweir }
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir ///  KORR_FUTURE:  So far, this works only when tokens do not cross inserted text boundaries.
76*cdf0e10cSrcweir void
77*cdf0e10cSrcweir CharacterSource::InsertTextAtCurPos( const char * i_sText2Insert )
78*cdf0e10cSrcweir {
79*cdf0e10cSrcweir     if ( i_sText2Insert == 0 ? true : strlen(i_sText2Insert) == 0 )
80*cdf0e10cSrcweir         return;
81*cdf0e10cSrcweir 
82*cdf0e10cSrcweir     aSourcesStack.push( S_SourceState(
83*cdf0e10cSrcweir                             dpSource,
84*cdf0e10cSrcweir                             nSourceSize,
85*cdf0e10cSrcweir                             nCurPos,
86*cdf0e10cSrcweir                             nLastCut,
87*cdf0e10cSrcweir                             nLastTokenStart,
88*cdf0e10cSrcweir                             cCharAtLastCut ) );
89*cdf0e10cSrcweir 
90*cdf0e10cSrcweir     nSourceSize = strlen(i_sText2Insert);
91*cdf0e10cSrcweir     dpSource = new char[nSourceSize+1];
92*cdf0e10cSrcweir     strcpy( dpSource,  i_sText2Insert);     // SAFE STRCPY (#100211# - checked)
93*cdf0e10cSrcweir 
94*cdf0e10cSrcweir     BeginSource();
95*cdf0e10cSrcweir }
96*cdf0e10cSrcweir 
97*cdf0e10cSrcweir const char *
98*cdf0e10cSrcweir CharacterSource::CutToken()
99*cdf0e10cSrcweir {
100*cdf0e10cSrcweir     dpSource[nLastCut] = cCharAtLastCut;
101*cdf0e10cSrcweir     nLastTokenStart = nLastCut;
102*cdf0e10cSrcweir     nLastCut = CurPos();
103*cdf0e10cSrcweir     cCharAtLastCut = dpSource[nLastCut];
104*cdf0e10cSrcweir     dpSource[nLastCut] = NULCH;
105*cdf0e10cSrcweir 
106*cdf0e10cSrcweir     return &dpSource[nLastTokenStart];
107*cdf0e10cSrcweir }
108*cdf0e10cSrcweir 
109*cdf0e10cSrcweir void
110*cdf0e10cSrcweir CharacterSource::BeginSource()
111*cdf0e10cSrcweir {
112*cdf0e10cSrcweir     nCurPos = 0;
113*cdf0e10cSrcweir     nLastCut = 0;
114*cdf0e10cSrcweir     nLastTokenStart = 0;
115*cdf0e10cSrcweir     cCharAtLastCut = dpSource[nLastCut];
116*cdf0e10cSrcweir     dpSource[nLastCut] = NULCH;
117*cdf0e10cSrcweir }
118*cdf0e10cSrcweir 
119*cdf0e10cSrcweir //  KORR_FUTURE:  So far, this works only when tokens do not cross inserted text boundaries.
120*cdf0e10cSrcweir char
121*cdf0e10cSrcweir CharacterSource::MoveOn_OverStack()
122*cdf0e10cSrcweir {
123*cdf0e10cSrcweir     while ( aSourcesStack.size() > 0 AND nCurPos >= nSourceSize-1 )
124*cdf0e10cSrcweir     {
125*cdf0e10cSrcweir         S_SourceState & aState = aSourcesStack.top();
126*cdf0e10cSrcweir         delete [] dpSource;
127*cdf0e10cSrcweir 
128*cdf0e10cSrcweir         dpSource = aState.dpSource;
129*cdf0e10cSrcweir         nSourceSize = aState.nSourceSize;
130*cdf0e10cSrcweir         nCurPos = aState.nCurPos;
131*cdf0e10cSrcweir         nLastCut = aState.nLastCut;
132*cdf0e10cSrcweir         nLastTokenStart = aState.nLastTokenStart;
133*cdf0e10cSrcweir         cCharAtLastCut = aState.cCharAtLastCut;
134*cdf0e10cSrcweir 
135*cdf0e10cSrcweir         aSourcesStack.pop();
136*cdf0e10cSrcweir     }
137*cdf0e10cSrcweir 
138*cdf0e10cSrcweir     if ( nLastCut < nCurPos )
139*cdf0e10cSrcweir         CutToken();
140*cdf0e10cSrcweir 
141*cdf0e10cSrcweir     return CurChar();
142*cdf0e10cSrcweir }
143*cdf0e10cSrcweir 
144*cdf0e10cSrcweir CharacterSource::
145*cdf0e10cSrcweir S_SourceState::S_SourceState( DYN char *    dpSource_,
146*cdf0e10cSrcweir                               intt          nSourceSize_,
147*cdf0e10cSrcweir                               intt          nCurPos_,
148*cdf0e10cSrcweir                               intt          nLastCut_,
149*cdf0e10cSrcweir                               intt          nLastTokenStart_,
150*cdf0e10cSrcweir                               char          cCharAtLastCut_ )
151*cdf0e10cSrcweir     :   dpSource(dpSource_),
152*cdf0e10cSrcweir         nSourceSize(nSourceSize_),
153*cdf0e10cSrcweir         nCurPos(nCurPos_),
154*cdf0e10cSrcweir         nLastCut(nLastCut_),
155*cdf0e10cSrcweir         nLastTokenStart(nLastTokenStart_),
156*cdf0e10cSrcweir         cCharAtLastCut(cCharAtLastCut_)
157*cdf0e10cSrcweir {
158*cdf0e10cSrcweir }
159*cdf0e10cSrcweir 
160