#pragma interface
#endif
+#include <vector>
#include "insetcommand.h"
-using std::ostream;
-
class Buffer;
-/** Used to insert citations
- */
-class InsetCitation: public InsetCommand {
-public:
- ///
- InsetCitation() : InsetCommand("cite") {}
- ///
- InsetCitation(string const & key, string const & note = string());
- ///
- ~InsetCitation();
- ///
- Inset * Clone() const {
- return new InsetCitation(contents, options);
- }
- ///
- string getScreenLabel()const;
- ///
- void Edit(BufferView *, int x, int y, unsigned int button);
- ///
- EDITABLE Editable() const {
- return IS_EDITABLE;
- }
- ///
- struct Holder {
- InsetCitation * inset;
- BufferView * view;
- };
-
-private:
- ///
- Holder holder;
-};
-
-
/** Used to insert bibitem's information (key and label)
Must be automatically inserted as the first object in a
bibliography paragraph.
*/
-class InsetBibKey: public InsetCommand {
+class InsetBibKey : public InsetCommand {
public:
///
- InsetBibKey() : InsetCommand("bibitem") { counter = 1; }
- ///
- InsetBibKey(string const & key, string const & label = string());
- ///
- InsetBibKey(InsetBibKey const *);
+ InsetBibKey(InsetCommandParams const &);
///
~InsetBibKey();
///
- Inset * Clone() const { return new InsetBibKey(this); }
- /// Currently \bibitem is used as a LyX2.x command, so we need this method.
- void Write(ostream &) const;
+ Inset * Clone(Buffer const &) const;
+ /** Currently \bibitem is used as a LyX2.x command,
+ so we need this method.
+ */
+ void Write(Buffer const *, std::ostream &) const;
+ ///
+ void Read(Buffer const *, LyXLex & lex);
///
- virtual string getScreenLabel() const;
+ virtual string const getScreenLabel() const;
///
void Edit(BufferView *, int x, int y, unsigned int button);
///
///
int getCounter() const { return counter; }
///
+ string const getBibLabel() const;
+ ///
struct Holder {
InsetBibKey * inset;
BufferView * view;
};
-
- private:
+
+private:
///
int counter;
-
///
Holder holder;
+ ///
+ static int key_counter;
};
/** Used to insert BibTeX's information
*/
-class InsetBibtex: public InsetCommand {
+class InsetBibtex : public InsetCommand {
public:
- ///
- InsetBibtex() : InsetCommand("BibTeX") { owner = 0; }
///
- InsetBibtex(string const & dbase, string const & style,
- Buffer *);
+ InsetBibtex(InsetCommandParams const &);
///
~InsetBibtex();
-
- ///
- Inset * Clone() const {
- return new InsetBibtex(contents, options, 0);
- }
- ///
- Inset::Code LyxCode() const
- {
- return Inset::BIBTEX_CODE;
+ ///
+ Inset * Clone(Buffer const &) const {
+ return new InsetBibtex(params());
}
///
- string getScreenLabel() const;
+ string const getScreenLabel() const;
+ ///
+ EDITABLE Editable() const { return IS_EDITABLE; }
+ ///
+ Inset::Code LyxCode() const { return Inset::BIBTEX_CODE; }
///
void Edit(BufferView *, int x, int y, unsigned int button);
///
- int Latex(ostream &, signed char, bool) const;
+ int Latex(Buffer const *, std::ostream &,
+ bool fragile, bool freespace) const;
///
- string getKeys(char delim);
- ///
- EDITABLE Editable() const {
- return IS_EDITABLE;
- }
+ std::vector<std::pair<string,string> > const getKeys(Buffer const *) const;
///
bool addDatabase(string const &);
///
bool delDatabase(string const &);
///
bool display() const { return true; }
-
+ ///
struct Holder {
InsetBibtex * inset;
BufferView * view;
};
private:
- ///
- mutable Buffer * owner;
-
///
Holder holder;
};