Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include <tools/resid.hxx>
21 : #include <unotools/charclass.hxx>
22 : #include <com/sun/star/i18n/CollatorOptions.hpp>
23 : #include <editeng/unolingu.hxx>
24 : #include <txtfld.hxx>
25 : #include <doc.hxx>
26 : #include <IDocumentLayoutAccess.hxx>
27 : #include <docary.hxx>
28 : #include <cntfrm.hxx>
29 : #include <node.hxx>
30 : #include <frmatr.hxx>
31 : #include <pam.hxx>
32 : #include <txttxmrk.hxx>
33 : #include <frmfmt.hxx>
34 : #include <fmtfld.hxx>
35 : #include <txmsrt.hxx>
36 : #include <ndtxt.hxx>
37 : #include <txtatr.hxx>
38 : #include <swtable.hxx>
39 : #include <expfld.hxx>
40 : #include <authfld.hxx>
41 : #include <toxwrap.hxx>
42 :
43 : #include <comcore.hrc>
44 : #include <numrule.hxx>
45 : #include <reffld.hxx>
46 :
47 : using namespace ::com::sun::star;
48 : using namespace ::com::sun::star::uno;
49 :
50 : // Initialize strings
51 : sal_uInt16 SwTOXSortTabBase::nOpt = 0;
52 :
53 14 : SwTOXInternational::SwTOXInternational( LanguageType nLang, sal_uInt16 nOpt,
54 : const OUString& rSortAlgorithm ) :
55 : eLang( nLang ),
56 : sSortAlgorithm(rSortAlgorithm),
57 14 : nOptions( nOpt )
58 : {
59 14 : Init();
60 14 : }
61 :
62 0 : SwTOXInternational::SwTOXInternational( const SwTOXInternational& rIntl ) :
63 : eLang( rIntl.eLang ),
64 : sSortAlgorithm(rIntl.sSortAlgorithm),
65 0 : nOptions( rIntl.nOptions )
66 : {
67 0 : Init();
68 0 : }
69 :
70 14 : void SwTOXInternational::Init()
71 : {
72 14 : pIndexWrapper = new IndexEntrySupplierWrapper();
73 :
74 14 : const lang::Locale aLcl( LanguageTag::convertToLocale( eLang ) );
75 14 : pIndexWrapper->SetLocale( aLcl );
76 :
77 14 : if(sSortAlgorithm.isEmpty())
78 : {
79 10 : Sequence < OUString > aSeq( pIndexWrapper->GetAlgorithmList( aLcl ));
80 10 : if(aSeq.getLength())
81 10 : sSortAlgorithm = aSeq.getConstArray()[0];
82 : }
83 :
84 14 : if ( nOptions & nsSwTOIOptions::TOI_CASE_SENSITIVE )
85 4 : pIndexWrapper->LoadAlgorithm( aLcl, sSortAlgorithm, 0 );
86 : else
87 10 : pIndexWrapper->LoadAlgorithm( aLcl, sSortAlgorithm, SW_COLLATOR_IGNORES );
88 :
89 14 : pCharClass = new CharClass( LanguageTag( aLcl ));
90 :
91 14 : }
92 :
93 28 : SwTOXInternational::~SwTOXInternational()
94 : {
95 14 : delete pCharClass;
96 14 : delete pIndexWrapper;
97 14 : }
98 :
99 2 : OUString SwTOXInternational::ToUpper( const OUString& rStr, sal_Int32 nPos ) const
100 : {
101 2 : return pCharClass->uppercase( rStr, nPos, 1 );
102 : }
103 :
104 0 : inline bool SwTOXInternational::IsNumeric( const OUString& rStr ) const
105 : {
106 0 : return pCharClass->isNumeric( rStr );
107 : }
108 :
109 0 : sal_Int32 SwTOXInternational::Compare( const TextAndReading& rTaR1,
110 : const lang::Locale& rLocale1,
111 : const TextAndReading& rTaR2,
112 : const lang::Locale& rLocale2 ) const
113 : {
114 : return pIndexWrapper->CompareIndexEntry( rTaR1.sText, rTaR1.sReading, rLocale1,
115 0 : rTaR2.sText, rTaR2.sReading, rLocale2 );
116 : }
117 :
118 2 : OUString SwTOXInternational::GetIndexKey( const TextAndReading& rTaR,
119 : const lang::Locale& rLocale ) const
120 : {
121 2 : return pIndexWrapper->GetIndexKey( rTaR.sText, rTaR.sReading, rLocale );
122 : }
123 :
124 0 : OUString SwTOXInternational::GetFollowingText( bool bMorePages ) const
125 : {
126 0 : return pIndexWrapper->GetFollowingText( bMorePages );
127 : }
128 :
129 : // SortElement for TOX entries
130 12 : SwTOXSortTabBase::SwTOXSortTabBase( TOXSortType nTyp, const SwCntntNode* pNd,
131 : const SwTxtTOXMark* pMark,
132 : const SwTOXInternational* pInter,
133 : const lang::Locale* pLocale )
134 : : pTOXNd( 0 ), pTxtMark( pMark ), pTOXIntl( pInter ),
135 12 : nPos( 0 ), nCntPos( 0 ), nType( static_cast<sal_uInt16>(nTyp) ), bValidTxt( false )
136 : {
137 12 : if ( pLocale )
138 2 : aLocale = *pLocale;
139 :
140 12 : if( pNd )
141 : {
142 8 : sal_Int32 n = 0;
143 8 : if( pTxtMark )
144 2 : n = pTxtMark->GetStart();
145 8 : SwTOXSource aTmp( pNd, n, pTxtMark && pTxtMark->GetTOXMark().IsMainEntry() );
146 8 : aTOXSources.push_back(aTmp);
147 :
148 8 : nPos = pNd->GetIndex();
149 :
150 8 : switch( nTyp )
151 : {
152 : case TOX_SORT_CONTENT:
153 : case TOX_SORT_PARA:
154 : case TOX_SORT_TABLE:
155 : // If they are in a special areas, we should get the position at the
156 : // body
157 6 : if( nPos < pNd->GetNodes().GetEndOfExtras().GetIndex() )
158 : {
159 : // Then get the 'anchor' (body) position
160 0 : Point aPt;
161 0 : const SwCntntFrm* pFrm = pNd->getLayoutFrm( pNd->GetDoc()->getIDocumentLayoutAccess().GetCurrentLayout(), &aPt, 0, false );
162 0 : if( pFrm )
163 : {
164 0 : SwPosition aPos( *pNd );
165 0 : const SwDoc& rDoc = *pNd->GetDoc();
166 0 : bool const bResult = GetBodyTxtNode( rDoc, aPos, *pFrm );
167 : OSL_ENSURE(bResult, "where is the text node");
168 : (void) bResult; // unused in non-debug
169 0 : nPos = aPos.nNode.GetIndex();
170 0 : nCntPos = aPos.nContent.GetIndex();
171 : }
172 : }
173 : else
174 6 : nCntPos = n;
175 6 : break;
176 2 : default: break;
177 : }
178 : }
179 12 : }
180 :
181 0 : OUString SwTOXSortTabBase::GetURL() const
182 : {
183 0 : return OUString();
184 : }
185 :
186 0 : void SwTOXSortTabBase::FillText( SwTxtNode& rNd, const SwIndex& rInsPos,
187 : sal_uInt16 ) const
188 : {
189 0 : rNd.InsertText( GetTxt().sText, rInsPos );
190 0 : }
191 :
192 2 : bool SwTOXSortTabBase::operator==( const SwTOXSortTabBase& rCmp )
193 : {
194 2 : bool bRet = nPos == rCmp.nPos && nCntPos == rCmp.nCntPos &&
195 0 : (!aTOXSources[0].pNd || !rCmp.aTOXSources[0].pNd ||
196 2 : aTOXSources[0].pNd == rCmp.aTOXSources[0].pNd );
197 :
198 2 : if( TOX_SORT_CONTENT == nType )
199 : {
200 0 : bRet = bRet && pTxtMark && rCmp.pTxtMark &&
201 0 : pTxtMark->GetStart() == rCmp.pTxtMark->GetStart();
202 :
203 0 : if( bRet )
204 : {
205 : // Both pointers exist -> compare text
206 : // else -> compare AlternativeText
207 0 : const sal_Int32 *pEnd = pTxtMark->End();
208 0 : const sal_Int32 *pEndCmp = rCmp.pTxtMark->End();
209 :
210 0 : bRet = ( ( pEnd && pEndCmp ) || ( !pEnd && !pEndCmp ) ) &&
211 0 : pTOXIntl->IsEqual( GetTxt(), GetLocale(),
212 0 : rCmp.GetTxt(), rCmp.GetLocale() );
213 : }
214 : }
215 2 : return bRet;
216 : }
217 :
218 2 : bool SwTOXSortTabBase::operator<( const SwTOXSortTabBase& rCmp )
219 : {
220 2 : if( nPos < rCmp.nPos )
221 0 : return true;
222 :
223 2 : if( nPos == rCmp.nPos )
224 : {
225 0 : if( nCntPos < rCmp.nCntPos )
226 0 : return true;
227 :
228 0 : if( nCntPos == rCmp.nCntPos )
229 : {
230 0 : const SwNode* pFirst = aTOXSources[0].pNd;
231 0 : const SwNode* pNext = rCmp.aTOXSources[0].pNd;
232 :
233 0 : if( pFirst && pFirst == pNext )
234 : {
235 0 : if( TOX_SORT_CONTENT == nType && pTxtMark && rCmp.pTxtMark )
236 : {
237 0 : if( pTxtMark->GetStart() < rCmp.pTxtMark->GetStart() )
238 0 : return true;
239 :
240 0 : if( pTxtMark->GetStart() == rCmp.pTxtMark->GetStart() )
241 : {
242 0 : const sal_Int32 *pEnd = pTxtMark->End();
243 0 : const sal_Int32 *pEndCmp = rCmp.pTxtMark->End();
244 :
245 : // Both pointers exist -> compare text
246 : // else -> compare AlternativeText
247 0 : if( ( pEnd && pEndCmp ) || ( !pEnd && !pEndCmp ) )
248 : {
249 0 : return pTOXIntl->IsLess( GetTxt(), GetLocale(),
250 0 : rCmp.GetTxt(), rCmp.GetLocale() );
251 : }
252 0 : if( pEnd && !pEndCmp )
253 0 : return true;
254 : }
255 0 : }
256 : }
257 0 : else if( pFirst && pFirst->IsTxtNode() &&
258 0 : pNext && pNext->IsTxtNode() )
259 : return ::IsFrameBehind( *(SwTxtNode*)pNext, nCntPos,
260 0 : *(SwTxtNode*)pFirst, nCntPos );
261 : }
262 : }
263 2 : return false;
264 : }
265 :
266 : // Sorted keyword entry
267 2 : SwTOXIndex::SwTOXIndex( const SwTxtNode& rNd,
268 : const SwTxtTOXMark* pMark, sal_uInt16 nOptions,
269 : sal_uInt8 nKyLevel,
270 : const SwTOXInternational& rIntl,
271 : const lang::Locale& rLocale )
272 : : SwTOXSortTabBase( TOX_SORT_INDEX, &rNd, pMark, &rIntl, &rLocale ),
273 2 : nKeyLevel(nKyLevel)
274 : {
275 2 : nPos = rNd.GetIndex();
276 2 : nOpt = nOptions;
277 2 : }
278 :
279 : // Compare keywords. Only relates to the text.
280 :
281 0 : bool SwTOXIndex::operator==( const SwTOXSortTabBase& rCmpBase )
282 : {
283 0 : SwTOXIndex& rCmp = (SwTOXIndex&)rCmpBase;
284 :
285 : // Respect case taking dependencies into account
286 0 : if(GetLevel() != rCmp.GetLevel() || nKeyLevel != rCmp.nKeyLevel)
287 0 : return false;
288 :
289 : OSL_ENSURE(pTxtMark, "pTxtMark == 0, No keyword");
290 :
291 0 : bool bRet = pTOXIntl->IsEqual( GetTxt(), GetLocale(),
292 0 : rCmp.GetTxt(), rCmp.GetLocale() );
293 :
294 : // If we don't summarize we need to evaluate the Pos
295 0 : if(bRet && !(GetOptions() & nsSwTOIOptions::TOI_SAME_ENTRY))
296 0 : bRet = nPos == rCmp.nPos;
297 :
298 0 : return bRet;
299 : }
300 :
301 : // operator, only depends on the text
302 :
303 0 : bool SwTOXIndex::operator<( const SwTOXSortTabBase& rCmpBase )
304 : {
305 0 : SwTOXIndex& rCmp = (SwTOXIndex&)rCmpBase;
306 :
307 : OSL_ENSURE(pTxtMark, "pTxtMark == 0, No keyword");
308 :
309 0 : const TextAndReading aMyTaR(GetTxt());
310 0 : const TextAndReading aOtherTaR(rCmp.GetTxt());
311 :
312 0 : bool bRet = GetLevel() == rCmp.GetLevel() &&
313 0 : pTOXIntl->IsLess( aMyTaR, GetLocale(),
314 0 : aOtherTaR, rCmp.GetLocale() );
315 :
316 : // If we don't summarize we need to evaluate the Pos
317 0 : if( !bRet && !(GetOptions() & nsSwTOIOptions::TOI_SAME_ENTRY) )
318 : {
319 0 : bRet = pTOXIntl->IsEqual( aMyTaR, GetLocale(),
320 0 : aOtherTaR, rCmp.GetLocale() ) &&
321 0 : nPos < rCmp.nPos;
322 : }
323 :
324 0 : return bRet;
325 : }
326 :
327 : // The keyword itself
328 :
329 2 : TextAndReading SwTOXIndex::GetText_Impl() const
330 : {
331 : OSL_ENSURE(pTxtMark, "pTxtMark == 0, No keyword");
332 2 : const SwTOXMark& rTOXMark = pTxtMark->GetTOXMark();
333 :
334 2 : TextAndReading aRet;
335 2 : switch(nKeyLevel)
336 : {
337 : case FORM_PRIMARY_KEY :
338 : {
339 0 : aRet.sText = rTOXMark.GetPrimaryKey();
340 0 : aRet.sReading = rTOXMark.GetPrimaryKeyReading();
341 : }
342 0 : break;
343 : case FORM_SECONDARY_KEY :
344 : {
345 0 : aRet.sText = rTOXMark.GetSecondaryKey();
346 0 : aRet.sReading = rTOXMark.GetSecondaryKeyReading();
347 : }
348 0 : break;
349 : case FORM_ENTRY :
350 : {
351 2 : aRet.sText = rTOXMark.GetText();
352 2 : aRet.sReading = rTOXMark.GetTextReading();
353 : }
354 2 : break;
355 : }
356 : // if TOI_INITIAL_CAPS is set, first character is to be capitalized
357 2 : if( nsSwTOIOptions::TOI_INITIAL_CAPS & nOpt && pTOXIntl && !aRet.sText.isEmpty())
358 : {
359 2 : aRet.sText = pTOXIntl->ToUpper( aRet.sText, 0 ) + aRet.sText.copy(1);
360 : }
361 :
362 2 : return aRet;
363 : }
364 :
365 0 : void SwTOXIndex::FillText( SwTxtNode& rNd, const SwIndex& rInsPos, sal_uInt16 ) const
366 : {
367 0 : const sal_Int32* pEnd = pTxtMark->End();
368 :
369 0 : TextAndReading aRet;
370 0 : if( pEnd && !pTxtMark->GetTOXMark().IsAlternativeText() &&
371 0 : 0 == (GetOptions() & nsSwTOIOptions::TOI_KEY_AS_ENTRY))
372 : {
373 0 : aRet.sText = ((SwTxtNode*)aTOXSources[0].pNd)->GetExpandTxt(
374 0 : pTxtMark->GetStart(),
375 0 : *pEnd - pTxtMark->GetStart());
376 0 : if(nsSwTOIOptions::TOI_INITIAL_CAPS & nOpt && pTOXIntl && !aRet.sText.isEmpty())
377 : {
378 0 : aRet.sText = pTOXIntl->ToUpper( aRet.sText, 0 ) + aRet.sText.copy(1);
379 : }
380 : }
381 : else
382 0 : aRet = GetTxt();
383 :
384 0 : rNd.InsertText( aRet.sText, rInsPos );
385 0 : }
386 :
387 6 : sal_uInt16 SwTOXIndex::GetLevel() const
388 : {
389 : OSL_ENSURE(pTxtMark, "pTxtMark == 0, No keyword");
390 :
391 6 : sal_uInt16 nForm = FORM_PRIMARY_KEY;
392 :
393 18 : if( 0 == (GetOptions() & nsSwTOIOptions::TOI_KEY_AS_ENTRY)&&
394 6 : !pTxtMark->GetTOXMark().GetPrimaryKey().isEmpty() )
395 : {
396 0 : nForm = FORM_SECONDARY_KEY;
397 0 : if( !pTxtMark->GetTOXMark().GetSecondaryKey().isEmpty() )
398 0 : nForm = FORM_ENTRY;
399 : }
400 6 : return nForm;
401 : }
402 :
403 : // Key and separator
404 0 : SwTOXCustom::SwTOXCustom(const TextAndReading& rKey,
405 : sal_uInt16 nLevel,
406 : const SwTOXInternational& rIntl,
407 : const lang::Locale& rLocale )
408 : : SwTOXSortTabBase( TOX_SORT_CUSTOM, 0, 0, &rIntl, &rLocale ),
409 0 : m_aKey(rKey), nLev(nLevel)
410 : {
411 0 : }
412 :
413 0 : bool SwTOXCustom::operator==(const SwTOXSortTabBase& rCmpBase)
414 : {
415 0 : return GetLevel() == rCmpBase.GetLevel() &&
416 0 : pTOXIntl->IsEqual( GetTxt(), GetLocale(),
417 0 : rCmpBase.GetTxt(), rCmpBase.GetLocale() );
418 : }
419 :
420 0 : bool SwTOXCustom::operator < (const SwTOXSortTabBase& rCmpBase)
421 : {
422 0 : return GetLevel() <= rCmpBase.GetLevel() &&
423 0 : pTOXIntl->IsLess( GetTxt(), GetLocale(),
424 0 : rCmpBase.GetTxt(), rCmpBase.GetLocale() );
425 : }
426 :
427 0 : sal_uInt16 SwTOXCustom::GetLevel() const
428 : {
429 0 : return nLev;
430 : }
431 :
432 0 : TextAndReading SwTOXCustom::GetText_Impl() const
433 : {
434 0 : return m_aKey;
435 : }
436 :
437 : // Sorts the TOX entries
438 0 : SwTOXContent::SwTOXContent( const SwTxtNode& rNd, const SwTxtTOXMark* pMark,
439 : const SwTOXInternational& rIntl)
440 0 : : SwTOXSortTabBase( TOX_SORT_CONTENT, &rNd, pMark, &rIntl )
441 : {
442 0 : }
443 :
444 : // The content's text
445 :
446 0 : TextAndReading SwTOXContent::GetText_Impl() const
447 : {
448 0 : const sal_Int32* pEnd = pTxtMark->End();
449 0 : if( pEnd && !pTxtMark->GetTOXMark().IsAlternativeText() )
450 : {
451 : return TextAndReading(
452 0 : ((SwTxtNode*)aTOXSources[0].pNd)->GetExpandTxt(
453 0 : pTxtMark->GetStart(),
454 0 : *pEnd - pTxtMark->GetStart() ),
455 0 : pTxtMark->GetTOXMark().GetTextReading());
456 : }
457 :
458 0 : return TextAndReading(pTxtMark->GetTOXMark().GetAlternativeText(), OUString());
459 : }
460 :
461 0 : void SwTOXContent::FillText( SwTxtNode& rNd, const SwIndex& rInsPos, sal_uInt16 ) const
462 : {
463 0 : const sal_Int32* pEnd = pTxtMark->End();
464 0 : if( pEnd && !pTxtMark->GetTOXMark().IsAlternativeText() )
465 0 : ((SwTxtNode*)aTOXSources[0].pNd)->GetExpandTxt( rNd, &rInsPos,
466 0 : pTxtMark->GetStart(),
467 0 : *pEnd - pTxtMark->GetStart() );
468 : else
469 : {
470 0 : rNd.InsertText( GetTxt().sText, rInsPos );
471 : }
472 0 : }
473 :
474 : // The level for displaying it
475 :
476 0 : sal_uInt16 SwTOXContent::GetLevel() const
477 : {
478 0 : return pTxtMark->GetTOXMark().GetLevel();
479 : }
480 :
481 : // TOX assembled from paragraphs
482 : // Watch out for OLE/graphics when sorting!
483 : // The position must not come from the document, but from the "anchor"!
484 6 : SwTOXPara::SwTOXPara( const SwCntntNode& rNd, SwTOXElement eT, sal_uInt16 nLevel, const OUString& sSeqName )
485 : : SwTOXSortTabBase( TOX_SORT_PARA, &rNd, 0, 0 ),
486 : eType( eT ),
487 : m_nLevel(nLevel),
488 : nStartIndex(0),
489 : nEndIndex(-1),
490 6 : m_sSequenceName( sSeqName )
491 : {
492 6 : }
493 :
494 6 : TextAndReading SwTOXPara::GetText_Impl() const
495 : {
496 6 : const SwCntntNode* pNd = aTOXSources[0].pNd;
497 6 : switch( eType )
498 : {
499 : case nsSwTOXElement::TOX_SEQUENCE:
500 : case nsSwTOXElement::TOX_TEMPLATE:
501 : case nsSwTOXElement::TOX_OUTLINELEVEL:
502 : {
503 : return TextAndReading(((SwTxtNode*)pNd)->GetExpandTxt(
504 : nStartIndex,
505 6 : nEndIndex == -1 ? -1 : nEndIndex - nStartIndex),
506 12 : OUString());
507 : }
508 : break;
509 :
510 : case nsSwTOXElement::TOX_OLE:
511 : case nsSwTOXElement::TOX_GRAPHIC:
512 : case nsSwTOXElement::TOX_FRAME:
513 : {
514 : // Find the FlyFormat; the object/graphic name is there
515 0 : SwFrmFmt* pFly = pNd->GetFlyFmt();
516 0 : if( pFly )
517 0 : return TextAndReading(pFly->GetName(), OUString());
518 :
519 : OSL_ENSURE( false, "Graphic/object without name" );
520 0 : sal_uInt16 nId = nsSwTOXElement::TOX_OLE == eType
521 : ? STR_OBJECT_DEFNAME
522 0 : : nsSwTOXElement::TOX_GRAPHIC == eType
523 : ? STR_GRAPHIC_DEFNAME
524 0 : : STR_FRAME_DEFNAME;
525 0 : return TextAndReading(SW_RESSTR( nId ), OUString());
526 : }
527 : break;
528 0 : default: break;
529 : }
530 0 : return TextAndReading();
531 : }
532 :
533 0 : void SwTOXPara::FillText( SwTxtNode& rNd, const SwIndex& rInsPos, sal_uInt16 ) const
534 : {
535 0 : if( nsSwTOXElement::TOX_TEMPLATE == eType || nsSwTOXElement::TOX_SEQUENCE == eType || nsSwTOXElement::TOX_OUTLINELEVEL == eType)
536 : {
537 0 : SwTxtNode* pSrc = (SwTxtNode*)aTOXSources[0].pNd;
538 : pSrc->GetExpandTxt( rNd, &rInsPos, nStartIndex,
539 0 : nEndIndex == -1 ? -1 : nEndIndex - nStartIndex,
540 0 : false, false, true );
541 : }
542 : else
543 : {
544 0 : rNd.InsertText( GetTxt().sText.replace('\t', ' '), rInsPos );
545 : }
546 0 : }
547 :
548 12 : sal_uInt16 SwTOXPara::GetLevel() const
549 : {
550 12 : sal_uInt16 nRet = m_nLevel;
551 12 : const SwCntntNode* pNd = aTOXSources[0].pNd;
552 :
553 12 : if( nsSwTOXElement::TOX_OUTLINELEVEL == eType && pNd->GetTxtNode() )
554 : {
555 12 : const int nTmp = ((SwTxtNode*)pNd)->GetAttrOutlineLevel();
556 12 : if(nTmp != 0 )
557 12 : nRet = static_cast<sal_uInt16>(nTmp);
558 : }
559 12 : return nRet;
560 : }
561 :
562 6 : OUString SwTOXPara::GetURL() const
563 : {
564 6 : OUString aTxt;
565 6 : const SwCntntNode* pNd = aTOXSources[0].pNd;
566 6 : switch( eType )
567 : {
568 : case nsSwTOXElement::TOX_TEMPLATE:
569 : case nsSwTOXElement::TOX_OUTLINELEVEL:
570 : {
571 6 : const SwTxtNode * pTxtNd = static_cast<const SwTxtNode *>(pNd);
572 :
573 6 : SwDoc* pDoc = const_cast<SwDoc*>( pTxtNd->GetDoc() );
574 6 : ::sw::mark::IMark const * const pMark = pDoc->getIDocumentMarkAccess()->getMarkForTxtNode(
575 : *(pTxtNd),
576 6 : IDocumentMarkAccess::CROSSREF_HEADING_BOOKMARK);
577 6 : aTxt = "#" + pMark->GetName();
578 : }
579 6 : break;
580 :
581 : case nsSwTOXElement::TOX_OLE:
582 : case nsSwTOXElement::TOX_GRAPHIC:
583 : case nsSwTOXElement::TOX_FRAME:
584 : {
585 : // Find the FlyFormat; the object/graphic name is there
586 0 : SwFrmFmt* pFly = pNd->GetFlyFmt();
587 0 : if( pFly )
588 : {
589 0 : aTxt = "#" + pFly->GetName() + OUString(cMarkSeparator);
590 : const sal_Char* pStr;
591 0 : switch( eType )
592 : {
593 0 : case nsSwTOXElement::TOX_OLE: pStr = "ole"; break;
594 0 : case nsSwTOXElement::TOX_GRAPHIC: pStr = "graphic"; break;
595 0 : case nsSwTOXElement::TOX_FRAME: pStr = "frame"; break;
596 0 : default: pStr = 0;
597 : }
598 0 : if( pStr )
599 0 : aTxt += OUString::createFromAscii( pStr );
600 : }
601 : }
602 0 : break;
603 : case nsSwTOXElement::TOX_SEQUENCE:
604 : {
605 0 : aTxt = "#" + m_sSequenceName + OUString(cMarkSeparator)
606 0 : + "sequence";
607 : }
608 0 : break;
609 0 : default: break;
610 : }
611 6 : return aTxt;
612 : }
613 :
614 : // Table
615 0 : SwTOXTable::SwTOXTable( const SwCntntNode& rNd )
616 : : SwTOXSortTabBase( TOX_SORT_TABLE, &rNd, 0, 0 ),
617 0 : nLevel(FORM_ALPHA_DELIMITTER)
618 : {
619 0 : }
620 :
621 0 : TextAndReading SwTOXTable::GetText_Impl() const
622 : {
623 0 : const SwNode* pNd = aTOXSources[0].pNd;
624 0 : if( pNd )
625 : {
626 : const SwTableNode* pTableNd =
627 0 : reinterpret_cast<const SwTableNode*>(pNd->FindTableNode());
628 0 : if (pTableNd)
629 : {
630 0 : return TextAndReading(pTableNd->GetTable().GetFrmFmt()->GetName(), OUString());
631 : }
632 : }
633 :
634 : OSL_ENSURE( false, "Where's my table?" );
635 0 : return TextAndReading(SW_RESSTR( STR_TABLE_DEFNAME ), OUString());
636 : }
637 :
638 0 : sal_uInt16 SwTOXTable::GetLevel() const
639 : {
640 0 : return nLevel;
641 : }
642 :
643 0 : OUString SwTOXTable::GetURL() const
644 : {
645 0 : const SwNode* pNd = aTOXSources[0].pNd;
646 0 : if (!pNd)
647 0 : return OUString();
648 :
649 0 : pNd = pNd->FindTableNode();
650 0 : if (!pNd)
651 0 : return OUString();
652 :
653 0 : const OUString sName = ((SwTableNode*)pNd)->GetTable().GetFrmFmt()->GetName();
654 0 : if ( sName.isEmpty() )
655 0 : return OUString();
656 :
657 0 : return "#" + sName + OUString(cMarkSeparator) + "table";
658 : }
659 :
660 0 : SwTOXAuthority::SwTOXAuthority( const SwCntntNode& rNd,
661 : SwFmtFld& rField, const SwTOXInternational& rIntl ) :
662 : SwTOXSortTabBase( TOX_SORT_AUTHORITY, &rNd, 0, &rIntl ),
663 0 : m_rField(rField)
664 : {
665 0 : if(rField.GetTxtFld())
666 0 : nCntPos = rField.GetTxtFld()->GetStart();
667 0 : }
668 :
669 0 : sal_uInt16 SwTOXAuthority::GetLevel() const
670 : {
671 0 : OUString sText(((SwAuthorityField*)m_rField.GetField())->GetFieldText(AUTH_FIELD_AUTHORITY_TYPE));
672 : //#i18655# the level '0' is the heading level therefore the values are incremented here
673 0 : sal_uInt16 nRet = 1;
674 0 : if( pTOXIntl->IsNumeric( sText ) )
675 : {
676 0 : nRet = (sal_uInt16)sText.toInt32();
677 0 : nRet++;
678 : }
679 : //illegal values are also set to 'ARTICLE' as non-numeric values are
680 0 : if(nRet > AUTH_TYPE_END)
681 0 : nRet = 1;
682 0 : return nRet;
683 : }
684 :
685 0 : static OUString lcl_GetText(SwFmtFld const& rField)
686 : {
687 0 : return rField.GetField()->ExpandField(true);
688 : }
689 :
690 0 : TextAndReading SwTOXAuthority::GetText_Impl() const
691 : {
692 0 : return TextAndReading(lcl_GetText(m_rField), OUString());
693 : }
694 :
695 0 : void SwTOXAuthority::FillText( SwTxtNode& rNd,
696 : const SwIndex& rInsPos, sal_uInt16 nAuthField ) const
697 : {
698 0 : SwAuthorityField* pField = (SwAuthorityField*)m_rField.GetField();
699 0 : OUString sText;
700 0 : if(AUTH_FIELD_IDENTIFIER == nAuthField)
701 : {
702 0 : sText = lcl_GetText(m_rField);
703 0 : const SwAuthorityFieldType* pType = (const SwAuthorityFieldType*)pField->GetTyp();
704 0 : sal_Unicode cChar = pType->GetPrefix();
705 0 : if(cChar && cChar != ' ')
706 0 : sText = sText.copy(1);
707 0 : cChar = pType->GetSuffix();
708 0 : if(cChar && cChar != ' ')
709 0 : sText = sText.copy(0, sText.getLength() - 1);
710 : }
711 0 : else if(AUTH_FIELD_AUTHORITY_TYPE == nAuthField)
712 : {
713 0 : sal_uInt16 nLevel = GetLevel();
714 0 : if(nLevel)
715 0 : sText = SwAuthorityFieldType::GetAuthTypeName((ToxAuthorityType) --nLevel);
716 : }
717 : else
718 0 : sText = (pField->GetFieldText((ToxAuthorityField) nAuthField));
719 0 : rNd.InsertText( sText, rInsPos );
720 0 : }
721 :
722 0 : bool SwTOXAuthority::operator==( const SwTOXSortTabBase& rCmp)
723 : {
724 0 : return nType == rCmp.nType &&
725 0 : ((SwAuthorityField*)m_rField.GetField())->GetHandle() ==
726 0 : ((SwAuthorityField*)((SwTOXAuthority&)rCmp).m_rField.GetField())->GetHandle();
727 : }
728 :
729 0 : bool SwTOXAuthority::operator<( const SwTOXSortTabBase& rBase)
730 : {
731 0 : bool bRet = false;
732 0 : SwAuthorityField* pField = (SwAuthorityField*)m_rField.GetField();
733 : SwAuthorityFieldType* pType = (SwAuthorityFieldType*)
734 0 : pField->GetTyp();
735 0 : if(pType->IsSortByDocument())
736 0 : bRet = SwTOXSortTabBase::operator<(rBase);
737 : else
738 : {
739 : SwAuthorityField* pCmpField =
740 0 : (SwAuthorityField*)((SwTOXAuthority&)rBase).m_rField.GetField();
741 :
742 0 : for(sal_uInt16 i = 0; i < pType->GetSortKeyCount(); i++)
743 : {
744 0 : const SwTOXSortKey* pKey = pType->GetSortKey(i);
745 0 : const TextAndReading aMy(pField->GetFieldText(pKey->eField), OUString());
746 0 : const TextAndReading aOther(pCmpField->GetFieldText(pKey->eField), OUString());
747 :
748 0 : sal_Int32 nComp = pTOXIntl->Compare( aMy, GetLocale(),
749 0 : aOther, rBase.GetLocale() );
750 :
751 0 : if( nComp )
752 : {
753 0 : bRet = (-1 == nComp) == pKey->bSortAscending;
754 0 : break;
755 : }
756 0 : }
757 : }
758 0 : return bRet;
759 270 : }
760 :
761 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|