From 665d9ca1da8c5e0290958017bc36ad89fd5b702f Mon Sep 17 00:00:00 2001 From: Renaud Fivet Date: Mon, 9 Aug 2021 15:45:01 +0800 Subject: [PATCH] bindable: code review and minor refactoring. --- bindable.c | 195 ++++++++++++++++++++++++----------------------------- bindable.h | 9 +++ 2 files changed, 97 insertions(+), 107 deletions(-) diff --git a/bindable.c b/bindable.c index 12a2706..7f42f7f 100644 --- a/bindable.c +++ b/bindable.c @@ -3,146 +3,127 @@ #include - #include "defines.h" #include "buffer.h" -#include "display.h" -#include "estruct.h" +#include "display.h" /* vttidy() */ #include "file.h" #include "input.h" #include "lock.h" #include "mlout.h" #include "terminal.h" -/* - * Fancy quit command, as implemented by Norm. If the any buffer has - * changed do a write on that buffer and exit emacs, otherwise simply exit. + +/* Fancy quit command, as implemented by Norm. If any buffer has changed + do a write on that buffer and exit emacs, otherwise simply exit. */ -int quickexit(int f, int n) -{ - struct buffer *bp; /* scanning pointer to buffers */ - struct buffer *oldcb; /* original current buffer */ - int status; - - oldcb = curbp; /* save in case we fail */ - - bp = bheadp; - while (bp != NULL) { - if ((bp->b_flag & BFCHG) != 0 /* Changed. */ - && (bp->b_flag & BFTRUNC) == 0 /* Not truncated P.K. */ - && (bp->b_flag & BFINVS) == 0) { /* Real. */ - curbp = bp; /* make that buffer cur */ - mloutfmt( "(Saving %s)", bp->b_fname) ; -#if PKCODE -#else - mloutstr( "\n") ; -#endif - if ((status = filesave(f, n)) != TRUE) { - curbp = oldcb; /* restore curbp */ - return status; - } - } - bp = bp->b_bufp; /* on to the next buffer */ - } - quit(f, n); /* conditionally quit */ - return TRUE; +BINDABLE( quickexit) { + buffer_p oldcb = curbp ; /* save in case we fail */ + for( buffer_p bp = bheadp ; bp != NULL ; bp = bp->b_bufp) { + if( (bp->b_flag & (BFCHG | BFTRUNC | BFINVS)) == BFCHG) { + /* Changed, Not truncated and real buffer */ + curbp = bp ; /* make that buffer cur */ + mloutfmt( "(Saving %s)", bp->b_fname) ; + int status = filesave( f, n) ; + if( status != TRUE) { + curbp = oldcb ; /* restore curbp */ + return status ; + } + } + } + + return quit( f, n) ; /* conditionally quit */ } -/* - * Quit command. If an argument, always quit. Otherwise confirm if a buffer + +/* Quit command. If an argument, always quit. Otherwise confirm if a buffer * has been changed and not written out. Normally bound to "C-X C-C". */ -int quit(int f, int n) -{ - int s; - - if (f != FALSE /* Argument forces it. */ - || anycb() == FALSE /* All buffers clean. */ - /* User says it's OK. */ - || (s = - mlyesno("Modified buffers exist. Leave anyway")) == TRUE) { -#if (FILOCK && BSD) || SVR4 - if (lockrel() != TRUE) { - TTputc('\n'); - TTputc('\r'); - TTclose(); - TTkclose(); - exit( EXIT_FAILURE) ; - } +BINDABLE( quit) { + int s ; /* status of user query */ + + if( f != FALSE /* Argument forces it. */ + || anycb() == FALSE /* All buffers clean. */ + /* User says it's OK. */ + || (s = mlyesno( "Modified buffers exist. Leave anyway")) == TRUE) { +#if (FILOCK && BSD) || SVR4 + if( lockrel() != TRUE) { + TTputc('\n') ; + TTputc('\r') ; + TTclose() ; + TTkclose() ; + exit( EXIT_FAILURE) ; + } #endif - vttidy(); - if (f) - exit(n); - else - exit( EXIT_SUCCESS) ; - } - mloutstr( "") ; - return s; + vttidy() ; + if( f) + exit( n) ; + else + exit( EXIT_SUCCESS) ; + } + + mloutstr( "") ; + return s ; } -/* - * Begin a keyboard macro. + +/* Begin a keyboard macro. * Error if not at the top level in keyboard processing. Set up variables and * return. */ -int ctlxlp(int f, int n) -{ - if (kbdmode != STOP) { - mloutstr( "%Macro already active") ; - return FALSE; - } - mloutstr( "(Start macro)") ; - kbdptr = &kbdm[0]; - kbdend = kbdptr; - kbdmode = RECORD; - return TRUE; +BINDABLE( ctlxlp) { + if( kbdmode != STOP) + return mloutfail( "%Macro already active") ; + + mloutstr( "(Start macro)") ; + kbdptr = kbdm ; + kbdend = kbdptr ; + kbdmode = RECORD ; + return TRUE ; } -/* - * End keyboard macro. Check for the same limit conditions as the above + +/* End keyboard macro. Check for the same limit conditions as the above * routine. Set up the variables and return to the caller. */ -int ctlxrp(int f, int n) -{ - if (kbdmode == STOP) { - mloutstr( "%Macro not active") ; - return FALSE; - } - if (kbdmode == RECORD) { - mloutstr( "(End macro)") ; - kbdmode = STOP; - } - return TRUE; +BINDABLE( ctlxrp) { + if( kbdmode == STOP) + return mloutfail( "%Macro not active") ; + + if (kbdmode == RECORD) { + mloutstr( "(End macro)") ; + kbdmode = STOP; + } + + return TRUE ; } -/* - * Execute a macro. + +/* Execute a macro. * The command argument is the number of times to loop. Quit as soon as a * command gets an error. Return TRUE if all ok, else FALSE. */ -int ctlxe(int f, int n) -{ - if (kbdmode != STOP) { - mloutstr( "%Macro already active") ; - return FALSE; - } - if (n <= 0) - return TRUE; - kbdrep = n; /* remember how many times to execute */ - kbdmode = PLAY; /* start us in play mode */ - kbdptr = &kbdm[0]; /* at the beginning */ - return TRUE; +BINDABLE( ctlxe) { + if( kbdmode != STOP) + return mloutfail( "%Macro already active") ; + + if( n <= 0) + return TRUE ; + + kbdrep = n ; /* remember how many times to execute */ + kbdmode = PLAY ; /* start us in play mode */ + kbdptr = kbdm ; /* at the beginning */ + return TRUE ; } -/* - * abort: + +/* abort: * Beep the beeper. Kill off any keyboard macro, etc., that is in progress. * Sometimes called as a routine, to do general aborting of stuff. */ -int ctrlg( int f, int n) { - kbdmode = STOP ; - mloutfmt( "%B(Aborted)") ; - return ABORT ; +BINDABLE( ctrlg) { + kbdmode = STOP ; + mloutfmt( "%B(Aborted)") ; + return ABORT ; } /* end of bindable.c */ diff --git a/bindable.h b/bindable.h index fb96884..30b5b3b 100644 --- a/bindable.h +++ b/bindable.h @@ -1,3 +1,8 @@ +/* bindable.h -- misc bindable functions */ + +#ifndef _BINDABLE_H_ +#define _BINDABLE_H_ + #include "names.h" /* functions that can be bound to keys or procedure names */ @@ -7,3 +12,7 @@ BINDABLE( ctlxlp) ; BINDABLE( ctlxrp) ; BINDABLE( ctlxe) ; BINDABLE( ctrlg) ; + +#endif + +/* end of bindable.h */