⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ckcsig.h

📁 linux终端仿真程序
💻 H
字号:
/*  C K C S I G . H  *//*  Definitions and prototypes for signal handling  *//*  Author: Jeffrey Altman (jaltman@columbia.edu),  Columbia University Academic Information Systems, New York City.  Copyright (C) 1985, 1996, Trustees of Columbia University in the City of New  York.  The C-Kermit software may not be, in whole or in part, licensed or  sold for profit as a software product itself, nor may it be included in or  distributed with commercial products or otherwise distributed by commercial  concerns to their clients or customers without written permission of the  Office of Kermit Development and Distribution, Columbia University.  This  copyright notice must not be removed, altered, or obscured.*/#ifdef OS2#ifndef NT#ifndef __HEV__			/* INCL_SEMAPHORE may also define HEV */#define __HEV__typedef  ULONG    HEV;			/* hev */typedef  HEV      *PHEV;#endif /* __HEV__ */#endif /* NT */struct _threadinfo {    int inuse;    int child;    int sibling;#ifdef NT    HANDLE id;    HANDLE handle;    HANDLE parent;    HANDLE CompletionSem ;    HANDLE DieSem ;#else /* NT */    TID id;    TID parent;    HEV CompletionSem;    HEV DieSem;#endif /* NT */};#endif /* OS2 */#ifdef CK_ANSICtypedef SIGTYP (*ck_sigfunc)(void *);typedef SIGTYP (*ck_sighand)(int);#elsetypedef SIGTYP (*ck_sigfunc)();typedef SIGTYP (*ck_sighand)();#endif /* CK_ANSIC *//* Macros for POSIX vs old-style signal handling. */#ifdef CK_POSIX_SIGtypedef sigjmp_buf ckjmpbuf;#else#ifdef NT#include <windows.h>#ifdef NTASMtypedef struct {    CONTEXT context;    DWORD retcode;} ckjmpbuf;#else /* NTASM */typedef jmp_buf ckjmpbuf;#endif /* NTASM */#elsetypedef jmp_buf ckjmpbuf;#endif#endif /* CK_POSIX_SIG *//*  Suppose you want to pass the address of a jmp_buf bar to a function foo.  Since jmp_buf is normally defined (typedef'd) as an array, you would do  it like this:  foo(bar), where foo = foo(jmp_buf bar).  But suppose a  jmp_buf is (say) a struct rather than an array.  Then you must do  foo(&bar) where foo is foo(jmp_buf * bar).  This is controlled here in  the traditional fashion, by ifdefs.  By default, we assume that jmp_buf  is an array.  Define the symbol JBNOTARRAY if jmp_buf is not an array.*/  #ifndef JBNOTARRAY#ifdef NT#define JBNOTARRAY#endif /* NT */#endif /* JBNOTARRAY */#ifdef JBNOTARRAYtypedef ckjmpbuf * ckjptr;#define ckjaddr(x) & x#define ckjdref(x) * x#ifdef CK_POSIX_SIG#define cksetjmp(x) sigsetjmp(x,1)#define cklongjmp(x,y) siglongjmp(x,y)#else#ifdef NT__inline intck_ih(void) {    extern int TlsIndex;#ifdef NTSIG    struct _threadinfo * threadinfo;    threadinfo = (struct _threadinfo *) TlsGetValue(TlsIndex);    if (threadinfo) {	if (WaitAndResetSem(threadinfo->DieSem,0)) {	    ckThreadDie(threadinfo);	    return 1;			/* This should never execute */	}    }#ifdef COMMENT    else debug( F100, "ck_ih() threadinfo is NULL","",0);#endif /* COMMENT */#endif /* NTSIG */    return 0;}#ifdef NTSIG#define cksetjmp(x) setjmp(x)#define cklongjmp(x,y) longjmp(x,y)#else /* NTSIG */#ifdef NTASM__inline DWORDcksetjmp( ckjptr jmp ) {    extern int isinterrupted;    jmp->retcode = 0;    memset( &jmp->context, 0, sizeof(CONTEXT) );    jmp->context.ContextFlags = CONTEXT_FULL ;    if ( !GetThreadContext( GetCurrentThread(), &jmp->context ) )      debug( F101, "cksetjmp GetThreadContext failed","",GetLastError());    debug(F101,"cksetjmp returns","",jmp->retcode);    isinterrupted = 0;    return (jmp->retcode);}__inline void cklongjmp( ckjptr jmp, int retval ) {    extern HANDLE tidCommand;    extern int ttyfd, mdmtyp ;    extern DWORD CommandID;    extern int isinterrupted;    connoi();    isinterrupted = 1;    jmp->retcode = ( retval ? retval : 1 );    debug(F101,"about to SetThreadContext for thread","", CommandID);    debug(F101,"from Thread","",GetCurrentThreadId());    if ( mdmtyp >= 0 ) {	PurgeComm( (HANDLE) ttyfd, PURGE_TXABORT | PURGE_RXABORT );    }    if (SetThreadContext( tidCommand, &jmp->context ))      debug(F100,"cklongjmp SetThreadContext success","",0);    else      debug(F101,"cklongjmp SetThreadContext failed","",GetLastError());    msleep(50);    cmini(1);				/* Reset command parser */    putkey(13);				/* Stuff a carriage return */   /* PostEventAvailSem(); */}#else /* NTASM */void crash( void ) ;#define cksetjmp(x) setjmp(x)__inline void cklongjmp( ckjptr jmp, int retval ) {    extern HANDLE tidCommand;    extern int ttyfd, mdmtyp;    extern DWORD CommandID;    CONTEXT context;    if ( mdmtyp >= 0 ) {	PurgeComm( (HANDLE) ttyfd, PURGE_TXABORT | PURGE_RXABORT ) ;    }    memset( &context, 0, sizeof(CONTEXT) );    context.ContextFlags = CONTEXT_FULL;    if ( !GetThreadContext( tidCommand, &context ) )      debug( F101, "cklongjmp GetThreadContext failed","",GetLastError());               /* Invalidate the instruction pointer */    context.Eip =  (unsigned long) crash;    debug(F101,"about to SetThreadContext for thread","", CommandID);    debug(F101,"from Thread","",GetCurrentThreadId());    if (SetThreadContext( tidCommand, &context ))      debug(F100,"cklongjmp SetThreadContext success","",0);    else      debug(F101,"cklongjmp SetThreadContext failed","",GetLastError());}#endif /* NTASM */#endif /* NTSIG */#else /* NT */#define cksetjmp(x) setjmp(x)#endif /* NT */#endif /* CK_POSIX_SIG */#else  /* jmp_buf is an array */typedef ckjmpbuf ckjptr;#define ckjaddr(x) x#define ckjdref(x) x#ifdef CK_POSIX_SIG#define cksetjmp(x) sigsetjmp(x,1)#define cklongjmp(x,y) siglongjmp(x,y)#else#define cksetjmp(x) setjmp(x)#define cklongjmp(x,y) longjmp(x,y)#endif /* CK_POSIX_SIG */#endif /* JBNOTARRAY */_PROTOTYP( int cc_execute, (ckjptr, ck_sigfunc, ck_sigfunc) );_PROTOTYP( int alrm_execute,	  (ckjptr,	   int /* timo */,	   ck_sighand /* handler */,	   ck_sigfunc, ck_sigfunc) );_PROTOTYP( int cc_alrm_execute,	  (ckjptr,	   int /* timo */,	   ck_sighand /* handler */,	   ck_sigfunc,	   ck_sigfunc) );/* End of ckusig.h */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -