📄 ntotrio.c
字号:
/****************************************************************************
*
* Open Watcom Project
*
* Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
*
* ========================================================================
*
* This file contains Original Code and/or Modifications of Original
* Code as defined in and that are subject to the Sybase Open Watcom
* Public License version 1.0 (the 'License'). You may not use this file
* except in compliance with the License. BY USING THIS FILE YOU AGREE TO
* ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
* provided with the Original Code and Modifications, and is also
* available at www.sybase.com/developer/opensource.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
* ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
* NON-INFRINGEMENT. Please see the License for the specific language
* governing rights and limitations under the License.
*
* ========================================================================
*
* Description: QNX Neutrino trap file I/O.
*
****************************************************************************/
#include <string.h>
#include <unistd.h>
#include <termios.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/time.h>
#include "trpimp.h"
extern char RWBuff[];
void Output( char *str )
{
write( 2, str, strlen( str ) );
}
void SayGNiteGracey( int return_code )
{
_exit( return_code );
}
void StartupErr( char *err )
{
Output( err );
Output( "\n" );
SayGNiteGracey( 1 );
}
int KeyPress( void )
{
int ret;
struct termios old;
struct termios new;
struct timeval tv;
fd_set rdfs;
tcgetattr( 0, &old );
new = old;
new.c_lflag &= ~(ICANON | ECHO);
new.c_cc[VMIN] = 1;
new.c_cc[VTIME] = 0;
tcsetattr( 0, TCSANOW, &new );
FD_ZERO( &rdfs );
FD_SET( 0, &rdfs );
tv.tv_sec = 0;
tv.tv_usec = 0;
ret = select(1, &rdfs, NULL, NULL, &tv );
tcsetattr( 0, TCSANOW, &old );
return( ret != 0 );
}
int KeyGet( void )
{
struct termios old;
struct termios new;
char key;
tcgetattr( 0, &old );
new = old;
new.c_lflag &= ~(ICANON | ECHO);
new.c_cc[VMIN] = 1;
new.c_cc[VTIME] = 0;
tcsetattr( 0, TCSANOW, &new );
read( 0, &key, 1 );
tcsetattr( 0, TCSANOW, &old );
return( key );
}
static char *StrCopy( char *src, char *dst )
{
while( (*dst = *src) ) {
++src;
++dst;
}
return( dst );
}
static unsigned TryOnePath( char *path, struct stat *tmp, char *name,
char *result )
{
char *end;
char *ptr;
if( path == NULL ) return( 0 );
ptr = result;
for( ;; ) {
if( *path == '\0' || *path == ':' ) {
if( ptr != result ) *ptr++ = '/';
end = StrCopy( name, ptr );
if( stat( (char *)result, tmp ) == 0 ) return( end - result );
if( *path == '\0' ) return( 0 );
++path;
ptr = result;
}
if( *path != ' ' && *path != '\t' ) {
*ptr++ = *path;
}
++path;
}
}
static unsigned FindFilePath( char *name, char *result )
{
struct stat tmp;
unsigned len;
char *end;
char cmd[256];
if( stat( name, &tmp ) == 0 ) {
end = StrCopy( name, result );
return( end - result );
}
len = TryOnePath( getenv( "WD_PATH" ), &tmp, name, result );
if( len != 0 ) return( len );
len = TryOnePath( getenv( "HOME" ), &tmp, name, result );
if( len != 0 ) return( len );
if( _cmdname( cmd ) != NULL ) {
end = strrchr( cmd, '/' );
if( end != NULL ) {
*end = '\0';
end = strrchr( cmd, '/' );
if( end != NULL ) {
/* look in the wd sibling directory of where the command
came from */
StrCopy( "wd", end + 1 );
len = TryOnePath( cmd, &tmp, name, result );
if( len != 0 ) return( len );
}
}
}
return( TryOnePath( "/usr/watcom/wd", &tmp, name, result ) );
}
unsigned FullPathOpen( char const *name, char *ext, char *result, unsigned max_result )
{
bool has_ext;
bool has_path;
const char *ptr;
const char *endptr;
char trpfile[256];
unsigned filehndl;
int name_len = strlen(name);
has_ext = FALSE;
has_path = FALSE;
endptr = name + name_len;
for( ptr = name; ptr != endptr; ++ptr ) {
switch( *ptr ) {
case '.':
has_ext = TRUE;
break;
case '/':
has_ext = FALSE;
has_path = TRUE;
/* fall through */
break;
}
}
memcpy( trpfile, name, name_len );
if( has_ext ) {
trpfile[name_len] = '\0';
} else {
trpfile[ name_len++ ] = '.';
memcpy( trpfile + name_len, ext, strlen( ext ) + 1 );
}
if( has_path ) {
filehndl = open( trpfile, O_RDONLY );
} else {
if( FindFilePath( trpfile, result ) == 0 ) {
filehndl = -1;
} else {
filehndl = open( result, O_RDONLY );
}
}
return( filehndl );
}
unsigned PathOpen( char *name, unsigned name_len, char *exts )
{
bool has_ext;
bool has_path;
char *ptr;
char *endptr;
char trpfile[256];
unsigned filehndl;
has_ext = FALSE;
has_path = FALSE;
endptr = name + name_len;
for( ptr = name; ptr != endptr; ++ptr ) {
switch( *ptr ) {
case '.':
has_ext = TRUE;
break;
case '/':
has_ext = FALSE;
has_path = TRUE;
/* fall through */
break;
}
}
memcpy( trpfile, name, name_len );
if( has_ext ) {
trpfile[name_len] = '\0';
} else {
trpfile[ name_len++ ] = '.';
memcpy( (char near *)&trpfile[ name_len ], exts, strlen( exts ) + 1 );
}
if( has_path ) {
filehndl = open( trpfile, O_RDONLY );
} else {
if( FindFilePath( trpfile, RWBuff ) == 0 ) {
filehndl = -1;
} else {
filehndl = open( RWBuff, O_RDONLY );
}
}
return( filehndl );
}
unsigned long GetSystemHandle( unsigned h )
{
return( h );
}
unsigned FileClose( unsigned h )
{
close( h );
return( 0 );
}
int WantUsage( char *ptr )
{
/*
This is a really stupid place to put this, but it's the first
system dependant code that the servers run. This code sets the
effective GID and UID back to the real ones so that the server
can be made set UID root without being a security hole. That allows
use to run at ring 1 for the parallel server/trap file.
*/
setegid( getgid() );
seteuid( getuid() );
if( *ptr == '?' ) return( TRUE );
return( FALSE );
}
void *DIGCliAlloc( unsigned amount )
{
return( malloc( amount ) );
}
void DIGCliFree( void *p )
{
free( p );
}
unsigned long DIGCliSeek( dig_fhandle h, unsigned long p,
dig_seek k )
{
return( lseek( h, p, k ) );
}
unsigned DIGCliRead( dig_fhandle h, void *b , unsigned s )
{
return( read( h, b, s ) );
}
void DIGCliClose( dig_fhandle h )
{
close( h );
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -