~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to mysys/mf_format.cc

enable remaining subselect tests, merge with latest from the trunk

Show diffs side-by-side

added added

removed removed

Lines of Context:
24
24
*/
25
25
 
26
26
char * fn_format(char * to, const char *name, const char *dir,
27
 
                    const char *extension, uint flag)
 
27
                    const char *extension, uint32_t flag)
28
28
{
29
29
  char dev[FN_REFLEN], buff[FN_REFLEN], *pos;
30
30
  const char *startpos = name;
37
37
  if (length == 0 || (flag & MY_REPLACE_DIR))
38
38
  {
39
39
    /* Use given directory */
40
 
    convert_dirname(dev,dir,NullS);             /* Fix to this OS */
 
40
    convert_dirname(dev,dir,NULL);              /* Fix to this OS */
41
41
  }
42
42
  else if ((flag & MY_RELATIVE_PATH) && !test_if_hard_path(dev))
43
43
  {
44
44
    /* Put 'dir' before the given path */
45
 
    strmake(buff,dev,sizeof(buff)-1);
46
 
    pos=convert_dirname(dev,dir,NullS);
47
 
    strmake(pos,buff,sizeof(buff)-1- (int) (pos-dev));
 
45
    strncpy(buff,dev,sizeof(buff)-1);
 
46
    pos=convert_dirname(dev,dir,NULL);
 
47
    strncpy(pos,buff,sizeof(buff)-1- (int) (pos-dev));
48
48
  }
49
49
 
50
50
  if (flag & MY_PACK_FILENAME)
53
53
    (void) unpack_dirname(dev,dev);             /* Replace ~/.. with dir */
54
54
 
55
55
  if (!(flag & MY_APPEND_EXT) &&
56
 
      (pos= (char*) strchr(name,FN_EXTCHAR)) != NullS)
 
56
      (pos= (char*) strchr(name,FN_EXTCHAR)) != NULL)
57
57
  {
58
58
    if ((flag & MY_REPLACE_EXT) == 0)           /* If we should keep old ext */
59
59
    {
77
77
    /* To long path, return original or NULL */
78
78
    size_t tmp_length;
79
79
    if (flag & MY_SAFE_PATH)
80
 
      return NullS;
81
 
    tmp_length= strlength(startpos);
82
 
    (void) strmake(to,startpos,min(tmp_length,FN_REFLEN-1));
 
80
      return NULL;
 
81
    tmp_length= cmin(strlength(startpos), FN_REFLEN-1);
 
82
    strncpy(to,startpos,tmp_length);
 
83
    to[tmp_length]= '\0';
83
84
  }
84
85
  else
85
86
  {
86
87
    if (to == startpos)
87
88
    {
88
 
      memcpy(buff, name, length); /* Save name for last copy */
 
89
      memmove(buff, name, length); /* Save name for last copy */
89
90
      name=buff;
90
91
    }
91
 
    pos=strmake(stpcpy(to,dev),name,length);
92
 
    (void) stpcpy(pos,ext);                     /* Don't convert extension */
 
92
    char *tmp= strcpy(to, dev) + strlen(dev);
 
93
    pos= strncpy(tmp,name,length) + length;
 
94
    (void) strcpy(pos,ext);                     /* Don't convert extension */
93
95
  }
94
96
  /*
95
97
    If MY_RETURN_REAL_PATH and MY_RESOLVE_SYMLINK is given, only do
100
102
                                   MY_RESOLVE_LINK: 0));
101
103
  else if (flag & MY_RESOLVE_SYMLINKS)
102
104
  {
103
 
    stpcpy(buff,to);
 
105
    strcpy(buff,to);
104
106
    (void) my_readlink(to, buff, MYF(0));
105
107
  }
106
108
  return(to);