// -*- C++ -*- /* This file is part of * ====================================================== * * LyX, The Document Processor * Copyright (C) 1995 Matthias Ettrich * * This file is Copyleft (C) 1996 * Lars Gullik Bjønnes *
*======================================================*/
/** The buffer object. The is is the buffer object. It contains all the informations about a document loaded into LyX. I am not sure if the class is complete or minimal, probably not.
*/ class Buffer { public: /**@name Constructors and destructor */ //@{ ///
Buffer(LString const & file, LyXRC * lyxrc = NULL, bool b= false);
///
~Buffer(); //@}
/**@name Methods */ //@{
/** save the buffer's parameters as user default This function saves a file user_lyxdir/templates/defaults.lyx which parameters are those of the current buffer. This file is used as a default template when creating a new file. Returns true on success.
*/ bool saveParamsAsDefaults();
/// should be changed to work for a list. void resize()
{ if (users) {
users->resize();
} elseif (text) { delete text;
text = 0;
}
}
/// Update window titles of all users void updateTitles();
/// Reset autosave timers for all users void resetAutosaveTimers();
/** Adds the BufferView to the users list. Later this func will insert the BufferView into a real list, not just setting a pointer.
*/ void addUser(BufferView *u) { users = u; }
/** Removes the BufferView from the users list. Since we only can have one at the moment, we just reset it.
*/ void delUser(BufferView *){ users = 0; }
/// Open and lock an updatable inset void open_new_inset(UpdatableInset*);
/// void loadAutoSaveFile();
/** Reads a file. Returns false if it fails.
If par is given, the file is inserted. */ bool readFile(LyXLex &, LyXParagraph *par = 0);
/** Reads a file without header. Returns false, if file is not completely read.
If par is given, the file is inserted. */ bool readLyXformat2(LyXLex &,LyXParagraph *par = 0);
/// Inserts a lyx file at cursor position. Returns false if it fails. bool insertLyXFile(LString const & filename);
/// void makeLinuxDocFile(LString const & filename, int column);
/// returns the main language for the buffer (document)
LString GetLanguage() const { return params.language;
}
/// bool isLyxClean() const { return lyx_clean; }
/// bool isDviClean() const { return dvi_clean; }
/// bool isBakClean() const { return bak_clean; }
/// bool isDepClean(LString const & name) const;
/// void markLyxClean() { if (!lyx_clean) {
lyx_clean = true;
updateTitles();
} // if the .lyx file has been saved, we don't need an // autosave
bak_clean = true;
}
/// Change name of buffer. Updates "read-only" flag. void setFileName(LString const & newfile);
/// Is buffer read-only? bool isReadonly() { return read_only; }
/// Set buffer read-only flag void setReadonly(bool flag = true)
{ if (read_only != flag) {
read_only = flag;
updateTitles();
updateAllVisibleBufferRelatedPopups();
} if (read_only) {
WarnReadonly();
}
}
/// returns true if the buffer contains a LaTeX document bool isLatex(); /// returns true if the buffer contains a LinuxDoc document bool isLinuxDoc();
/// void setPaperStuff();
/// void setOldPaperStuff();
/** Validate a buffer for LaTeX. This validates the buffer, and returns a struct for use by makeLaTeX and others. Its main use is to figure out what commands and packages need to be included in the LaTeX file. It (should) also check that the needed constructs are there (i.e. that the \refs points to coresponding \labels). It should perhaps inset "error" insets to help the user correct obvious mistakes.
*/ void validate(LaTeXFeatures&); //the correct parameters to be //included later
/** Insert an inset into the buffer Insert inset into buffer, placing it in a layout of lout,
if no_table make sure that it doesn't end up in a table. */ void insertInset(Inset *, LString const &lout=LString(), bool no_table = false);
/** Gets next LinuxDoc parameter. This is one of the methods I don't understand. What is its purpose? Can somebody explain please? Yes. It's used in multi-inset-Insets ;-). Terrible. Should be redesigned, if we switch to LaTeX-based LyX-file. But at moment, e.g. URL-Insets split up into three inset-parts. Firstly \url{. Then comes text [text1]. After this as second inset {} and again "normal" text[text2]. And a closing (third) } - Inset. GetNextParameter() now reads a text inbetween to Insets and handles further insets, which are allowed to arise inside such a construction.
*/ int GetNextParameter(LyXParagraph *par, int pos,
LString &buffer, bool convert);
/// is regenerating .tex necessary
DEPCLEAN *dep_clean;
/// buffer is r/o bool read_only;
/// name of the file the buffer is associated with.
LString filename;
/// Format number of buffer float format;
/** A list of views using this buffer. Why not keep a list of the BufferViews that use this buffer?
At least then we don't have to do a lot of magic like: buffer->lyx_gui->bufferview->updateLayoutChoice. Just ask each of the buffers in the list of users to do a updateLayoutChoice.
*/
BufferView *users;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.