#include <config.h>
-#include <cstdlib>
-
#ifdef __GNUG__
#pragma implementation
#endif
-#include FORMS_H_LOCATION
#include "insetref.h"
#include "buffer.h"
-#include "debug.h"
-#include "lyx_gui_misc.h" // CancelCloseBoxCB
-#include "LyXView.h"
-#include "lyxfunc.h"
#include "commandtags.h"
+#include "debug.h"
#include "gettext.h"
+#include "LaTeXFeatures.h"
+#include "lyxfunc.h"
+#include "LyXView.h"
+#include "frontends/Dialogs.h"
-extern BufferView * current_view;
-
-
-InsetRef::InsetRef(string const & cmd, Buffer * bf)
- : master(bf)
-{
- scanCommand(cmd);
- if (getCmdName() == "ref")
- flag = InsetRef::REF;
- else
- flag = InsetRef::PAGE_REF;
-}
-
+using std::ostream;
-InsetRef::InsetRef(InsetCommand const & inscmd, Buffer * bf)
- : master(bf)
-{
- setCmdName(inscmd.getCmdName());
- setContents(inscmd.getContents());
- setOptions(inscmd.getOptions());
- if (getCmdName() == "ref")
- flag = InsetRef::REF;
- else
- flag = InsetRef::PAGE_REF;
-}
+InsetRef::InsetRef(InsetCommandParams const & p, Buffer const & buf)
+ : InsetCommand(p), isLatex(buf.isLatex())
+{}
-
-void InsetRef::Edit(BufferView * bv, int, int, unsigned int)
+void InsetRef::Edit(BufferView * bv, int, int, unsigned int button)
{
- bv->owner()->getLyXFunc()->
- Dispatch(LFUN_REFGOTO, getContents().c_str());
+ // Eventually trigger dialog with button 3 not 1
+ if (button == 3 )
+ bv->owner()->getLyXFunc()->
+ Dispatch(LFUN_REF_GOTO, getContents());
+ else if (button == 1 )
+ bv->owner()->getDialogs()->showRef( this );
}
-string InsetRef::getScreenLabel() const
+string const InsetRef::getScreenLabel() const
{
string temp;
- if (flag == InsetRef::PAGE_REF)
- temp += _("Page: ");
- else
- temp += _("Ref: ");
+ for (int i = 0; !types[i].latex_name.empty(); ++ i)
+ if (getCmdName() == types[i].latex_name) {
+ temp = _(types[i].short_gui_name);
+ break;
+ }
temp += getContents();
- if(!current_view->buffer()->isLatex()
+
+ if (!isLatex
&& !getOptions().empty()) {
temp += "||";
temp += getOptions();
}
-int InsetRef::Latex(ostream & os, signed char /*fragile*/, bool /*fs*/) const
+int InsetRef::Latex(Buffer const *, ostream & os,
+ bool /*fragile*/, bool /*fs*/) const
{
- if(getOptions().empty())
+ if (getOptions().empty())
os << escape(getCommand());
else {
- string ns;
- InsetCommand clone = InsetCommand(getCmdName(),
- getContents(), ns);
- os << escape(clone.getCommand());
+ InsetCommandParams p( getCmdName(), getContents(), "" );
+ os << escape(p.getCommand());
}
return 0;
}
-int InsetRef::Linuxdoc(ostream & os) const
+int InsetRef::Ascii(Buffer const *, ostream & os, int) const
+{
+ os << "[" << getContents() << "]";
+ return 0;
+}
+
+
+int InsetRef::Linuxdoc(Buffer const *, ostream & os) const
{
os << "<ref id=\"" << getContents()
<< "\" name=\"" << getOptions() << "\" >";
}
-int InsetRef::DocBook(ostream & os) const
+int InsetRef::DocBook(Buffer const *, ostream & os) const
{
os << "<link linkend=\"" << getContents()
<< "\">" << getOptions() << "</link>";
// This function escapes 8-bit characters and other problematic characters
// It's exactly the same code as in insetlabel.C.
-string InsetRef::escape(string const & lab) const
+string const InsetRef::escape(string const & lab) const
{
char hexdigit[16] = { '0', '1', '2', '3', '4', '5', '6', '7',
'8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
}
return enc;
}
+
+
+void InsetRef::Validate(LaTeXFeatures & features) const
+{
+ if (getCmdName() == "vref" || getCmdName() == "vpageref")
+ features.varioref = true;
+ else if (getCmdName() == "prettyref")
+ features.prettyref = true;
+}
+
+InsetRef::type_info InsetRef::types[] = {
+ { "ref", N_("Standard"), N_("Ref: ")},
+ { "pageref", N_("Page Number"), N_("Page: ")},
+ { "vpageref", N_("Textual Page Number"), N_("TextPage: ")},
+ { "vref", N_("Standard+Textual Page"), N_("Ref+Text: ")},
+ { "prettyref", N_("PrettyRef"), N_("PrettyRef: ")},
+ { "", "", "" }
+};
+
+
+int InsetRef::getType(string const & name)
+{
+ for (int i = 0; !types[i].latex_name.empty(); ++i)
+ if (name == types[i].latex_name)
+ return i;
+ return 0;
+}
+
+
+string const & InsetRef::getName(int type)
+{
+ return types[type].latex_name;
+}