mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-02 11:21:42 +00:00
55660072db
* Activate.c (XMenuActivate): Callback's first arg is readonly. * AddPane.c (XMenuAddPane): Label is readonly. Rename local to avoid shadowing. * AddSel.c (XMenuAddSelection): Help arg is readonly. Rename local. * Create.c (atoi, atof): Remove decls; include <stdlib.h>. (MAX_INACT_PNUM, TILE_BUF_SIZE): Remove; unused. (x_get_resource_string): Args are readonly. (XAllocDisplayColor): colorName is readonly. (XMenuCreate): def_env is readonly. Remove unused locals. Avoid "else;". * Destroy.c (XMenuDestroy): Return void. * Error.c (XMenuError): Remove const pointer. * EvHand.c (XMenuEventHandler): Return void. * FindPane.c, FindSel.c: Include <string.h>. * InsPane.c (XMenuInsertPane): Rename local to avoid shadowing. * InsSel.c (XMenuInsertSelection): Likewise. * Internal.c (toggle_color, BUFFER_SIZE): Remove; unused. (_XMErrorList): Now const. (_XMWinQueInit, _XMRecomputeGlobals, _XMTransToOrigin, _XMRefreshPane): (_XMRefreshSelection): Return void. (_XMWinQueFlush, _XMRefreshSelection): Rename locals to avoid shadowing. (_XMWinQueFlush): Use stack, not heap. Don't use uninitialized var. * SetAEQ.c (XMenuSetAEQ): Now returns void. * SetFrz.c (XMenuSetFreeze): Likewise. * X10.h (XAssoc): Use void * for generic pointer. * XDelAssoc.c: Include XMenuInt.h rather than duplicating part of it. * XDestAssoc.c, XMakeAssoc.c: Likewise. * XDestAssoc.c (XDestroyAssocTable): Return void. * XMakeAssoc.c (XMakeAssoc): Use void * for generic pointer. * XMenu.h, XMenuInt.h: Adjust to signature changes. Use const for pointers to readonly storage. * insque.c: Include XMenuInt.h, to check our own signature. (emacs_insque, emacs_remque): Use void * for generic pointers.
113 lines
2.6 KiB
C
113 lines
2.6 KiB
C
/* Copyright Massachusetts Institute of Technology 1985 */
|
|
|
|
#include "copyright.h"
|
|
|
|
|
|
/*
|
|
* XMenu: MIT Project Athena, X Window system menu package
|
|
*
|
|
* XMenuInsertPane - Inserts a pane into an XMenu object in
|
|
* a particular position.
|
|
*
|
|
* Author: Tony Della Fera, DEC
|
|
* 20-Nov-85
|
|
*
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include "XMenuInt.h"
|
|
|
|
int
|
|
XMenuInsertPane(register XMenu *menu, register int p_num, char *label, int active)
|
|
/* Menu object to be modified. */
|
|
/* Pane number of new pane. */
|
|
/* Selection label. */
|
|
/* Make selection active? */
|
|
{
|
|
register XMPane *p_ptr; /* XMPane pointer. */
|
|
register XMPane *pane; /* Newly created pane. */
|
|
register XMSelect *sel; /* Initial selection for the new pane. */
|
|
|
|
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 pane number one less than the one specified since that
|
|
* is the pane after which the insertion will occur.
|
|
*/
|
|
p_ptr = _XMGetPanePtr(menu, (p_num - 1));
|
|
if (p_ptr == NULL) return(XM_FAILURE);
|
|
|
|
/*
|
|
* Calloc the XMPane structure and the initial XMSelect.
|
|
*/
|
|
pane = (XMPane *)calloc(1, sizeof(XMPane));
|
|
if (pane == NULL) {
|
|
_XMErrorCode = XME_CALLOC;
|
|
return(XM_FAILURE);
|
|
}
|
|
sel = (XMSelect *)calloc(1, sizeof(XMSelect));
|
|
if (sel == NULL) {
|
|
_XMErrorCode = XME_CALLOC;
|
|
return(XM_FAILURE);
|
|
}
|
|
|
|
/*
|
|
* Determine label size.
|
|
*/
|
|
label_length = strlen(label);
|
|
label_width = XTextWidth(menu->p_fnt_info, label, label_length);
|
|
|
|
/*
|
|
* Set up the initial selection.
|
|
* Values not explicitly set are zeroed by calloc.
|
|
*/
|
|
sel->next = sel;
|
|
sel->prev = sel;
|
|
sel->type = SL_HEADER;
|
|
sel->serial = -1;
|
|
sel->parent_p = pane;
|
|
|
|
/*
|
|
* Fill the XMPane structure.
|
|
*/
|
|
pane->type = PANE;
|
|
pane->active = active;
|
|
pane->serial = -1;
|
|
pane->label = label;
|
|
pane->label_width = label_width;
|
|
pane->label_length = label_length;
|
|
pane->s_list = sel;
|
|
|
|
/*
|
|
* Insert the pane after the pane with the pane
|
|
* number one less than the desired number for the
|
|
* new pane.
|
|
*/
|
|
emacs_insque(pane, p_ptr);
|
|
|
|
/*
|
|
* Update the pane count.
|
|
*/
|
|
menu->p_count++;
|
|
|
|
/*
|
|
* Schedule a recompute.
|
|
*/
|
|
menu->recompute = 1;
|
|
|
|
/*
|
|
* Return the number of the pane just added.
|
|
*/
|
|
_XMErrorCode = XME_NO_ERROR;
|
|
return(p_num);
|
|
}
|