commit 18d9d7ee9d1777199802d78a8adfaf884e8cb6fe
Author: Juergen Spitzmueller <sp...@lyx.org>
Date:   Sun Jul 28 10:37:30 2024 +0200

    re-implement LFUN_REFERENCE_INSERT
    
    this is in preparation of another feature
    
    (cherry picked from commit 181c8ce7c1c4b5e443775bec72f899040f6a43a5)
---
 src/FuncCode.h    |  2 ++
 src/LyXAction.cpp | 10 ++++++++++
 src/Text.cpp      | 20 ++++++++++++++++++++
 3 files changed, 32 insertions(+)

diff --git a/src/FuncCode.h b/src/FuncCode.h
index a5f638d6d7..7f35ca391d 100644
--- a/src/FuncCode.h
+++ b/src/FuncCode.h
@@ -509,6 +509,8 @@ enum FuncCode
        LFUN_TAB_GROUP_PREVIOUS,        // daniel 20220130
        LFUN_BIBTEX_DATABASE_LIST,      // bpiwowar, 20221218
        LFUN_STATISTICS_REFERENCE_CLAMP,// sanda, 20240324
+       LFUN_REFERENCE_INSERT,          // spitz, 20240728
+       // 400
        LFUN_LASTACTION                 // end of the table
 };
 
diff --git a/src/LyXAction.cpp b/src/LyXAction.cpp
index f420f67f19..323a1c160b 100644
--- a/src/LyXAction.cpp
+++ b/src/LyXAction.cpp
@@ -3512,6 +3512,16 @@ void LyXAction::init()
  */
                { LFUN_REDO, "redo", ReadOnly, Edit },
 
+/*!
+ * \var lyx::FuncCode lyx::LFUN_REFERENCE_INSERT
+ * \li Action: Inserts a cross-reference into the document.
+ * \li Notion: Optional <TYPE> can be used to set the type of reference 
+ * \li Syntax: reference-insert <LABEL> [<TYPE>]
+ * \li Origin: spitz, 28 Jul 2024
+ * \endvar
+ */
+               { LFUN_REFERENCE_INSERT, "reference-insert", Noop, Edit },
+
 /*!
  * \var lyx::FuncCode lyx::LFUN_REFERENCE_NEXT
  * \li Action: Go to the next label or cross-reference.
diff --git a/src/Text.cpp b/src/Text.cpp
index f63a6ede4b..f40562d30d 100644
--- a/src/Text.cpp
+++ b/src/Text.cpp
@@ -82,6 +82,7 @@
 #include "insets/InsetIPAMacro.h"
 #include "insets/InsetNewline.h"
 #include "insets/InsetQuotes.h"
+#include "insets/InsetRef.h"
 #include "insets/InsetSpecialChar.h"
 #include "insets/InsetTabular.h"
 #include "insets/InsetText.h"
@@ -5480,6 +5481,18 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
                break;
        }
 
+       case LFUN_REFERENCE_INSERT: {
+               string const label = cmd.getArg(0);
+               string const type = cmd.getArg(1);
+               InsetCommandParams p(REF_CODE, "ref");
+               if (!type.empty())
+                       p.setCmdName(type);
+               p["reference"] = from_utf8(label);
+               string const data = InsetCommand::params2string(p);
+               lyx::dispatch(FuncRequest(LFUN_INSET_INSERT, data));
+               break;
+       }
+
        case LFUN_INFO_INSERT: {
                if (cmd.argument().empty()) {
                        bv->showDialog("info", 
cur.current_font.language()->lang());
@@ -6739,6 +6752,13 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & 
cmd,
        case LFUN_PREVIEW_INSERT:
                code = PREVIEW_CODE;
                break;
+       case LFUN_REFERENCE_INSERT: {
+               string const type = cmd.getArg(1);
+               if (!type.empty())
+                       enable = InsetRef::isCompatibleCommand(type);
+               code = REF_CODE;
+               break;
+       }
        case LFUN_SCRIPT_INSERT:
                code = SCRIPT_CODE;
                break;
-- 
lyx-cvs mailing list
lyx-cvs@lists.lyx.org
http://lists.lyx.org/mailman/listinfo/lyx-cvs

Reply via email to