]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetref.C
reformatting and remove using delc
[lyx.git] / src / insets / insetref.C
index ca83db0a0e9c5bb1c5a9aedeb0c04eb7eb56e865..aa43f916406312865c1b875a4d7631d73c9c7f34 100644 (file)
 
 using std::ostream;
 
-extern BufferView * current_view;
-
-
-InsetRef::InsetRef(InsetCommandParams const & p)
-       : InsetCommand(p)
+InsetRef::InsetRef(InsetCommandParams const & p, Buffer const & buf)
+       : InsetCommand(p), isLatex(buf.isLatex())
 {}
 
 void InsetRef::Edit(BufferView * bv, int, int, unsigned int button)
 {
        // Eventually trigger dialog with button 3 not 1
-       ifbutton == 3 )
+       if (button == 3 )
                bv->owner()->getLyXFunc()->
                        Dispatch(LFUN_REF_GOTO, getContents());
-       else ifbutton == 1 )
+       else if (button == 1 )
                bv->owner()->getDialogs()->showRef( this );
 }
 
@@ -37,20 +34,14 @@ void InsetRef::Edit(BufferView * bv, int, int, unsigned int button)
 string const InsetRef::getScreenLabel() const
 {
        string temp;
-       if (getCmdName() == "ref")
-               temp = _( "Ref: " );
-       else if (getCmdName() == "pageref")
-               temp = _( "Page: " );
-       else if (getCmdName() == "vref")
-               temp = _( "TextRef: " );
-       else if (getCmdName() == "vpageref")
-               temp = _( "TextPage: " );
-       else
-               temp = _( "PrettyRef: " );
-
+       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();
@@ -62,7 +53,7 @@ string const InsetRef::getScreenLabel() const
 int InsetRef::Latex(Buffer const *, ostream & os,
                    bool /*fragile*/, bool /*fs*/) const
 {
-       if(getOptions().empty())
+       if (getOptions().empty())
                os << escape(getCommand());
        else {
                InsetCommandParams p( getCmdName(), getContents(), "" );
@@ -120,6 +111,30 @@ void InsetRef::Validate(LaTeXFeatures & features) const
 {
        if (getCmdName() == "vref" || getCmdName() == "vpageref")
                features.varioref = true;
-       else if(getCmdName() == "prettyref")
+       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;
+}