]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetref.C
LyX Drinkers United: patch 2
[lyx.git] / src / insets / insetref.C
index b936e53ad941b1301fba6f4c22964f94cabc9d8f..681aa2183bf1289ca29c712fce99c1509dcf8b3d 100644 (file)
 #include "debug.h"
 #include "gettext.h"
 #include "LaTeXFeatures.h"
-#include "lyxfunc.h"
 #include "LyXView.h"
 #include "frontends/Dialogs.h"
+#include "lyxfunc.h"
+#include "BufferView.h"
+#include "support/lstrings.h"
 
 using std::ostream;
 
@@ -34,17 +36,11 @@ 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 (!isLatex
@@ -86,30 +82,14 @@ int InsetRef::Linuxdoc(Buffer const *, ostream & os) const
 
 int InsetRef::DocBook(Buffer const *, ostream & os) const
 {
-       os << "<link linkend=\"" << getContents()
-          << "\">" << getOptions() << "</link>";
-       return 0;
-}
-
-
-// This function escapes 8-bit characters and other problematic characters
-// It's exactly the same code as in insetlabel.C.
-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' };
-       string enc;
-       for (string::size_type i = 0; i < lab.length(); ++i) {
-               unsigned char c= lab[i];
-               if (c >= 128 || c == '=' || c == '%') {
-                       enc += '=';
-                       enc += hexdigit[c>>4];
-                       enc += hexdigit[c & 15];
-               } else {
-                       enc += c;
-               }
+       if (getOptions().empty()) {
+               os << "<xref linkend=\"" << getContents() << "\"/>";
+       } else {
+               os << "<link linkend=\"" << getContents()
+                  << "\">" << getOptions() << "</link>";
        }
-       return enc;
+
+       return 0;
 }
 
 
@@ -120,3 +100,27 @@ void InsetRef::Validate(LaTeXFeatures & features) const
        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;
+}