diff options
| author | Andi Gutmans <andi@php.net> | 2000-02-19 10:10:46 +0000 | 
|---|---|---|
| committer | Andi Gutmans <andi@php.net> | 2000-02-19 10:10:46 +0000 | 
| commit | 0cda28f77bcea25a35b2d55ee1bb52c5fdb34f2a (patch) | |
| tree | 11e6fbfcc15fe72ed98e6736d84b47ac9250fcc0 /ext/mysql/libmysql/mf_path.c | |
| parent | fe9abd3219b097e0c0f2c9106751d35b2bede2d6 (diff) | |
| download | php-git-0cda28f77bcea25a35b2d55ee1bb52c5fdb34f2a.tar.gz | |
- Add libmysql to the tree
Diffstat (limited to 'ext/mysql/libmysql/mf_path.c')
| -rw-r--r-- | ext/mysql/libmysql/mf_path.c | 106 | 
1 files changed, 106 insertions, 0 deletions
| diff --git a/ext/mysql/libmysql/mf_path.c b/ext/mysql/libmysql/mf_path.c new file mode 100644 index 0000000000..c51a79e238 --- /dev/null +++ b/ext/mysql/libmysql/mf_path.c @@ -0,0 +1,106 @@ +/* Copyright Abandoned 1996 TCX DataKonsult AB & Monty Program KB & Detron HB +   This file is public domain and comes with NO WARRANTY of any kind */ + +#include "mysys_priv.h" +#include <m_string.h> + +static char *find_file_in_path(char *to,const char *name); + +	/* Finds where program can find it's files. +	   pre_pathname is found by first locking at progname (argv[0]). +	   if progname contains path the path is returned. +	   else if progname is found in path, return it +	   else if progname is given and POSIX environment variable "_" is set +	   then path is taken from "_". +	   If filename doesn't contain a path append MY_BASEDIR_VERSION or +	   MY_BASEDIR if defined, else append "/my/running". +	   own_path_name_part is concatinated to result. +	   my_path puts result in to and returns to */ + +my_string my_path(my_string to, const char *progname, +		  const char *own_pathname_part) +{ +  my_string start,end,prog; +  DBUG_ENTER("my_path"); + +  start=to;					/* Return this */ +  if (progname && (dirname_part(to, progname) || +		   find_file_in_path(to,progname) || +		   ((prog=getenv("_")) != 0 && dirname_part(to,prog)))) +  { +    VOID(intern_filename(to,to)); +    if (!test_if_hard_path(to)) +    { +      if (!my_getwd(curr_dir,FN_REFLEN,MYF(0))) +	bchange(to,0,curr_dir,strlen(curr_dir),strlen(to)+1); +    } +  } +  else +  { +    if ((end = getenv("MY_BASEDIR_VERSION")) == 0 && +	(end = getenv("MY_BASEDIR")) == 0) +    { +#ifdef DEFAULT_BASEDIR +      end= (char*) DEFAULT_BASEDIR; +#else +      end= (char*) "/my/"; +#endif +    } +    VOID(intern_filename(to,end)); +    to=strend(to); +    if (to != start && to[-1] != FN_LIBCHAR) +      *to++ = FN_LIBCHAR; +    VOID(strmov(to,own_pathname_part)); +  } +  DBUG_PRINT("exit",("to: '%s'",start)); +  DBUG_RETURN(start); +} /* my_path */ + + +	/* test if file without filename is found in path */ +	/* Returns to if found and to has dirpart if found, else NullS */ + +#if defined(MSDOS) || defined(__WIN32__) +#define F_OK 0 +#define PATH_SEP ';' +#define PROGRAM_EXTENSION ".exe" +#else +#define PATH_SEP ':' +#endif + +static char *find_file_in_path(char *to, const char *name) +{ +  char *path,*pos,dir[2]; +  const char *ext=""; + +  if (!(path=getenv("PATH"))) +    return NullS; +  dir[0]=FN_LIBCHAR; dir[1]=0; +#ifdef PROGRAM_EXTENSION +  if (!fn_ext(name)[0]) +    ext=PROGRAM_EXTENSION; +#endif + +  for (pos=path ; (pos=strchr(pos,PATH_SEP)) ; path= ++pos) +  { +    if (path != pos) +    { +      strxmov(strnmov(to,path,(uint) (pos-path)),dir,name,ext,NullS); +      if (!access(to,F_OK)) +      { +	to[(uint) (pos-path)+1]=0;	/* Return path only */ +	return to; +      } +    } +  } +#ifdef __WIN32__ +  to[0]=FN_CURLIB; +  strxmov(to+1,dir,name,ext,NullS); +  if (!access(to,F_OK))			/* Test in current dir */ +  { +    to[2]=0;				/* Leave ".\" */ +    return to; +  } +#endif +  return NullS;				/* File not found */ +} | 
