~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to mysys/mf_path.cc

  • Committer: Brian Aker
  • Date: 2009-01-20 23:03:10 UTC
  • mfrom: (779.1.23 devel)
  • Revision ID: brian@tangent.org-20090120230310-zqygzc4o915d0y3d
Merge from Monty

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* Copyright (C) 2000 MySQL AB
2
 
 
3
 
   This program is free software; you can redistribute it and/or modify
4
 
   it under the terms of the GNU General Public License as published by
5
 
   the Free Software Foundation; version 2 of the License.
6
 
 
7
 
   This program is distributed in the hope that it will be useful,
8
 
   but WITHOUT ANY WARRANTY; without even the implied warranty of
9
 
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
 
   GNU General Public License for more details.
11
 
 
12
 
   You should have received a copy of the GNU General Public License
13
 
   along with this program; if not, write to the Free Software
14
 
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
15
 
 
16
 
#include "mysys_priv.h"
17
 
#include <mystrings/m_string.h>
18
 
#include "my_static.h"
19
 
#include <drizzled/configmake.h>
20
 
#include <stdlib.h>
21
 
#include <sstream>
22
 
 
23
 
using namespace std;
24
 
 
25
 
static char *find_file_in_path(char *to,const char *name);
26
 
 
27
 
        /* Finds where program can find it's files.
28
 
           pre_pathname is found by first locking at progname (argv[0]).
29
 
           if progname contains path the path is returned.
30
 
           else if progname is found in path, return it
31
 
           else if progname is given and POSIX environment variable "_" is set
32
 
           then path is taken from "_".
33
 
           If filename doesn't contain a path append MY_BASEDIR_VERSION or
34
 
           MY_BASEDIR if defined, else append "/my/running".
35
 
           own_path_name_part is concatinated to result.
36
 
           my_path puts result in to and returns to */
37
 
 
38
 
char * my_path(char * to, const char *progname,
39
 
               const char *own_pathname_part)
40
 
{
41
 
  char *start, *prog;
42
 
  const char *end;
43
 
  size_t to_length;
44
 
 
45
 
  start=to;                                     /* Return this */
46
 
  if (progname && (dirname_part(to, progname, &to_length) ||
47
 
                   find_file_in_path(to,progname) ||
48
 
                   ((prog=getenv("_")) != 0 &&
49
 
                    dirname_part(to, prog, &to_length))))
50
 
  {
51
 
    intern_filename(to,to);
52
 
    if (!test_if_hard_path(to))
53
 
    {
54
 
      if (!getcwd(curr_dir,FN_REFLEN))
55
 
        bchange((unsigned char*) to, 0, (unsigned char*) curr_dir, strlen(curr_dir), strlen(to)+1);
56
 
    }
57
 
  }
58
 
  else
59
 
  {
60
 
    if ((end = getenv("MY_BASEDIR_VERSION")) == 0 &&
61
 
        (end = getenv("MY_BASEDIR")) == 0)
62
 
    {
63
 
      end= PREFIX;
64
 
    }
65
 
    intern_filename(to,end);
66
 
    to= strchr(to, '\0');
67
 
    if (to != start && to[-1] != FN_LIBCHAR)
68
 
      *to++ = FN_LIBCHAR;
69
 
    strcpy(to,own_pathname_part);
70
 
  }
71
 
  return(start);
72
 
} /* my_path */
73
 
 
74
 
 
75
 
        /* test if file without filename is found in path */
76
 
        /* Returns to if found and to has dirpart if found, else NULL */
77
 
 
78
 
#define PATH_SEP ':'
79
 
 
80
 
static char *find_file_in_path(char *to, const char *name)
81
 
{
82
 
  char *path, *pos, dir[2];
83
 
  const char *ext="";
84
 
  ostringstream sstream;
85
 
 
86
 
  if (!(path=getenv("PATH")))
87
 
    return NULL;
88
 
  dir[0]=FN_LIBCHAR; dir[1]=0;
89
 
#ifdef PROGRAM_EXTENSION
90
 
  if (!fn_ext(name)[0])
91
 
    ext=PROGRAM_EXTENSION;
92
 
#endif
93
 
 
94
 
  for (pos=path ; (pos=strchr(pos,PATH_SEP)) ; path= ++pos)
95
 
  {
96
 
    if (path != pos)
97
 
    {
98
 
      sstream << path << dir << name << ext  << '\0';
99
 
      strncpy(to, sstream.str().c_str(), sstream.str().length());
100
 
      if (!access(to,F_OK))
101
 
      {
102
 
        to[(uint) (pos-path)+1]=0;      /* Return path only */
103
 
        return to;
104
 
      }
105
 
    }
106
 
  }
107
 
  return NULL;                          /* File not found */
108
 
}
109
 
 
110
 
        /* Test if hard pathname */
111
 
        /* Returns true if dirname is a hard path */
112
 
 
113
 
bool test_if_hard_path(register const char *dir_name)
114
 
{
115
 
  if (dir_name[0] == FN_HOMELIB && dir_name[1] == FN_LIBCHAR)
116
 
    return (home_dir != NULL && test_if_hard_path(home_dir));
117
 
  if (dir_name[0] == FN_LIBCHAR)
118
 
    return (true);
119
 
  return false;
120
 
} /* test_if_hard_path */
121