X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fbufferview_funcs.h;h=161ed4a5ef6805355ef1529e7afc24b3f181691f;hb=66561205e371dcd755f2187d562872c08ea582da;hp=264b4b2f0716a9f5de3ae29768dfb05f531c30dc;hpb=4faa9e29cf9d341bd1ab84e0e1a99985f2cceac2;p=lyx.git diff --git a/src/bufferview_funcs.h b/src/bufferview_funcs.h index 264b4b2f07..161ed4a5ef 100644 --- a/src/bufferview_funcs.h +++ b/src/bufferview_funcs.h @@ -15,88 +15,61 @@ #define BUFFERVIEW_FUNCS_H #include +#include +namespace lyx { +class Point; class BufferView; -class LyXFont; -class LyXText; -class PosIterator; - +class DocIterator; +class Inset_code; +class Font; namespace bv_funcs { -/** Set \param data using \param font and \param toggle. - * If successful, returns true. - */ -bool font2string(LyXFont const & font, bool toggle, std::string & data); -/** Set \param font and \param toggle using \param data. - * If successful, returns true. - */ -bool string2font(std::string const & data, LyXFont & font, bool & toggle); +/// Set \param data using \param font and \param toggle. Return success. +bool font2string(Font const & font, bool toggle, std::string & data); + +/// Set \param font and \param toggle using \param data. Return success. +bool string2font(std::string const & data, Font & font, bool & toggle); + /** Returns the current freefont, encoded as a std::string to be passed to the * frontends. */ std::string const freefont2string(); -/** Set the freefont using the contents of \param data dispatched from - * the frontends and apply it at the current cursor location. - */ -void update_and_apply_freefont(BufferView * bv, std::string const & data); -/** Apply the contents of freefont at the current cursor location. - */ -void apply_freefont(BufferView * bv); +Point getPos(BufferView const & bv, DocIterator const & dit, bool boundary); -void put_selection_at(BufferView * bv, PosIterator & cur, - int length, bool backwards); +enum CurStatus { + CUR_INSIDE, + CUR_ABOVE, + CUR_BELOW +}; -/// what type of depth change to make -enum DEPTH_CHANGE { - INC_DEPTH, - DEC_DEPTH -}; +CurStatus status(BufferView const * bv, DocIterator const & dit); -/** - * Increase or decrease the nesting depth of the selected paragraph(s) - * if test_only, don't change any depths. Returns whether something - * (would have) changed - */ -extern bool changeDepth(BufferView *, LyXText *, DEPTH_CHANGE, bool test_only); - -/// -extern void emph(BufferView *); -/// -extern void bold(BufferView *); -/// -extern void noun(BufferView *); -/// -extern void lang(BufferView *, std::string const &); -/// -extern void number(BufferView *); -/// -extern void tex(BufferView *); -/// -extern void code(BufferView *); -/// -extern void sans(BufferView *); -/// -extern void roman(BufferView *); -/// -extern void styleReset(BufferView *); -/// -extern void underline(BufferView *); -/// -extern void fontSize(BufferView *, std::string const &); -/// Returns the current font and depth as a message. -extern std::string const currentState(BufferView *); -/// -extern void toggleAndShow(BufferView *, LyXFont const &, - bool toggleall = true); -/// replace selection with insertion -extern void replaceSelection(LyXText * lt); - - - -}; // namespace bv_funcs + +Point coordOffset(BufferView const & bv, DocIterator const & dit, bool boundary); + +/// Moves cursor to the next inset with one of the given codes. +void gotoInset(BufferView * bv, std::vector const & codes, + bool same_content); + +/// Moves cursor to the next inset with given code. +void gotoInset(BufferView * bv, Inset_code code, bool same_content); + +/// Looks for next inset with one of the the given code +bool findInset(DocIterator & dit, std::vector const & codes, + bool same_content); + +/// Looks for next inset with the given code +void findInset(DocIterator & dit, Inset_code code, bool same_content); + + +} // namespace bv_funcs + + +} // namespace lyx #endif