2001-04-17 14:06:11 +00:00
|
|
|
// -*- C++ -*-
|
2002-09-05 14:10:50 +00:00
|
|
|
/**
|
2007-04-28 20:44:46 +00:00
|
|
|
* \file ButtonPolicy.h
|
2002-09-05 15:14:23 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
2001-03-22 11:24:36 +00:00
|
|
|
*
|
2002-09-05 14:10:50 +00:00
|
|
|
* \author Allan Rae
|
2001-03-15 13:37:04 +00:00
|
|
|
*
|
2003-08-23 00:17:00 +00:00
|
|
|
* Full author contact details are available in file CREDITS.
|
2001-03-15 13:37:04 +00:00
|
|
|
*
|
2002-09-05 14:10:50 +00:00
|
|
|
* Provides a state machine implementation of the various button policies
|
|
|
|
* used by the dialogs.
|
2001-03-15 13:37:04 +00:00
|
|
|
*/
|
|
|
|
|
2007-04-28 20:44:46 +00:00
|
|
|
#ifndef BUTTONPOLICY_H
|
|
|
|
#define BUTTONPOLICY_H
|
2001-03-15 13:37:04 +00:00
|
|
|
|
2004-05-19 15:11:37 +00:00
|
|
|
namespace lyx {
|
|
|
|
namespace frontend {
|
|
|
|
|
2007-09-02 07:53:07 +00:00
|
|
|
/** A class for button policies.
|
2001-03-15 13:37:04 +00:00
|
|
|
A state machine implementation of the various button policies used by the
|
|
|
|
dialogs. Only the policy is implemented here. Separate ButtonController
|
|
|
|
classes are needed for each GUI implementation.
|
|
|
|
|
2009-01-18 14:37:14 +00:00
|
|
|
Policy | ReadOnly | Apply Button | Repeated Apply
|
2001-03-15 13:37:04 +00:00
|
|
|
========================================================================
|
2007-05-29 16:58:42 +00:00
|
|
|
OkCancel | N | N | -
|
|
|
|
OkCancelReadOnly | Y | N | -
|
|
|
|
OkApplyCancel | N | Y | Y
|
|
|
|
OkApplyCancelReadOnly | Y | Y | Y
|
|
|
|
NoRepeatedApply | N | Y | N
|
|
|
|
NoRepeatedApplyReadOnly | Y | Y | N
|
2009-01-18 14:33:51 +00:00
|
|
|
OkApplyCancelAutoReadOnly | Y | Y | Y
|
2007-05-29 16:58:42 +00:00
|
|
|
Preferences | N | Y | No (Ok-Close)
|
|
|
|
Ignorant | N/A | N/A | N/A
|
2001-03-15 13:37:04 +00:00
|
|
|
========================================================================
|
|
|
|
|
|
|
|
Policy
|
|
|
|
The name of the policy
|
|
|
|
ReadOnly
|
|
|
|
Does the policy treat read-only docs differently to read-write docs?
|
|
|
|
This usually means that when an SMI_READ_ONLY input arrives then
|
|
|
|
all the buttons are disabled except Cancel/Close. The state
|
|
|
|
machine tracks the inputs (valid/invalid) and has states for all
|
|
|
|
combinations. When an SMI_READ_WRITE input arrives the appropriate
|
|
|
|
machine state is entered (just as if the document had always been
|
|
|
|
read-write).
|
|
|
|
NOTE: If a dialog doesn't care about the read-only status of a document
|
|
|
|
(and uses an appropriate policy) it can never get into a read-only state
|
|
|
|
so isReadOnly() can only ever return false even though the document may
|
|
|
|
be read-only.
|
|
|
|
Repeated Apply
|
|
|
|
Simply means that it is alright to use the Apply button multiple times
|
|
|
|
without requiring a change of the dialog contents. If no repeating is
|
|
|
|
allowed the Ok+Apply buttons are deactivated. The Preferences dialog
|
|
|
|
has its own special version of repeated apply handling because its Ok
|
2007-09-01 20:44:14 +00:00
|
|
|
button is actually a Save button -- it is always reasonable to Save the
|
2001-03-15 13:37:04 +00:00
|
|
|
preferences if the dialog has changed since the last save.
|
|
|
|
|
|
|
|
The IgnorantPolicy is a special case that allows anything.
|
|
|
|
*/
|
2007-09-02 07:53:07 +00:00
|
|
|
|
2008-04-19 08:42:56 +00:00
|
|
|
class ButtonPolicy
|
|
|
|
{
|
2001-03-15 13:37:04 +00:00
|
|
|
public:
|
2007-09-02 07:53:07 +00:00
|
|
|
|
|
|
|
// The various poicies
|
2017-07-03 13:45:58 -04:00
|
|
|
enum Policy {
|
2007-09-02 07:53:07 +00:00
|
|
|
/** Ok and Cancel buttons for dialogs with read-only operation.
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close and
|
|
|
|
vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
2009-01-18 14:33:51 +00:00
|
|
|
OkCancelPolicy,
|
2007-09-02 07:53:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
/** Ok and Cancel buttons for dialogs where read-only operation is blocked.
|
|
|
|
The state machine design for this policy allows changes to occur within
|
|
|
|
the dialog while a file is read-only -- the okay button is disabled until
|
|
|
|
a read-write input is given. When the file is made read-write the dialog
|
|
|
|
will then be in the correct state (as if the file had always been
|
|
|
|
read-write).
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
OkCancelReadOnlyPolicy,
|
|
|
|
|
|
|
|
/** Ok, Apply and Cancel buttons for dialogs where read-only operation
|
|
|
|
is blocked.
|
|
|
|
Repeated Apply are not allowed. Likewise, Ok cannot follow Apply without
|
|
|
|
some valid input. That is, the dialog contents must change between
|
|
|
|
each Apply or Apply and Ok.
|
|
|
|
The state machine design for this policy allows changes to occur within
|
|
|
|
the dialog while a file is read-only -- the Ok+Apply buttons are disabled
|
|
|
|
until a read-write input is given. When the file is made read-write the
|
|
|
|
dialog will then be in the correct state (as if the file had always been
|
|
|
|
read-write).
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
NoRepeatedApplyReadOnlyPolicy,
|
|
|
|
|
|
|
|
/** Ok, Apply and Cancel buttons for dialogs where read-only
|
|
|
|
operation is blocked.
|
|
|
|
Repeated Apply is allowed. Likewise, Ok can follow Apply.
|
|
|
|
The state machine design for this policy allows changes to occur within
|
|
|
|
the dialog while a file is read-only -- the Ok+Apply buttons are disabled
|
|
|
|
until a read-write input is given. When the file is made read-write the
|
|
|
|
dialog will then be in the correct state (as if the file had always been
|
|
|
|
read-write).
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
OkApplyCancelReadOnlyPolicy,
|
|
|
|
|
|
|
|
/** Ok, Apply and Cancel buttons for dialogs where repeated
|
2009-01-18 14:33:51 +00:00
|
|
|
Apply is allowed.
|
2007-09-02 07:53:07 +00:00
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
OkApplyCancelPolicy,
|
|
|
|
|
|
|
|
/** Ok, Apply and Cancel buttons for dialogs with no repeated Apply.
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
NoRepeatedApplyPolicy,
|
|
|
|
|
2009-01-18 14:33:51 +00:00
|
|
|
/** Ok, Apply and Cancel buttons and an AutoApply checkbox.
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
OkApplyCancelAutoReadOnlyPolicy,
|
|
|
|
|
2007-09-02 07:53:07 +00:00
|
|
|
/** Defines the policy used by the Preferences dialog.
|
|
|
|
Four buttons: Ok (Save), Apply, Cancel/Close, Restore.
|
|
|
|
Note: This scheme supports the relabelling of Cancel to Close
|
|
|
|
and vice versa.
|
|
|
|
This is based on the value of the bool state of the Button::CANCEL.
|
|
|
|
true == Cancel, false == Close
|
|
|
|
*/
|
|
|
|
PreferencesPolicy,
|
|
|
|
|
|
|
|
/** Defines the policy used by dialogs that are forced to support a button
|
|
|
|
controller when they either don't have a use for one or are not ready to
|
|
|
|
use one. This may be useful when testing a new button policy but wishing
|
|
|
|
to minimise problems to users by supplying an anything-goes policy via a
|
|
|
|
preprocessor directive.
|
|
|
|
*/
|
2010-12-17 19:56:51 +00:00
|
|
|
IgnorantPolicy
|
2007-09-02 07:53:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Constructor
|
|
|
|
explicit ButtonPolicy(Policy policy);
|
2008-04-19 08:42:56 +00:00
|
|
|
/// Destructor
|
|
|
|
~ButtonPolicy();
|
|
|
|
///
|
|
|
|
void setPolicy(Policy policy);
|
2001-03-15 13:37:04 +00:00
|
|
|
|
|
|
|
/** The various possible state names.
|
|
|
|
Not all state-machines have this many states. However, we need
|
|
|
|
to define them all here so we can share the code.
|
|
|
|
*/
|
|
|
|
enum State {
|
|
|
|
///
|
|
|
|
INITIAL = 0,
|
|
|
|
///
|
|
|
|
VALID,
|
|
|
|
///
|
|
|
|
INVALID,
|
|
|
|
///
|
|
|
|
APPLIED,
|
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
AUTOAPPLY_INITIAL,
|
|
|
|
///
|
|
|
|
AUTOAPPLY_CHANGED,
|
|
|
|
///
|
2001-03-15 13:37:04 +00:00
|
|
|
RO_INITIAL,
|
|
|
|
///
|
|
|
|
RO_VALID,
|
|
|
|
///
|
|
|
|
RO_INVALID,
|
|
|
|
///
|
|
|
|
RO_APPLIED,
|
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
RO_AUTOAPPLY,
|
|
|
|
///
|
2001-03-15 13:37:04 +00:00
|
|
|
BOGUS = 55
|
|
|
|
};
|
2002-03-21 21:21:28 +00:00
|
|
|
|
2001-03-15 13:37:04 +00:00
|
|
|
/// The various button types.
|
|
|
|
enum Button {
|
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
CLOSE = 0, // Not a real button, but effectively !CANCEL
|
|
|
|
///
|
|
|
|
OKAY = 1,
|
2001-03-15 13:37:04 +00:00
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
APPLY = 2,
|
2001-03-15 13:37:04 +00:00
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
CANCEL = 4,
|
2001-03-15 13:37:04 +00:00
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
RESTORE = 8,
|
2001-03-15 13:37:04 +00:00
|
|
|
///
|
2009-01-18 14:33:51 +00:00
|
|
|
AUTOAPPLY = 16 // This is usually a checkbox
|
2001-03-15 13:37:04 +00:00
|
|
|
};
|
|
|
|
///
|
|
|
|
static const Button ALL_BUTTONS =
|
2009-01-18 14:33:51 +00:00
|
|
|
Button(OKAY | APPLY | CANCEL | RESTORE | AUTOAPPLY);
|
2002-03-21 21:21:28 +00:00
|
|
|
|
2001-03-15 13:37:04 +00:00
|
|
|
/** State machine inputs.
|
|
|
|
All the policies so far have both CANCEL and HIDE always going to
|
|
|
|
INITIAL. This won't necessarily be true for all [future] policies
|
|
|
|
though so I'll leave those two as distinct inputs rather than merge
|
|
|
|
them. For example, a dialog that doesn't update it's input fields
|
|
|
|
when reshown after being hidden needs a policy where CANCEL and
|
|
|
|
HIDE are treated differently.
|
|
|
|
*/
|
|
|
|
enum SMInput {
|
2001-04-03 14:30:58 +00:00
|
|
|
/// the dialog contents are now valid
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_VALID = 0,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// the dialog contents are now invalid
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_INVALID,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// an apply-and-hide action has happened
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_OKAY,
|
2002-03-21 21:21:28 +00:00
|
|
|
/// an apply action has happened
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_APPLY,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// a cancel action has happened
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_CANCEL,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// a restore action has happened
|
|
|
|
SMI_RESTORE,
|
2009-01-18 14:33:51 +00:00
|
|
|
/// apply auto-apply
|
|
|
|
SMI_AUTOAPPLY,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// the dialog has been hidden
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_HIDE,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// the dialog contents are read-only
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_READ_ONLY,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// the dialog contents can be modified
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_READ_WRITE,
|
2002-03-21 21:21:28 +00:00
|
|
|
/// the state of the dialog contents has not changed
|
2001-03-15 13:37:04 +00:00
|
|
|
SMI_NOOP,
|
2001-04-03 14:30:58 +00:00
|
|
|
/// for internal use
|
|
|
|
SMI_TOTAL
|
2001-03-15 13:37:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Trigger a transition with this input.
|
2007-09-02 07:53:07 +00:00
|
|
|
void input(SMInput);
|
2001-03-15 13:37:04 +00:00
|
|
|
/** Activation status of a button.
|
|
|
|
We assume that we haven't gotten into an undefined state.
|
|
|
|
This is reasonable since we can only reach states defined
|
|
|
|
in the state machine and they should all have been defined in
|
|
|
|
the outputs_ variable. Perhaps we can do something at compile
|
|
|
|
time to check that all the states have corresponding outputs.
|
|
|
|
*/
|
2007-09-02 07:53:07 +00:00
|
|
|
bool buttonStatus(Button) const;
|
2001-03-15 13:37:04 +00:00
|
|
|
/// Are we in a read-only state?
|
2007-09-02 07:53:07 +00:00
|
|
|
bool isReadOnly() const;
|
2002-03-21 21:21:28 +00:00
|
|
|
|
2001-03-15 13:37:04 +00:00
|
|
|
private:
|
2008-04-19 08:42:56 +00:00
|
|
|
/// noncopyable
|
|
|
|
ButtonPolicy(ButtonPolicy const &);
|
|
|
|
void operator=(ButtonPolicy const &);
|
2017-07-03 13:45:58 -04:00
|
|
|
|
2008-04-19 08:42:56 +00:00
|
|
|
/// pimpl
|
|
|
|
class Private;
|
|
|
|
Private * d;
|
2001-03-15 13:37:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2004-05-19 15:11:37 +00:00
|
|
|
} // namespace frontend
|
|
|
|
} // namespace lyx
|
|
|
|
|
2001-03-15 13:37:04 +00:00
|
|
|
#endif
|