2003-02-17 17:12:50 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
/**
|
|
|
|
* \file insetbase.h
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
*
|
|
|
|
* \author none
|
|
|
|
*
|
2003-08-23 00:17:00 +00:00
|
|
|
* Full author contact details are available in file CREDITS.
|
2003-02-17 17:12:50 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef INSETBASE_H
|
|
|
|
#define INSETBASE_H
|
|
|
|
|
2003-10-06 15:43:21 +00:00
|
|
|
#include <string>
|
2003-02-18 11:47:16 +00:00
|
|
|
#include <vector>
|
2003-07-27 15:52:05 +00:00
|
|
|
#include <memory>
|
2003-02-18 11:47:16 +00:00
|
|
|
|
2003-09-18 20:18:39 +00:00
|
|
|
class Buffer;
|
2003-03-10 13:33:39 +00:00
|
|
|
class BufferView;
|
2003-02-18 11:47:16 +00:00
|
|
|
class FuncRequest;
|
2003-05-30 06:48:24 +00:00
|
|
|
class MetricsInfo;
|
2003-06-02 10:03:27 +00:00
|
|
|
class Dimension;
|
2003-05-30 06:48:24 +00:00
|
|
|
class PainterInfo;
|
2003-06-02 16:14:33 +00:00
|
|
|
class LaTeXFeatures;
|
2003-02-18 11:47:16 +00:00
|
|
|
|
|
|
|
/** Dispatch result codes
|
|
|
|
DISPATCHED = the inset catched the action
|
|
|
|
DISPATCHED_NOUPDATE = the inset catched the action and no update
|
|
|
|
is needed here to redraw the inset
|
|
|
|
FINISHED = the inset must be unlocked as a result
|
|
|
|
of the action
|
|
|
|
FINISHED_RIGHT = FINISHED, but put the cursor to the RIGHT of
|
|
|
|
the inset.
|
|
|
|
FINISHED_UP = FINISHED, but put the cursor UP of
|
|
|
|
the inset.
|
|
|
|
FINISHED_DOWN = FINISHED, but put the cursor DOWN of
|
|
|
|
the inset.
|
|
|
|
UNDISPATCHED = the action was not catched, it should be
|
|
|
|
dispatched by lower level insets
|
|
|
|
*/
|
|
|
|
enum dispatch_result {
|
|
|
|
UNDISPATCHED = 0,
|
|
|
|
DISPATCHED,
|
|
|
|
DISPATCHED_NOUPDATE,
|
|
|
|
FINISHED,
|
|
|
|
FINISHED_RIGHT,
|
|
|
|
FINISHED_UP,
|
|
|
|
FINISHED_DOWN,
|
|
|
|
DISPATCHED_POP
|
|
|
|
};
|
|
|
|
|
2003-09-18 11:21:53 +00:00
|
|
|
/** \c DispatchResult is a wrapper for dispatch_result.
|
|
|
|
* It can be forward-declared and passed as a function argument without
|
|
|
|
* having to expose insetbase.h.
|
|
|
|
*/
|
|
|
|
class DispatchResult {
|
|
|
|
dispatch_result val_;
|
|
|
|
public:
|
|
|
|
DispatchResult(dispatch_result val) : val_(val) {}
|
|
|
|
operator dispatch_result() const{ return val_; }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2003-02-17 17:12:50 +00:00
|
|
|
|
|
|
|
/// Common base class to all insets
|
|
|
|
class InsetBase {
|
|
|
|
public:
|
2003-06-02 10:03:27 +00:00
|
|
|
///
|
|
|
|
typedef int difference_type;
|
|
|
|
/// short of anything else reasonable
|
|
|
|
typedef size_t size_type;
|
2003-02-18 11:47:16 +00:00
|
|
|
/// type for cell indices
|
2003-06-02 10:03:27 +00:00
|
|
|
typedef size_t idx_type;
|
2003-02-18 11:47:16 +00:00
|
|
|
/// type for cursor positions
|
2003-06-02 10:03:27 +00:00
|
|
|
typedef size_t pos_type;
|
2003-02-18 11:47:16 +00:00
|
|
|
/// type for row numbers
|
2003-06-02 10:03:27 +00:00
|
|
|
typedef size_t row_type;
|
2003-02-18 11:47:16 +00:00
|
|
|
/// type for column numbers
|
2003-06-02 10:03:27 +00:00
|
|
|
typedef size_t col_type;
|
2003-02-18 11:47:16 +00:00
|
|
|
|
2003-06-16 11:49:38 +00:00
|
|
|
/// virtual base class destructor
|
|
|
|
virtual ~InsetBase() {}
|
|
|
|
/// replicate ourselves
|
2003-07-25 17:11:25 +00:00
|
|
|
virtual std::auto_ptr<InsetBase> clone() const = 0;
|
2003-06-16 11:49:38 +00:00
|
|
|
|
2003-02-18 11:47:16 +00:00
|
|
|
// the real dispatcher
|
|
|
|
virtual dispatch_result dispatch
|
|
|
|
(FuncRequest const & cmd, idx_type & idx, pos_type & pos);
|
|
|
|
|
|
|
|
/// small wrapper for the time being
|
|
|
|
virtual dispatch_result localDispatch(FuncRequest const & cmd);
|
2003-06-02 10:03:27 +00:00
|
|
|
/// compute the size of the object returned in dim
|
|
|
|
virtual void metrics(MetricsInfo & mi, Dimension & dim) const = 0;
|
|
|
|
/// draw inset and update (xo, yo)-cache
|
2003-05-30 06:48:24 +00:00
|
|
|
virtual void draw(PainterInfo & pi, int x, int y) const = 0;
|
2003-02-17 17:12:50 +00:00
|
|
|
|
2003-06-02 16:14:33 +00:00
|
|
|
/// request "external features"
|
|
|
|
virtual void validate(LaTeXFeatures &) const {}
|
2003-09-18 20:18:39 +00:00
|
|
|
/// Appends \c list with all labels found within this inset.
|
|
|
|
virtual void getLabelList(Buffer const &,
|
2003-10-06 15:43:21 +00:00
|
|
|
std::vector<std::string> & /* list */) const {}
|
2003-02-17 17:12:50 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|