1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef _UNOCRSR_HXX
#define _UNOCRSR_HXX
#include <swcrsr.hxx>
#include <calbck.hxx>
class SwUnoCrsr : public virtual SwCursor, public SwModify
{
BOOL bRemainInSection : 1;
BOOL bSkipOverHiddenSections : 1;
BOOL bSkipOverProtectSections : 1;
public:
SwUnoCrsr( const SwPosition &rPos, SwPaM* pRing = 0 );
virtual ~SwUnoCrsr();
// @@@ semantic: no copy ctor.
SwUnoCrsr( SwUnoCrsr& );
private:
// forbidden and not implemented.
//SwUnoCrsr( const SwUnoCrsr& );
SwUnoCrsr & operator= ( const SwUnoCrsr& );
protected:
virtual const SwCntntFrm* DoSetBidiLevelLeftRight(
BOOL & io_rbLeft, BOOL bVisualAllowed, BOOL bInsertCrsr);
virtual void DoSetBidiLevelUpDown();
public:
// virtual SwCursor* Create( SwPaM* pRing = 0 ) const;
// gibt es eine Selection vom Content in die Tabelle
// Return Wert gibt an, ob der Crsr auf der alten Position verbleibt
virtual BOOL IsSelOvr( int eFlags =
( nsSwCursorSelOverFlags::SELOVER_CHECKNODESSECTION |
nsSwCursorSelOverFlags::SELOVER_TOGGLE |
nsSwCursorSelOverFlags::SELOVER_CHANGEPOS ));
virtual bool IsReadOnlyAvailable() const;
BOOL IsRemainInSection() const { return bRemainInSection; }
void SetRemainInSection( BOOL bFlag ) { bRemainInSection = bFlag; }
virtual BOOL IsSkipOverProtectSections() const
{ return bSkipOverProtectSections; }
void SetSkipOverProtectSections( BOOL bFlag )
{ bSkipOverProtectSections = bFlag; }
virtual BOOL IsSkipOverHiddenSections() const
{ return bSkipOverHiddenSections; }
void SetSkipOverHiddenSections( BOOL bFlag )
{ bSkipOverHiddenSections = bFlag; }
// make copy of cursor
virtual SwUnoCrsr * Clone() const;
DECL_FIXEDMEMPOOL_NEWDEL( SwUnoCrsr )
};
class SwUnoTableCrsr : public virtual SwUnoCrsr, public virtual SwTableCursor
{
// die Selection hat die gleiche Reihenfolge wie die
// TabellenBoxen. D.h., wird aus dem einen Array an einer Position
// etwas geloescht, dann muss es auch im anderen erfolgen!!
SwCursor aTblSel;
using SwTableCursor::MakeBoxSels;
public:
SwUnoTableCrsr( const SwPosition& rPos );
virtual ~SwUnoTableCrsr();
// virtual SwCursor* Create( SwPaM* pRing = 0 ) const;
// gibt es eine Selection vom Content in die Tabelle
// Return Wert gibt an, ob der Crsr auf der alten Position verbleibt
virtual BOOL IsSelOvr( int eFlags =
( nsSwCursorSelOverFlags::SELOVER_CHECKNODESSECTION |
nsSwCursorSelOverFlags::SELOVER_TOGGLE |
nsSwCursorSelOverFlags::SELOVER_CHANGEPOS ));
virtual SwUnoTableCrsr * Clone() const;
void MakeBoxSels();
SwCursor& GetSelRing() { return aTblSel; }
const SwCursor& GetSelRing() const { return aTblSel; }
};
#endif
|