summaryrefslogtreecommitdiff
path: root/oldXMenu/InsSel.c
diff options
context:
space:
mode:
authorDave Love <fx@gnu.org>1999-10-03 19:36:13 +0000
committerDave Love <fx@gnu.org>1999-10-03 19:36:13 +0000
commite745ede7473e87b93d71858bc1c8447a1307de28 (patch)
tree59353dca94fcb3a9ce2fd9f79614a3119da7f863 /oldXMenu/InsSel.c
parent0c898dd963a3277b5ec8d59f0a350e3fb50e50c3 (diff)
downloademacs-e745ede7473e87b93d71858bc1c8447a1307de28.tar.gz
#
Diffstat (limited to 'oldXMenu/InsSel.c')
-rw-r--r--oldXMenu/InsSel.c116
1 files changed, 116 insertions, 0 deletions
diff --git a/oldXMenu/InsSel.c b/oldXMenu/InsSel.c
new file mode 100644
index 00000000000..200f57574ef
--- /dev/null
+++ b/oldXMenu/InsSel.c
@@ -0,0 +1,116 @@
+#include "copyright.h"
+
+/* $Header: /u/src/emacs/19.0/oldXMenu/RCS/InsSel.c,v 1.1 1992/04/11 22:10:19 jimb Exp $ */
+/* Copyright Massachusetts Institute of Technology 1985 */
+
+/*
+ * XMenu: MIT Project Athena, X Window system menu package
+ *
+ * XMenuInsertSelection - Inserts a selection into an XMenu object
+ *
+ * Author: Tony Della Fera, DEC
+ * 20-Nov-85
+ *
+ */
+
+#include <config.h>
+#include "XMenuInt.h"
+
+int
+XMenuInsertSelection(menu, p_num, s_num, data, label, active)
+ register XMenu *menu; /* Menu object to be modified. */
+ register int p_num; /* Pane number to be modified. */
+ register int s_num; /* Selection number of new selection. */
+ char *data; /* Data value. */
+ char *label; /* Selection label. */
+ int active; /* Make selection active? */
+{
+ register XMPane *p_ptr; /* XMPane pointer. */
+ register XMSelect *s_ptr; /* XMSelect pointer. */
+
+ XMSelect *select; /* Newly created selection. */
+
+ int label_length; /* Label length in characters. */
+ int label_width; /* Label width in pixels. */
+
+ /*
+ * Check for NULL pointers!
+ */
+ if (label == NULL) {
+ _XMErrorCode = XME_ARG_BOUNDS;
+ return(XM_FAILURE);
+ }
+
+ /*
+ * Find the right pane.
+ */
+ p_ptr = _XMGetPanePtr(menu, p_num);
+ if (p_ptr == NULL) return(XM_FAILURE);
+
+ /*
+ * Find the selection number one less than the one specified since that
+ * is the selection after which the insertion will occur.
+ */
+ s_ptr = _XMGetSelectionPtr(p_ptr, (s_num - 1));
+ if (s_ptr == NULL) return(XM_FAILURE);
+
+ /*
+ * Calloc the XMSelect structure.
+ */
+ select = (XMSelect *)calloc(1, sizeof(XMSelect));
+ if (select == NULL) {
+ _XMErrorCode = XME_CALLOC;
+ return(XM_FAILURE);
+ }
+
+ /*
+ * Determine label size.
+ */
+ label_length = strlen(label);
+ label_width = XTextWidth(menu->s_fnt_info, label, label_length);
+
+
+ /*
+ * Fill the XMSelect structure.
+ */
+ if (!strcmp (label, "--") || !strcmp (label, "---"))
+ {
+ select->type = SEPARATOR;
+ select->active = 0;
+ }
+ else
+ {
+ select->type = SELECTION;
+ select->active = active;
+ }
+
+ select->active = active;
+ select->serial = -1;
+ select->label = label;
+ select->label_width = label_width;
+ select->label_length = label_length;
+ select->data = data;
+ select->parent_p = p_ptr;
+
+ /*
+ * Insert the selection after the selection with the selection
+ * number one less than the desired number for the new selection.
+ */
+ emacs_insque(select, s_ptr);
+
+ /*
+ * Update the selection count.
+ */
+ p_ptr->s_count++;
+
+ /*
+ * Schedule a recompute.
+ */
+ menu->recompute = 1;
+
+ /*
+ * Return the selection number just inserted.
+ */
+ _XMErrorCode = XME_NO_ERROR;
+ return(s_num);
+}