NetBSD/usr.bin/vi/ex/ex_display.c

146 lines
3.1 KiB
C
Raw Normal View History

/*-
* Copyright (c) 1992, 1993, 1994
* The Regents of the University of California. All rights reserved.
1996-05-20 07:47:00 +04:00
* Copyright (c) 1992, 1993, 1994, 1995, 1996
* Keith Bostic. All rights reserved.
*
1996-05-20 07:47:00 +04:00
* See the LICENSE file for redistribution information.
*/
1996-05-20 07:47:00 +04:00
#include "config.h"
#ifndef lint
1996-05-20 07:47:00 +04:00
static const char sccsid[] = "@(#)ex_display.c 10.12 (Berkeley) 4/10/96";
#endif /* not lint */
#include <sys/types.h>
#include <sys/queue.h>
#include <bitstring.h>
#include <ctype.h>
#include <limits.h>
#include <stdio.h>
#include <string.h>
1996-05-20 07:47:00 +04:00
#include "../common/common.h"
#include "tag.h"
1996-05-20 07:47:00 +04:00
static int bdisplay __P((SCR *));
static void db __P((SCR *, CB *, CHAR_T *));
/*
1996-05-20 07:47:00 +04:00
* ex_display -- :display b[uffers] | c[onnections] | s[creens] | t[ags]
*
1996-05-20 07:47:00 +04:00
* Display cscope connections, buffers, tags or screens.
*
* PUBLIC: int ex_display __P((SCR *, EXCMD *));
*/
int
1996-05-20 07:47:00 +04:00
ex_display(sp, cmdp)
SCR *sp;
1996-05-20 07:47:00 +04:00
EXCMD *cmdp;
{
switch (cmdp->argv[0]->bp[0]) {
case 'b':
#undef ARG
#define ARG "buffers"
if (cmdp->argv[0]->len >= sizeof(ARG) ||
memcmp(cmdp->argv[0]->bp, ARG, cmdp->argv[0]->len))
break;
1996-05-20 07:47:00 +04:00
return (bdisplay(sp));
case 'c':
#undef ARG
#define ARG "connections"
if (cmdp->argv[0]->len >= sizeof(ARG) ||
memcmp(cmdp->argv[0]->bp, ARG, cmdp->argv[0]->len))
break;
return (cscope_display(sp));
case 's':
#undef ARG
#define ARG "screens"
if (cmdp->argv[0]->len >= sizeof(ARG) ||
memcmp(cmdp->argv[0]->bp, ARG, cmdp->argv[0]->len))
break;
1996-05-20 07:47:00 +04:00
return (ex_sdisplay(sp));
case 't':
#undef ARG
#define ARG "tags"
if (cmdp->argv[0]->len >= sizeof(ARG) ||
memcmp(cmdp->argv[0]->bp, ARG, cmdp->argv[0]->len))
break;
1996-05-20 07:47:00 +04:00
return (ex_tag_display(sp));
}
1996-05-20 07:47:00 +04:00
ex_emsg(sp, cmdp->cmd->usage, EXM_USAGE);
return (1);
}
/*
* bdisplay --
*
* Display buffers.
*/
static int
1996-05-20 07:47:00 +04:00
bdisplay(sp)
SCR *sp;
{
CB *cbp;
if (sp->gp->cutq.lh_first == NULL && sp->gp->dcbp == NULL) {
1996-05-20 07:47:00 +04:00
msgq(sp, M_INFO, "123|No cut buffers to display");
return (0);
}
/* Display regular cut buffers. */
for (cbp = sp->gp->cutq.lh_first; cbp != NULL; cbp = cbp->q.le_next) {
if (isdigit(cbp->name))
continue;
if (cbp->textq.cqh_first != (void *)&cbp->textq)
db(sp, cbp, NULL);
if (INTERRUPTED(sp))
return (0);
}
/* Display numbered buffers. */
for (cbp = sp->gp->cutq.lh_first; cbp != NULL; cbp = cbp->q.le_next) {
if (!isdigit(cbp->name))
continue;
if (cbp->textq.cqh_first != (void *)&cbp->textq)
db(sp, cbp, NULL);
if (INTERRUPTED(sp))
return (0);
}
/* Display default buffer. */
if ((cbp = sp->gp->dcbp) != NULL)
db(sp, cbp, "default buffer");
return (0);
}
/*
* db --
* Display a buffer.
*/
static void
db(sp, cbp, name)
SCR *sp;
CB *cbp;
CHAR_T *name;
{
CHAR_T *p;
1996-05-20 07:47:00 +04:00
GS *gp;
TEXT *tp;
size_t len;
1996-05-20 07:47:00 +04:00
gp = sp->gp;
(void)ex_printf(sp, "********** %s%s\n",
name == NULL ? KEY_NAME(sp, cbp->name) : name,
F_ISSET(cbp, CB_LMODE) ? " (line mode)" : " (character mode)");
for (tp = cbp->textq.cqh_first;
tp != (void *)&cbp->textq; tp = tp->q.cqe_next) {
for (len = tp->len, p = tp->lb; len--; ++p) {
1996-05-20 07:47:00 +04:00
(void)ex_puts(sp, KEY_NAME(sp, *p));
if (INTERRUPTED(sp))
return;
}
1996-05-20 07:47:00 +04:00
(void)ex_puts(sp, "\n");
}
}