2010-10-14 08:30:41 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2006-08-14 14:14:15 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* 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.
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* 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).
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
2008-04-10 09:41:27 +00:00
|
|
|
* 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.
|
2006-08-14 14:14:15 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
2006-10-11 07:45:25 +00:00
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
#ifndef IDOCUMENTUNDOREDO_HXX_INCLUDED
|
|
|
|
#define IDOCUMENTUNDOREDO_HXX_INCLUDED
|
2006-08-14 14:14:15 +00:00
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
#include <sal/types.h>
|
|
|
|
#include <swundo.hxx>
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
class SwUndoIter;
|
|
|
|
class SwRewriter;
|
|
|
|
class String;
|
|
|
|
class SwUndoIds;
|
|
|
|
class SwNodes;
|
|
|
|
class SwUndo;
|
2007-05-25 11:59:33 +00:00
|
|
|
|
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
typedef sal_uInt16 SwUndoNoModifiedPosition;
|
|
|
|
|
|
|
|
/** IDocumentUndoRedo
|
|
|
|
*/
|
|
|
|
class IDocumentUndoRedo
|
|
|
|
{
|
|
|
|
public:
|
2006-08-14 14:14:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual void SetUndoNoResetModified() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual bool IsUndoNoResetModified() const = 0;
|
|
|
|
|
|
|
|
/** UndoHistory am Dokument pflegen
|
|
|
|
bei Save, SaveAs, Create wird UndoHistory zurueckgesetzt ???
|
|
|
|
*/
|
|
|
|
virtual void DoUndo(bool bUn) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual bool DoesUndo() const = 0;
|
|
|
|
|
|
|
|
/** Zusammenfassen von Kontinuierlichen Insert/Delete/Overwrite von
|
|
|
|
Charaktern. Default ist ::com::sun::star::sdbcx::Group-Undo.
|
|
|
|
*/
|
|
|
|
virtual void DoGroupUndo(bool bUn) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual bool DoesGroupUndo() const = 0;
|
|
|
|
|
|
|
|
/** macht rueckgaengig:
|
|
|
|
0 letzte Aktion, sonst Aktionen bis zum Start der Klammerung nUndoId
|
|
|
|
In rUndoRange wird der restaurierte Bereich gesetzt.
|
|
|
|
*/
|
|
|
|
virtual bool Undo( SwUndoIter& ) = 0; // -> #111827#
|
|
|
|
|
|
|
|
/** Opens undo block.
|
|
|
|
|
|
|
|
@param nUndoId undo ID for the start object
|
|
|
|
@param pRewriter rewriter for comments @see SwUndo::GetComment
|
|
|
|
|
|
|
|
If the given nUndoId is equal to zero an undo object with ID
|
|
|
|
UNDO_START will be generated.
|
|
|
|
|
|
|
|
@return the undo ID of the created object
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndoId StartUndo( SwUndoId eUndoId, const SwRewriter * pRewriter) = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Closes undo block.
|
|
|
|
|
|
|
|
@param nUndoId undo ID for the closure object
|
|
|
|
@param pRewriter rewriter for comments @see SwUndo::GetComment
|
|
|
|
|
|
|
|
If the given nUndoId is equal to zero an undo object with ID
|
|
|
|
UNDO_START will be generated.
|
|
|
|
|
|
|
|
If pRewriter is not equal to zero the given rewriter will be
|
|
|
|
set for the generated closure object and the corresponding
|
|
|
|
start object. Otherwise an existent rewriter in theIDocumentRedlineAccess
|
|
|
|
corresponding start object will be propagated to the generated
|
|
|
|
closure object.
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndoId EndUndo( SwUndoId eUndoId, const SwRewriter * pRewriter) = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/** <- #111827#
|
|
|
|
loescht die gesamten UndoObjecte ( fuer Methoden die am Nodes
|
|
|
|
Array drehen ohne entsprechendes Undo !!)
|
|
|
|
*/
|
|
|
|
virtual void DelAllUndoObj() = 0;
|
|
|
|
|
|
|
|
/** liefert die Id der letzten undofaehigen Aktion zurueck
|
|
|
|
oder USHRT_MAX fuellt ggf. VARARR mit ::com::sun::star::sdbcx::User-UndoIds
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndoId GetUndoIds(String* pStr, SwUndoIds *pUndoIds) const = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual String GetUndoIdsStr(String* pStr, SwUndoIds *pUndoIds) const = 0;
|
|
|
|
|
|
|
|
/** gibt es Klammerung mit der Id?
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual bool HasUndoId(SwUndoId eId) const = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/* @@@MAINTAINABILITY-HORROR@@@
|
|
|
|
Implementation details made public.
|
|
|
|
die drei folgenden Methoden werden beim Undo und nur dort
|
|
|
|
benoetigt. Sollten sonst nicht aufgerufen werden.
|
|
|
|
*/
|
|
|
|
virtual const SwNodes* GetUndoNds() const = 0;
|
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndo* RemoveLastUndo(SwUndoId eUndoId) = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/** 2002-05-31 dvo, #95884#: To prevent an undo array overflow when
|
|
|
|
doing nested undos, undo may have to be disabled. Undo-intensive
|
|
|
|
actions (like auto-format) should check this manually.
|
|
|
|
*/
|
|
|
|
virtual bool HasTooManyUndos() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual bool Redo( SwUndoIter& ) = 0;
|
|
|
|
|
|
|
|
/** liefert die Id der letzten Redofaehigen Aktion zurueck
|
|
|
|
fuellt ggf. VARARR mit RedoIds
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndoId GetRedoIds( String* pStr, SwUndoIds *pRedoIds) const = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual String GetRedoIdsStr( String* pStr, SwUndoIds *pRedoIds) const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual bool Repeat( SwUndoIter&, sal_uInt16 nRepeatCnt) = 0;
|
|
|
|
|
|
|
|
/** liefert die Id der letzten Repeatfaehigen Aktion zurueck
|
|
|
|
fuellt ggf. VARARR mit RedoIds
|
|
|
|
*/
|
2007-09-27 06:54:26 +00:00
|
|
|
virtual SwUndoId GetRepeatIds( String* pStr, SwUndoIds *pRedoIds) const = 0;
|
2006-08-14 14:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
virtual String GetRepeatIdsStr( String* pStr, SwUndoIds *pRedoIds) const = 0;
|
|
|
|
|
|
|
|
/** interne Verkuerzung fuer Insert am Ende
|
|
|
|
*/
|
|
|
|
virtual void AppendUndo(SwUndo*) = 0;
|
|
|
|
|
|
|
|
/** loescht alle UndoObjecte von nUndoPos
|
|
|
|
bis zum Ende des Undo-Arrays
|
|
|
|
*/
|
|
|
|
virtual void ClearRedo() = 0;
|
|
|
|
|
2007-05-25 11:59:33 +00:00
|
|
|
/** Manipulates the position of the undo stack which reset the modified flag
|
|
|
|
*/
|
|
|
|
virtual void setUndoNoModifiedPosition( SwUndoNoModifiedPosition ) = 0;
|
|
|
|
|
|
|
|
/** Gets the position of the undo stack which reset the modified flag
|
|
|
|
*/
|
|
|
|
virtual SwUndoNoModifiedPosition getUndoNoModifiedPosition() const = 0;
|
|
|
|
|
2007-09-27 06:54:26 +00:00
|
|
|
protected:
|
2006-08-14 14:14:15 +00:00
|
|
|
virtual ~IDocumentUndoRedo() {};
|
2007-09-27 06:54:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|
2006-08-14 14:14:15 +00:00
|
|
|
|
2010-10-14 08:30:41 +02:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|