mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-22 20:03:02 +01:00
Autoconf:
o added tests for nttab.h sys/mntent.h sys/mnttab.h o added tests for getcwd getwd setmntent getmntent o ISC_PREFIX renamed to FB_PREFIX o major code cleanup in src/jrd/isc_file.cpp Removed platform-specific files from posix/Makefile.in.firebird.
This commit is contained in:
parent
dade0c09a0
commit
eed374c06a
@ -27,7 +27,7 @@
|
|||||||
# Contributor(s):
|
# Contributor(s):
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# $Id: Makefile.in.firebird,v 1.18 2002-11-16 03:14:26 skywalker Exp $
|
# $Id: Makefile.in.firebird,v 1.19 2002-11-18 13:22:45 eku Exp $
|
||||||
#
|
#
|
||||||
|
|
||||||
ROOT=..
|
ROOT=..
|
||||||
@ -490,11 +490,14 @@ rebuild_codes :
|
|||||||
#___________________________________________________________________________
|
#___________________________________________________________________________
|
||||||
# Install generic files.
|
# Install generic files.
|
||||||
|
|
||||||
CLASSIC_MiscFiles = firebird.xinetd firebird.conf
|
CLASSIC_MiscFiles = firebird.conf
|
||||||
SUPER_MiscFiles = firebird.init.d.generic firebird.init.d.mandrake README firebird.conf
|
SUPER_MiscFiles = firebird.conf
|
||||||
|
|
||||||
|
ifeq ($(ArchType),super)
|
||||||
|
INSTALL_MiscFiles = $(addprefix $(FIREBIRD)/misc/, $(SUPER_MiscFiles))
|
||||||
|
else
|
||||||
INSTALL_MiscFiles = $(addprefix $(FIREBIRD)/misc/, $(CLASSIC_MiscFiles))
|
INSTALL_MiscFiles = $(addprefix $(FIREBIRD)/misc/, $(CLASSIC_MiscFiles))
|
||||||
#INSTALL_MiscFiles = $(addprefix $(FIREBIRD)/misc/, $(SUPER_MiscFiles))
|
endif
|
||||||
|
|
||||||
|
|
||||||
misc_files : $(INSTALL_MiscFiles)
|
misc_files : $(INSTALL_MiscFiles)
|
||||||
@ -512,8 +515,11 @@ CLASSIC_ScriptFiles = CSchangeRunUser.sh CSrestoreRootRunUser.sh changeDBAPasswo
|
|||||||
SUPER_ScriptFiles = SSchangeRunUser.sh SSrestoreRootRunUser.sh changeDBAPassword.sh
|
SUPER_ScriptFiles = SSchangeRunUser.sh SSrestoreRootRunUser.sh changeDBAPassword.sh
|
||||||
|
|
||||||
|
|
||||||
|
ifeq ($(ArchType),super)
|
||||||
|
INSTALL_ScriptFiles = $(addprefix $(BIN)/, $(SUPER_ScriptFiles))
|
||||||
|
else
|
||||||
INSTALL_ScriptFiles = $(addprefix $(BIN)/, $(CLASSIC_ScriptFiles))
|
INSTALL_ScriptFiles = $(addprefix $(BIN)/, $(CLASSIC_ScriptFiles))
|
||||||
#INSTALL_ScriptFiles = $(addprefix $(BIN)/, $(SUPER_ScriptFiles))
|
endif
|
||||||
|
|
||||||
|
|
||||||
script_files : $(INSTALL_ScriptFiles)
|
script_files : $(INSTALL_ScriptFiles)
|
||||||
|
31
configure.in
31
configure.in
@ -1,4 +1,4 @@
|
|||||||
dnl $Id: configure.in,v 1.91 2002-11-18 02:57:39 skywalker Exp $
|
dnl $Id: configure.in,v 1.92 2002-11-18 13:22:33 eku Exp $
|
||||||
|
|
||||||
dnl ############################# INITIALISATION ###############################
|
dnl ############################# INITIALISATION ###############################
|
||||||
|
|
||||||
@ -29,7 +29,7 @@ AC_SUBST(CPU_TYPE)
|
|||||||
|
|
||||||
dnl EKU: set appropiate defaults for each platform
|
dnl EKU: set appropiate defaults for each platform
|
||||||
dnl LOCK_MANAGER_FLG : build lock manager (CS only)
|
dnl LOCK_MANAGER_FLG : build lock manager (CS only)
|
||||||
dnl EDITLINE_FLG : support fancy command line editing in isql
|
dnl EDITLINE_FLG : support fancy command line editing in isql
|
||||||
|
|
||||||
case "$target" in
|
case "$target" in
|
||||||
*-*-darwin*)
|
*-*-darwin*)
|
||||||
@ -193,7 +193,6 @@ AC_ARG_WITH(editline,
|
|||||||
esac])
|
esac])
|
||||||
AC_SUBST(EDITLINE_FLG)
|
AC_SUBST(EDITLINE_FLG)
|
||||||
|
|
||||||
|
|
||||||
FB_SERVICE_NAME=gds_db
|
FB_SERVICE_NAME=gds_db
|
||||||
FB_SERVICE_PORT=3050
|
FB_SERVICE_PORT=3050
|
||||||
AC_ARG_WITH(service-name,
|
AC_ARG_WITH(service-name,
|
||||||
@ -242,7 +241,7 @@ AC_CHECK_HEADERS(crypt.h)
|
|||||||
AC_CHECK_HEADERS(netinet/in.h rpc/rpc.h netconfig.h)
|
AC_CHECK_HEADERS(netinet/in.h rpc/rpc.h netconfig.h)
|
||||||
AC_CHECK_HEADERS(rpc/xdr.h,,,[#include <rpc/rpc.h>])
|
AC_CHECK_HEADERS(rpc/xdr.h,,,[#include <rpc/rpc.h>])
|
||||||
AC_CHECK_HEADERS(aio.h)
|
AC_CHECK_HEADERS(aio.h)
|
||||||
AC_CHECK_HEADERS(mntent.h)
|
AC_CHECK_HEADERS(mntent.h mnttab.h sys/mntent.h sys/mnttab.h)
|
||||||
|
|
||||||
dnl Check for libraries
|
dnl Check for libraries
|
||||||
AC_CHECK_LIB(dl, main)
|
AC_CHECK_LIB(dl, main)
|
||||||
@ -259,6 +258,10 @@ if test "$EDITLINE_FLG" = "Y"; then
|
|||||||
fi
|
fi
|
||||||
AC_CHECK_LIB(stdc++, main,,, $LIBS)
|
AC_CHECK_LIB(stdc++, main,,, $LIBS)
|
||||||
AC_CHECK_LIB(sfio, main,,, $LIBS) dnl Solaris only
|
AC_CHECK_LIB(sfio, main,,, $LIBS) dnl Solaris only
|
||||||
|
dnl kkuznetsov: Solaris always check for -lnsl
|
||||||
|
if test "$PLATFORM" = "solx86" ; then
|
||||||
|
AC_CHECK_LIB(nsl, gethostname, XE_APPEND(-lnsl,LIBS))
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl Check for functions
|
dnl Check for functions
|
||||||
@ -284,11 +287,6 @@ AC_CHECK_FUNCS(gethostname connect)
|
|||||||
if test "$ac_cv_func_gethostname" = "no"; then
|
if test "$ac_cv_func_gethostname" = "no"; then
|
||||||
AC_CHECK_LIB(nsl, gethostname, XE_APPEND(-lnsl,LIBS))
|
AC_CHECK_LIB(nsl, gethostname, XE_APPEND(-lnsl,LIBS))
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$PLATFORM" = "solx86" ; then
|
|
||||||
AC_CHECK_LIB(nsl, gethostname, XE_APPEND(-lnsl,LIBS))
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$ac_cv_func_connect" = "no"; then
|
if test "$ac_cv_func_connect" = "no"; then
|
||||||
AC_CHECK_LIB(socket, connect, XE_APPEND(-lsocket,LIBS),, $LIBS)
|
AC_CHECK_LIB(socket, connect, XE_APPEND(-lsocket,LIBS),, $LIBS)
|
||||||
fi
|
fi
|
||||||
@ -321,6 +319,16 @@ AC_CHECK_FUNCS(getpagesize)
|
|||||||
AC_CHECK_FUNCS(crypt)
|
AC_CHECK_FUNCS(crypt)
|
||||||
AC_CHECK_FUNCS(xdr_hyper)
|
AC_CHECK_FUNCS(xdr_hyper)
|
||||||
AC_CHECK_FUNCS(pread pwrite)
|
AC_CHECK_FUNCS(pread pwrite)
|
||||||
|
AC_CHECK_FUNCS(getcwd getwd)
|
||||||
|
AC_CHECK_FUNCS(setmntent getmntent)
|
||||||
|
if test "$ac_cv_func_getmntent" = "yes"; then
|
||||||
|
AC_MSG_CHECKING(if getmntent needs second argument)
|
||||||
|
AC_TRY_COMPILE([#include <stdio.h>
|
||||||
|
#include <sys/mnttab.h>],
|
||||||
|
[FILE *f; struct mntent *m; getmntent(f, m);],
|
||||||
|
[AC_DEFINE(GETMNTENT_TAKES_TWO_ARGUMENTS) AC_MSG_RESULT(yes)],
|
||||||
|
[AC_MSG_RESULT(no)])
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl Check for other things
|
dnl Check for other things
|
||||||
@ -337,6 +345,7 @@ AC_CHECK_TYPES([struct XDR::xdr_ops],,,[#include <rpc/rpc.h>
|
|||||||
AC_CHECK_TYPES([struct xdr_ops],,,[#include <rpc/rpc.h>
|
AC_CHECK_TYPES([struct xdr_ops],,,[#include <rpc/rpc.h>
|
||||||
#include <rpc/xdr.h>])
|
#include <rpc/xdr.h>])
|
||||||
|
|
||||||
|
|
||||||
dnl EKU: try to determine the alignment of long and double
|
dnl EKU: try to determine the alignment of long and double
|
||||||
dnl replaces ALIGNMENT and DOUBLE_ALIGN in src/jrd/common.h
|
dnl replaces ALIGNMENT and DOUBLE_ALIGN in src/jrd/common.h
|
||||||
AC_MSG_CHECKING(alignment of long)
|
AC_MSG_CHECKING(alignment of long)
|
||||||
@ -429,7 +438,7 @@ NEW_FIREBIRD_DIR=$GEN_ROOT/firebird
|
|||||||
AC_SUBST(BUILD_ROOT_DIR)
|
AC_SUBST(BUILD_ROOT_DIR)
|
||||||
AC_SUBST(NEW_FIREBIRD_DIR)
|
AC_SUBST(NEW_FIREBIRD_DIR)
|
||||||
|
|
||||||
AC_DEFINE_UNQUOTED(ISC_PREFIX, $(if test "x$prefix" = "xNONE" ; then echo \"$ac_default_prefix\"; else echo \"$prefix\"; fi))
|
AC_DEFINE_UNQUOTED(FB_PREFIX, $(if test "x$prefix" = "xNONE" ; then echo \"$ac_default_prefix\"; else echo \"$prefix\"; fi))
|
||||||
|
|
||||||
AC_CONFIG_COMMANDS_PRE([
|
AC_CONFIG_COMMANDS_PRE([
|
||||||
mkdir -p gen/csv
|
mkdir -p gen/csv
|
||||||
@ -610,8 +619,6 @@ case $PLATFORM in
|
|||||||
])
|
])
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SINIX-Z)
|
SINIX-Z)
|
||||||
AC_CONFIG_FILES([
|
AC_CONFIG_FILES([
|
||||||
gen/install/pkginfo:src/install/arch-specific/sinixz/pkginfo.in
|
gen/install/pkginfo:src/install/arch-specific/sinixz/pkginfo.in
|
||||||
|
@ -74,6 +74,9 @@
|
|||||||
#undef HAVE_RPC_XDR_H
|
#undef HAVE_RPC_XDR_H
|
||||||
#undef HAVE_AIO_H
|
#undef HAVE_AIO_H
|
||||||
#undef HAVE_MNTENT_H
|
#undef HAVE_MNTENT_H
|
||||||
|
#undef HAVE_MNTTAB_H
|
||||||
|
#undef HAVE_SYS_MNTENT_H
|
||||||
|
#undef HAVE_SYS_MNTTAB_H
|
||||||
|
|
||||||
|
|
||||||
/* Functions */
|
/* Functions */
|
||||||
@ -103,6 +106,11 @@
|
|||||||
#undef HAVE_XDR_HYPER
|
#undef HAVE_XDR_HYPER
|
||||||
#undef HAVE_PREAD
|
#undef HAVE_PREAD
|
||||||
#undef HAVE_PWRITE
|
#undef HAVE_PWRITE
|
||||||
|
#undef HAVE_GETCWD
|
||||||
|
#undef HAVE_GETWD
|
||||||
|
#undef HAVE_SETMNTENT
|
||||||
|
#undef HAVE_GETMNTENT
|
||||||
|
#undef GETMNTENT_TAKES_TWO_ARGUMENTS
|
||||||
|
|
||||||
/* Types */
|
/* Types */
|
||||||
#undef socklen_t
|
#undef socklen_t
|
||||||
|
@ -58,6 +58,17 @@
|
|||||||
#include "../jrd/isc_f_proto.h"
|
#include "../jrd/isc_f_proto.h"
|
||||||
#include "../jrd/jrd_proto.h"
|
#include "../jrd/jrd_proto.h"
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/ipc.h>
|
||||||
|
#include <sys/file.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_PWD_H
|
||||||
|
#include <pwd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../common/config/config.h"
|
#include "../common/config/config.h"
|
||||||
|
|
||||||
/* VMS Specific Stuff */
|
/* VMS Specific Stuff */
|
||||||
@ -88,16 +99,51 @@ typedef struct itm {
|
|||||||
#endif /* of ifdef VMS */
|
#endif /* of ifdef VMS */
|
||||||
|
|
||||||
|
|
||||||
/* Unix/NFS specific stuff */
|
#ifdef SUPERSERVER
|
||||||
|
#define GETWD(buf) JRD_getdir(buf, MAXPATHLEN)
|
||||||
|
#else
|
||||||
|
#ifdef HAVE_GETCWD
|
||||||
|
#define GETWD(buf) getcwd(buf, MAXPATHLEN)
|
||||||
|
#else
|
||||||
|
#define GETWD getwd
|
||||||
|
#endif
|
||||||
|
#endif /* SUPERSERVER */
|
||||||
|
|
||||||
#ifdef HAVE_PWD_H
|
|
||||||
#include <pwd.h>
|
/* Unix/NFS specific stuff */
|
||||||
|
#ifndef NO_NFS
|
||||||
|
#ifdef HAVE_MNTENT_H
|
||||||
|
#include <mntent.h> /* get setmntent/endmntent */
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_SYS_MNTTAB_H
|
||||||
|
#include <sys/mnttab.h> /* get MNTTAB/_PATH_MNTTAB */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* EKU: if you get a compiler warning/error about redefinition of MTAB,
|
||||||
|
please remove the define from the platform-specific section below
|
||||||
|
and not here! */
|
||||||
|
#ifdef MNTTAB
|
||||||
|
#define MTAB MNTTAB
|
||||||
|
#else
|
||||||
|
#ifdef _PATH_MNTTAB
|
||||||
|
#define MTAB _PATH_MNTTAB
|
||||||
|
#else
|
||||||
|
#define MTAB "/etc/mtab"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SETMNTENT
|
||||||
|
#define MTAB_OPEN(path,type) setmntent(path, "r")
|
||||||
|
#define MTAB_CLOSE(stream) endmntent(stream)
|
||||||
|
#else
|
||||||
|
#define MTAB_OPEN(path,type) ib_fopen(path, type)
|
||||||
|
#define MTAB_CLOSE(stream) ib_fclose(stream)
|
||||||
|
#endif
|
||||||
|
#endif /* NO_NFS */
|
||||||
|
|
||||||
|
|
||||||
#ifdef hpux
|
#ifdef hpux
|
||||||
#define GETWD(buf) getcwd (buf, MAXPATHLEN)
|
|
||||||
#define MTAB "/etc/mnttab"
|
#define MTAB "/etc/mnttab"
|
||||||
#include <sys/types.h>
|
|
||||||
/* RITTER - added HP11 to the pre-processor condition below */
|
/* RITTER - added HP11 to the pre-processor condition below */
|
||||||
#if !(defined HP10 || defined HP11)
|
#if !(defined HP10 || defined HP11)
|
||||||
#include <cluster.h>
|
#include <cluster.h>
|
||||||
@ -105,38 +151,22 @@ typedef struct itm {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SOLARIS
|
#ifdef SOLARIS
|
||||||
#define SV_MNTENT
|
|
||||||
#include <sys/mnttab.h>
|
|
||||||
#define MTAB "/etc/mnttab"
|
#define MTAB "/etc/mnttab"
|
||||||
#define MTAB_OPEN(path,type) ib_fopen (path, type)
|
|
||||||
#define MTAB_CLOSE(stream) ib_fclose (stream)
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef FREEBSD
|
#ifdef FREEBSD
|
||||||
#define MTAB "/etc/fstab"
|
#define MTAB "/etc/fstab"
|
||||||
#define MTAB_OPEN(path,type) ib_fopen (path, type)
|
|
||||||
#define MTAB_CLOSE(stream) ib_fclose (stream)
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DARWIN
|
#ifdef DARWIN
|
||||||
#define MTAB "/etc/fstab.hd"
|
#define MTAB "/etc/fstab.hd"
|
||||||
#define MTAB_OPEN(path,type) ib_fopen (path, type)
|
|
||||||
#define MTAB_CLOSE(stream) ib_fclose (stream)
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SCO_UNIX
|
#ifdef SCO_UNIX
|
||||||
|
/* EKU: popen/pclose to access a file??? */
|
||||||
#define MTAB "/etc/mount"
|
#define MTAB "/etc/mount"
|
||||||
#define MTAB_OPEN(path,type) popen (path, type)
|
#define MTAB_OPEN(path,type) popen (path, type)
|
||||||
#define MTAB_CLOSE(stream) pclose (stream)
|
#define MTAB_CLOSE(stream) pclose (stream)
|
||||||
#define GETWD(buf) getcwd (buf, MAXPATHLEN)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SINIXZ
|
|
||||||
#include <sys/mnttab.h>
|
|
||||||
#define SV_MNTENT
|
|
||||||
#define MTAB "/etc/mnttab"
|
|
||||||
#define MTAB_OPEN(path,type) fopen (path, type)
|
|
||||||
#define MTAB_CLOSE(stream) fclose (stream)
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ultrix
|
#ifdef ultrix
|
||||||
@ -148,30 +178,6 @@ typedef struct itm {
|
|||||||
#include <sys/vmount.h>
|
#include <sys/vmount.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined SOLARIS || defined linux || defined FREEBSD || defined NETBSD || defined DARWIN || defined SINIXZ)
|
|
||||||
#define GETWD(buf) getcwd (buf, MAXPATHLEN)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SUPERSERVER
|
|
||||||
#undef GETWD
|
|
||||||
#define GETWD(buf) JRD_getdir (buf, MAXPATHLEN)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef GETWD
|
|
||||||
#define GETWD getwd
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_MNTENT_H
|
|
||||||
#ifndef NO_NFS
|
|
||||||
#include <mntent.h>
|
|
||||||
#define MTAB_OPEN(path,type) setmntent (path, "r")
|
|
||||||
#define MTAB_CLOSE(stream) endmntent (stream)
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef MTAB
|
|
||||||
#define MTAB "/etc/mtab"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct mnt {
|
typedef struct mnt {
|
||||||
TEXT *mnt_node;
|
TEXT *mnt_node;
|
||||||
@ -180,25 +186,6 @@ typedef struct mnt {
|
|||||||
} MNT;
|
} MNT;
|
||||||
|
|
||||||
|
|
||||||
/* Unix specific stuff */
|
|
||||||
|
|
||||||
#ifdef UNIX
|
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/ipc.h>
|
|
||||||
#include <sys/file.h>
|
|
||||||
#include <errno.h>
|
|
||||||
|
|
||||||
#ifdef DARWIN
|
|
||||||
#include </usr/include/pwd.h>
|
|
||||||
#else
|
|
||||||
extern struct passwd *getpwnam(), *getpwuid();
|
|
||||||
#endif
|
|
||||||
#endif // UNIX
|
|
||||||
|
|
||||||
|
|
||||||
/* Windows NT stuff */
|
/* Windows NT stuff */
|
||||||
#ifdef WIN_NT
|
#ifdef WIN_NT
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
@ -1500,9 +1487,9 @@ static BOOLEAN get_mounts(
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_GETMNTENT) && !defined(SOLARIS)
|
||||||
#if defined(SV_MNTENT) && !defined(SOLARIS)
|
|
||||||
#define GET_MOUNTS
|
#define GET_MOUNTS
|
||||||
|
#if defined(GETMNTENT_TAKES_TWO_ARGUMENTS) /* SYSV stylish */
|
||||||
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
||||||
{
|
{
|
||||||
/**************************************
|
/**************************************
|
||||||
@ -1547,14 +1534,12 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
else
|
else
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
#endif
|
#else /* !GETMNTENT_TAKES_TWO_ARGUMENTS */
|
||||||
#ifdef SOLARIS
|
|
||||||
#define GET_MOUNTS
|
|
||||||
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
||||||
{
|
{
|
||||||
/**************************************
|
/**************************************
|
||||||
*
|
*
|
||||||
* g e t _ m o u n t s ( S O L A R I S )
|
* g e t _ m o u n t s ( M N T E N T )
|
||||||
*
|
*
|
||||||
**************************************
|
**************************************
|
||||||
*
|
*
|
||||||
@ -1562,40 +1547,24 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
* Get ALL mount points.
|
* Get ALL mount points.
|
||||||
*
|
*
|
||||||
**************************************/
|
**************************************/
|
||||||
|
TEXT *p, *q;
|
||||||
/* Since we had to substitute our alternative for the stdio supplied
|
struct mntent *mptr;
|
||||||
with Solaris, we cannot use the getmntent() library call which
|
|
||||||
wants a Solaris stdio FILE* as an argument, so we parse the text-
|
|
||||||
type /etc/mnttab file ourselves. */
|
|
||||||
|
|
||||||
TEXT device[128], mount_point[128], type[128], rw[128], foo1[128], *p, *q;
|
|
||||||
SSHORT n;
|
|
||||||
|
|
||||||
/* Start by finding a mount point. */
|
/* Start by finding a mount point. */
|
||||||
|
|
||||||
p = buffer;
|
p = buffer;
|
||||||
|
|
||||||
for (;;) {
|
while ((mptr = getmntent(file)) != (struct mntent *)0) {
|
||||||
/* device, mountpoint, type, options, a number */
|
|
||||||
|
|
||||||
n = ib_fscanf(file, "%s %s %s %s %s",
|
|
||||||
device, mount_point, type, rw, foo1);
|
|
||||||
|
|
||||||
/* This should either be 5 (we got a line with 5 args, or EOF (we
|
|
||||||
got nothing. If we're short of 5, assume EOF */
|
|
||||||
if (n != 5)
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Include non-NFS (local) mounts - some may be longer than
|
/* Include non-NFS (local) mounts - some may be longer than
|
||||||
NFS mount points */
|
NFS mount points */
|
||||||
|
|
||||||
/****
|
/****
|
||||||
if (strcmp (type, "nfs"))
|
if (strcmp (mptr->mnt_type, MNTTYPE_NFS))
|
||||||
continue;
|
continue;
|
||||||
****/
|
****/
|
||||||
|
|
||||||
mount->mnt_node = p;
|
mount->mnt_node = p;
|
||||||
q = device;
|
q = mptr->mnt_fsname;
|
||||||
while (*q && *q != ':')
|
while (*q && *q != ':')
|
||||||
*p++ = *q++;
|
*p++ = *q++;
|
||||||
*p++ = 0;
|
*p++ = 0;
|
||||||
@ -1605,16 +1574,14 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
q++;
|
q++;
|
||||||
mount->mnt_path = p;
|
mount->mnt_path = p;
|
||||||
while (*p++ = *q++);
|
while (*p++ = *q++);
|
||||||
mount->mnt_mount = p;
|
mount->mnt_mount = mptr->mnt_dir;
|
||||||
q = mount_point;
|
|
||||||
while (*p++ = *q++);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
#endif
|
#endif /* GETMNTENT_TAKES_TWO_ARGUMENTS */
|
||||||
|
#endif /* HAVE_GETMNTENT && !SOLARIS */
|
||||||
|
|
||||||
#ifdef SCO_UNIX
|
#ifdef SCO_UNIX
|
||||||
#define GET_MOUNTS
|
#define GET_MOUNTS
|
||||||
@ -1679,57 +1646,6 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_MNTENT_H
|
|
||||||
#define GET_MOUNTS
|
|
||||||
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|
||||||
{
|
|
||||||
/**************************************
|
|
||||||
*
|
|
||||||
* g e t _ m o u n t s ( M N T E N T )
|
|
||||||
*
|
|
||||||
**************************************
|
|
||||||
*
|
|
||||||
* Functional description
|
|
||||||
* Get ALL mount points.
|
|
||||||
*
|
|
||||||
**************************************/
|
|
||||||
TEXT *p, *q;
|
|
||||||
struct mntent *mptr;
|
|
||||||
|
|
||||||
/* Start by finding a mount point. */
|
|
||||||
|
|
||||||
p = buffer;
|
|
||||||
|
|
||||||
while (mptr = getmntent(file)) {
|
|
||||||
/* Include non-NFS (local) mounts - some may be longer than
|
|
||||||
NFS mount points */
|
|
||||||
|
|
||||||
/****
|
|
||||||
if (strcmp (mptr->mnt_type, MNTTYPE_NFS))
|
|
||||||
continue;
|
|
||||||
****/
|
|
||||||
|
|
||||||
mount->mnt_node = p;
|
|
||||||
q = mptr->mnt_fsname;
|
|
||||||
while (*q && *q != ':')
|
|
||||||
*p++ = *q++;
|
|
||||||
*p++ = 0;
|
|
||||||
if (*q != ':')
|
|
||||||
mount->mnt_node = NULL;
|
|
||||||
if (*q)
|
|
||||||
q++;
|
|
||||||
mount->mnt_path = p;
|
|
||||||
while (*p++ = *q++);
|
|
||||||
mount->mnt_mount = mptr->mnt_dir;
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
#endif /* HAVE_MNTENT_H */
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef GET_MOUNTS
|
#ifndef GET_MOUNTS
|
||||||
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
||||||
{
|
{
|
||||||
@ -1751,10 +1667,12 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
p = buffer;
|
p = buffer;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
n =
|
n = ib_fscanf(file, "%s %s %s %s %s %s", device, mount_point, type, rw, foo1, foo1);
|
||||||
ib_fscanf(file, "%s %s %s %s %s %s", device, mount_point, type,
|
#ifdef SOLARIS
|
||||||
rw, foo1, foo1);
|
if (n != 5)
|
||||||
|
#else
|
||||||
if (n < 0)
|
if (n < 0)
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Include non-NFS (local) mounts - some may be longer than
|
/* Include non-NFS (local) mounts - some may be longer than
|
||||||
@ -1786,7 +1704,6 @@ static BOOLEAN get_mounts(MNT * mount, TEXT * buffer, IB_FILE * file)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef hpux
|
#ifdef hpux
|
||||||
/* RITTER - added HP11 to the pre-processor condition below */
|
/* RITTER - added HP11 to the pre-processor condition below */
|
||||||
#if !(defined HP10 || defined HP11)
|
#if !(defined HP10 || defined HP11)
|
||||||
@ -1799,7 +1716,7 @@ static BOOLEAN get_server(TEXT * file_name, TEXT * node_name)
|
|||||||
**************************************
|
**************************************
|
||||||
*
|
*
|
||||||
* Functional description
|
* Functional description
|
||||||
* If we're running on a cnode, the file system beSLONGs
|
* If we're running on a cnode, the file system belongs
|
||||||
* to the server node - load node_name with the server
|
* to the server node - load node_name with the server
|
||||||
* name and return TRUE.
|
* name and return TRUE.
|
||||||
*
|
*
|
||||||
|
@ -4188,8 +4188,12 @@ USHORT JRD_getdir(TEXT * buf, USHORT len)
|
|||||||
pwd = getpwnam(buf);
|
pwd = getpwnam(buf);
|
||||||
if (pwd)
|
if (pwd)
|
||||||
strcpy(buf, pwd->pw_dir);
|
strcpy(buf, pwd->pw_dir);
|
||||||
else /* No home dir for this users here. Default to server dir */
|
else /* No home dir for this users here. Default to server dir */
|
||||||
|
#ifdef HAVE_GETCWD
|
||||||
getcwd(buf, len);
|
getcwd(buf, len);
|
||||||
|
#else
|
||||||
|
getwd(buf);
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -5095,7 +5099,11 @@ static void get_options(UCHAR* dpb,
|
|||||||
else { /*No home dir for this users here. Default to server dir */
|
else { /*No home dir for this users here. Default to server dir */
|
||||||
|
|
||||||
**scratch = 0;
|
**scratch = 0;
|
||||||
|
#ifdef HAVE_GETCWD
|
||||||
if (getcwd(*scratch, MIN(MAXPATHLEN, buf_size)))
|
if (getcwd(*scratch, MIN(MAXPATHLEN, buf_size)))
|
||||||
|
#else
|
||||||
|
if (getwd(*scratch))
|
||||||
|
#endif
|
||||||
l = strlen(*scratch) + 1;
|
l = strlen(*scratch) + 1;
|
||||||
else
|
else
|
||||||
l = buf_size;
|
l = buf_size;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#ident "$Id: config.h.in,v 1.59 2002-11-15 10:55:34 kkuznetsov Exp $"
|
#ident "$Id: config.h.in,v 1.60 2002-11-18 13:22:57 eku Exp $"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 2002.02.15 Sean Leyne - Code Cleanup, removed obsolete ports:
|
* 2002.02.15 Sean Leyne - Code Cleanup, removed obsolete ports:
|
||||||
@ -55,6 +55,9 @@
|
|||||||
#undef HAVE_RPC_XDR_H
|
#undef HAVE_RPC_XDR_H
|
||||||
#undef HAVE_AIO_H
|
#undef HAVE_AIO_H
|
||||||
#undef HAVE_MNTENT_H
|
#undef HAVE_MNTENT_H
|
||||||
|
#undef HAVE_MNTTAB_H
|
||||||
|
#undef HAVE_SYS_MNTENT_H
|
||||||
|
#undef HAVE_SYS_MNTTAB_H
|
||||||
|
|
||||||
|
|
||||||
/* Functions */
|
/* Functions */
|
||||||
@ -84,6 +87,11 @@
|
|||||||
#undef HAVE_XDR_HYPER
|
#undef HAVE_XDR_HYPER
|
||||||
#undef HAVE_PREAD
|
#undef HAVE_PREAD
|
||||||
#undef HAVE_PWRITE
|
#undef HAVE_PWRITE
|
||||||
|
#undef HAVE_GETCWD
|
||||||
|
#undef HAVE_GETWD
|
||||||
|
#undef HAVE_SETMNTENT
|
||||||
|
#undef HAVE_GETMNTENT
|
||||||
|
#undef GETMNTENT_TAKES_TWO_ARGUMENTS
|
||||||
|
|
||||||
|
|
||||||
/* Types */
|
/* Types */
|
||||||
|
@ -4753,7 +4753,11 @@ static void add_working_directory(UCHAR* dpb_or_spb,
|
|||||||
|
|
||||||
if (node_name && !strcmp(node_name, "localhost"))
|
if (node_name && !strcmp(node_name, "localhost"))
|
||||||
{
|
{
|
||||||
|
#ifdef HAVE_GETCWD
|
||||||
getcwd(cwd, sizeof(cwd));
|
getcwd(cwd, sizeof(cwd));
|
||||||
|
#else
|
||||||
|
getwd(cwd);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user