1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir #include "system.h" 29*cdf0e10cSrcweir 30*cdf0e10cSrcweir #ifdef NO_PTHREAD_RTL 31*cdf0e10cSrcweir 32*cdf0e10cSrcweir static pthread_mutex_t getrtl_mutex = PTHREAD_MUTEX_INITIALIZER; 33*cdf0e10cSrcweir 34*cdf0e10cSrcweir /* struct passwd differs on some platforms */ 35*cdf0e10cSrcweir #if defined NETBSD 36*cdf0e10cSrcweir struct passwd *getpwnam_r(const char* name, struct passwd* s, char* buffer, int size ) 37*cdf0e10cSrcweir { 38*cdf0e10cSrcweir struct passwd* res; 39*cdf0e10cSrcweir 40*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 41*cdf0e10cSrcweir 42*cdf0e10cSrcweir if ( (res = getpwnam(name)) ) 43*cdf0e10cSrcweir { 44*cdf0e10cSrcweir int nname, npasswd, nclass, ngecos, ndir; 45*cdf0e10cSrcweir 46*cdf0e10cSrcweir nname= strlen(res->pw_name)+1; 47*cdf0e10cSrcweir npasswd= strlen(res->pw_passwd)+1; 48*cdf0e10cSrcweir nclass= strlen(res->pw_class)+1; 49*cdf0e10cSrcweir ngecos= strlen(res->pw_gecos)+1; 50*cdf0e10cSrcweir ndir= strlen(res->pw_dir)+1; 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir if (nname+npasswd+nclass+ngecos 53*cdf0e10cSrcweir +ndir+strlen(res->pw_shell) < size) 54*cdf0e10cSrcweir { 55*cdf0e10cSrcweir memcpy(s, res, sizeof(struct passwd)); 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir strcpy(buffer, res->pw_name); 58*cdf0e10cSrcweir s->pw_name = buffer; 59*cdf0e10cSrcweir buffer += nname; 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir strcpy(buffer, res->pw_passwd); 62*cdf0e10cSrcweir s->pw_passwd = buffer; 63*cdf0e10cSrcweir buffer += npasswd; 64*cdf0e10cSrcweir 65*cdf0e10cSrcweir strcpy(buffer, res->pw_class); 66*cdf0e10cSrcweir s->pw_class = buffer; 67*cdf0e10cSrcweir buffer += nclass; 68*cdf0e10cSrcweir 69*cdf0e10cSrcweir strcpy(buffer, res->pw_gecos); 70*cdf0e10cSrcweir s->pw_gecos = buffer; 71*cdf0e10cSrcweir buffer += ngecos; 72*cdf0e10cSrcweir 73*cdf0e10cSrcweir strcpy(buffer, res->pw_dir); 74*cdf0e10cSrcweir s->pw_dir = buffer; 75*cdf0e10cSrcweir buffer += ndir; 76*cdf0e10cSrcweir 77*cdf0e10cSrcweir strcpy(buffer, res->pw_shell); 78*cdf0e10cSrcweir s->pw_shell = buffer; 79*cdf0e10cSrcweir 80*cdf0e10cSrcweir res = s; 81*cdf0e10cSrcweir } 82*cdf0e10cSrcweir else 83*cdf0e10cSrcweir res = 0; 84*cdf0e10cSrcweir } 85*cdf0e10cSrcweir 86*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 87*cdf0e10cSrcweir 88*cdf0e10cSrcweir return(res); 89*cdf0e10cSrcweir } 90*cdf0e10cSrcweir 91*cdf0e10cSrcweir int getpwuid_r(uid_t uid, struct passwd *pwd, char *buffer, 92*cdf0e10cSrcweir size_t buflen, struct passwd **result) 93*cdf0e10cSrcweir { 94*cdf0e10cSrcweir struct passwd* res; 95*cdf0e10cSrcweir int retval = 0; 96*cdf0e10cSrcweir 97*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 98*cdf0e10cSrcweir 99*cdf0e10cSrcweir if ( (res = getpwuid(uid)) ) 100*cdf0e10cSrcweir { 101*cdf0e10cSrcweir size_t pw_name, pw_passwd, pw_class, pw_gecos, pw_dir, pw_shell; 102*cdf0e10cSrcweir 103*cdf0e10cSrcweir pw_name = strlen(res->pw_name)+1; 104*cdf0e10cSrcweir pw_passwd = strlen(res->pw_passwd)+1; 105*cdf0e10cSrcweir pw_class = strlen(res->pw_class)+1; 106*cdf0e10cSrcweir pw_gecos = strlen(res->pw_gecos)+1; 107*cdf0e10cSrcweir pw_dir = strlen(res->pw_dir)+1; 108*cdf0e10cSrcweir pw_shell = strlen(res->pw_shell)+1; 109*cdf0e10cSrcweir 110*cdf0e10cSrcweir if (pw_name+pw_passwd+pw_class+pw_gecos 111*cdf0e10cSrcweir +pw_dir+pw_shell < buflen) 112*cdf0e10cSrcweir { 113*cdf0e10cSrcweir memcpy(pwd, res, sizeof(struct passwd)); 114*cdf0e10cSrcweir 115*cdf0e10cSrcweir strncpy(buffer, res->pw_name, pw_name); 116*cdf0e10cSrcweir pwd->pw_name = buffer; 117*cdf0e10cSrcweir buffer += pw_name; 118*cdf0e10cSrcweir 119*cdf0e10cSrcweir strncpy(buffer, res->pw_passwd, pw_passwd); 120*cdf0e10cSrcweir pwd->pw_passwd = buffer; 121*cdf0e10cSrcweir buffer += pw_passwd; 122*cdf0e10cSrcweir 123*cdf0e10cSrcweir strncpy(buffer, res->pw_class, pw_class); 124*cdf0e10cSrcweir pwd->pw_class = buffer; 125*cdf0e10cSrcweir buffer += pw_class; 126*cdf0e10cSrcweir 127*cdf0e10cSrcweir strncpy(buffer, res->pw_gecos, pw_gecos); 128*cdf0e10cSrcweir pwd->pw_gecos = buffer; 129*cdf0e10cSrcweir buffer += pw_gecos; 130*cdf0e10cSrcweir 131*cdf0e10cSrcweir strncpy(buffer, res->pw_dir, pw_dir); 132*cdf0e10cSrcweir pwd->pw_dir = buffer; 133*cdf0e10cSrcweir buffer += pw_dir; 134*cdf0e10cSrcweir 135*cdf0e10cSrcweir strncpy(buffer, res->pw_shell, pw_shell); 136*cdf0e10cSrcweir pwd->pw_shell = buffer; 137*cdf0e10cSrcweir buffer += pw_shell; 138*cdf0e10cSrcweir 139*cdf0e10cSrcweir *result = pwd ; 140*cdf0e10cSrcweir retval = 0 ; 141*cdf0e10cSrcweir 142*cdf0e10cSrcweir } 143*cdf0e10cSrcweir else 144*cdf0e10cSrcweir retval = ENOMEM; 145*cdf0e10cSrcweir } 146*cdf0e10cSrcweir else 147*cdf0e10cSrcweir retval = errno ; 148*cdf0e10cSrcweir 149*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 150*cdf0e10cSrcweir 151*cdf0e10cSrcweir return retval; 152*cdf0e10cSrcweir } 153*cdf0e10cSrcweir 154*cdf0e10cSrcweir struct tm *localtime_r(const time_t *timep, struct tm *buffer) 155*cdf0e10cSrcweir { 156*cdf0e10cSrcweir struct tm* res; 157*cdf0e10cSrcweir 158*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 159*cdf0e10cSrcweir 160*cdf0e10cSrcweir if ( (res = localtime(timep))) 161*cdf0e10cSrcweir { 162*cdf0e10cSrcweir memcpy(buffer, res, sizeof(struct tm)); 163*cdf0e10cSrcweir res = buffer; 164*cdf0e10cSrcweir } 165*cdf0e10cSrcweir 166*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 167*cdf0e10cSrcweir 168*cdf0e10cSrcweir return res; 169*cdf0e10cSrcweir } 170*cdf0e10cSrcweir 171*cdf0e10cSrcweir struct tm *gmtime_r(const time_t *timep, struct tm *buffer) 172*cdf0e10cSrcweir { 173*cdf0e10cSrcweir struct tm* res; 174*cdf0e10cSrcweir 175*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 176*cdf0e10cSrcweir 177*cdf0e10cSrcweir if ( (res = gmtime(timep)) ) 178*cdf0e10cSrcweir { 179*cdf0e10cSrcweir memcpy(buffer, res, sizeof(struct tm)); 180*cdf0e10cSrcweir res = buffer; 181*cdf0e10cSrcweir } 182*cdf0e10cSrcweir 183*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 184*cdf0e10cSrcweir 185*cdf0e10cSrcweir return res; 186*cdf0e10cSrcweir } 187*cdf0e10cSrcweir #endif /* defined NETBSD */ 188*cdf0e10cSrcweir 189*cdf0e10cSrcweir #ifdef SCO 190*cdf0e10cSrcweir #include <pwd.h> 191*cdf0e10cSrcweir #include <shadow.h> 192*cdf0e10cSrcweir #include <sys/types.h> 193*cdf0e10cSrcweir 194*cdf0e10cSrcweir struct spwd *getspnam_r(const char *name, struct spwd* s, char* buffer, int size ) 195*cdf0e10cSrcweir { 196*cdf0e10cSrcweir struct spwd* res; 197*cdf0e10cSrcweir 198*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 199*cdf0e10cSrcweir 200*cdf0e10cSrcweir if ( res = getspnam(name) ) 201*cdf0e10cSrcweir { 202*cdf0e10cSrcweir int nnamp; 203*cdf0e10cSrcweir 204*cdf0e10cSrcweir nnamp = strlen(res->sp_namp)+1; 205*cdf0e10cSrcweir 206*cdf0e10cSrcweir if (nnamp+strlen(res->sp_pwdp) < size) { 207*cdf0e10cSrcweir memcpy(s, res, sizeof(struct spwd)); 208*cdf0e10cSrcweir 209*cdf0e10cSrcweir strcpy(buffer, res->sp_namp); 210*cdf0e10cSrcweir s->sp_namp = buffer; 211*cdf0e10cSrcweir buffer += nnamp; 212*cdf0e10cSrcweir 213*cdf0e10cSrcweir strcpy(buffer, res->sp_pwdp); 214*cdf0e10cSrcweir s->sp_pwdp = buffer; 215*cdf0e10cSrcweir 216*cdf0e10cSrcweir res = s; 217*cdf0e10cSrcweir } 218*cdf0e10cSrcweir else 219*cdf0e10cSrcweir res = 0; 220*cdf0e10cSrcweir } 221*cdf0e10cSrcweir 222*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 223*cdf0e10cSrcweir 224*cdf0e10cSrcweir return res; 225*cdf0e10cSrcweir } 226*cdf0e10cSrcweir 227*cdf0e10cSrcweir struct passwd *getpwnam_r(const char* name, struct passwd* s, char* buffer, int size ) 228*cdf0e10cSrcweir { 229*cdf0e10cSrcweir struct passwd* res; 230*cdf0e10cSrcweir 231*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 232*cdf0e10cSrcweir 233*cdf0e10cSrcweir if ( res = getpwnam(name) ) 234*cdf0e10cSrcweir { 235*cdf0e10cSrcweir int nname, npasswd, nage; 236*cdf0e10cSrcweir int ncomment, ngecos, ndir; 237*cdf0e10cSrcweir 238*cdf0e10cSrcweir nname= strlen(res->pw_name)+1; 239*cdf0e10cSrcweir npasswd= strlen(res->pw_passwd)+1; 240*cdf0e10cSrcweir nage= strlen(res->pw_age)+1; 241*cdf0e10cSrcweir ncomment= strlen(res->pw_comment)+1; 242*cdf0e10cSrcweir ngecos= strlen(res->pw_gecos)+1; 243*cdf0e10cSrcweir ndir= strlen(res->pw_dir)+1; 244*cdf0e10cSrcweir 245*cdf0e10cSrcweir if (nname+npasswd+nage+ncomment+ngecos+ndir 246*cdf0e10cSrcweir +strlen(res->pw_shell) < size) 247*cdf0e10cSrcweir { 248*cdf0e10cSrcweir memcpy(s, res, sizeof(struct passwd)); 249*cdf0e10cSrcweir 250*cdf0e10cSrcweir strcpy(buffer, res->pw_name); 251*cdf0e10cSrcweir s->pw_name = buffer; 252*cdf0e10cSrcweir buffer += nname; 253*cdf0e10cSrcweir 254*cdf0e10cSrcweir strcpy(buffer, res->pw_passwd); 255*cdf0e10cSrcweir s->pw_passwd = buffer; 256*cdf0e10cSrcweir buffer += npasswd; 257*cdf0e10cSrcweir 258*cdf0e10cSrcweir strcpy(buffer, res->pw_age); 259*cdf0e10cSrcweir s->pw_age = buffer; 260*cdf0e10cSrcweir buffer += nage; 261*cdf0e10cSrcweir 262*cdf0e10cSrcweir strcpy(buffer, res->pw_comment); 263*cdf0e10cSrcweir s->pw_comment = buffer; 264*cdf0e10cSrcweir buffer += ncomment; 265*cdf0e10cSrcweir 266*cdf0e10cSrcweir strcpy(buffer, res->pw_gecos); 267*cdf0e10cSrcweir s->pw_gecos = buffer; 268*cdf0e10cSrcweir buffer += ngecos; 269*cdf0e10cSrcweir 270*cdf0e10cSrcweir strcpy(buffer, res->pw_dir); 271*cdf0e10cSrcweir s->pw_dir = buffer; 272*cdf0e10cSrcweir buffer += ndir; 273*cdf0e10cSrcweir 274*cdf0e10cSrcweir strcpy(buffer, res->pw_shell); 275*cdf0e10cSrcweir s->pw_shell = buffer; 276*cdf0e10cSrcweir 277*cdf0e10cSrcweir res = s; 278*cdf0e10cSrcweir } 279*cdf0e10cSrcweir else 280*cdf0e10cSrcweir res = 0; 281*cdf0e10cSrcweir } 282*cdf0e10cSrcweir 283*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 284*cdf0e10cSrcweir 285*cdf0e10cSrcweir return res; 286*cdf0e10cSrcweir } 287*cdf0e10cSrcweir #endif /* defined SCO */ 288*cdf0e10cSrcweir 289*cdf0e10cSrcweir #if !defined(FREEBSD) || (__FreeBSD_version < 601103) 290*cdf0e10cSrcweir 291*cdf0e10cSrcweir extern int h_errno; 292*cdf0e10cSrcweir 293*cdf0e10cSrcweir struct hostent *gethostbyname_r(const char *name, struct hostent *result, 294*cdf0e10cSrcweir char *buffer, int buflen, int *h_errnop) 295*cdf0e10cSrcweir { 296*cdf0e10cSrcweir /* buffer layout: name\0 297*cdf0e10cSrcweir * array_of_pointer_to_aliases 298*cdf0e10cSrcweir * NULL 299*cdf0e10cSrcweir * alias1\0...aliasn\0 300*cdf0e10cSrcweir * array_of_pointer_to_addresses 301*cdf0e10cSrcweir * NULL 302*cdf0e10cSrcweir * addr1addr2addr3...addrn 303*cdf0e10cSrcweir */ 304*cdf0e10cSrcweir struct hostent* res; 305*cdf0e10cSrcweir 306*cdf0e10cSrcweir pthread_mutex_lock(&getrtl_mutex); 307*cdf0e10cSrcweir 308*cdf0e10cSrcweir if ( (res = gethostbyname(name)) ) 309*cdf0e10cSrcweir { 310*cdf0e10cSrcweir int nname, naliases, naddr_list, naliasesdata, n; 311*cdf0e10cSrcweir char **p, **parray, *data; 312*cdf0e10cSrcweir 313*cdf0e10cSrcweir /* Check buffer size before copying, we want to leave the 314*cdf0e10cSrcweir * buffers unmodified in case something goes wrong. 315*cdf0e10cSrcweir * 316*cdf0e10cSrcweir * Is this required? 317*cdf0e10cSrcweir */ 318*cdf0e10cSrcweir 319*cdf0e10cSrcweir nname= strlen(res->h_name)+1; 320*cdf0e10cSrcweir 321*cdf0e10cSrcweir naliases = naddr_list = naliasesdata = 0; 322*cdf0e10cSrcweir 323*cdf0e10cSrcweir for ( p = res->h_aliases; *p != NULL; p++) { 324*cdf0e10cSrcweir naliases++; 325*cdf0e10cSrcweir naliasesdata += strlen(*p)+1; 326*cdf0e10cSrcweir } 327*cdf0e10cSrcweir 328*cdf0e10cSrcweir for ( p = res->h_addr_list; *p != NULL; p++) 329*cdf0e10cSrcweir naddr_list++; 330*cdf0e10cSrcweir 331*cdf0e10cSrcweir if ( nname 332*cdf0e10cSrcweir + (naliases+1)*sizeof(char*) + naliasesdata 333*cdf0e10cSrcweir + (naddr_list+1)*sizeof(char*) + naddr_list*res->h_length 334*cdf0e10cSrcweir <= buflen ) 335*cdf0e10cSrcweir { 336*cdf0e10cSrcweir memcpy(result, res, sizeof(struct hostent)); 337*cdf0e10cSrcweir 338*cdf0e10cSrcweir strcpy(buffer, res->h_name); 339*cdf0e10cSrcweir result->h_name = buffer; 340*cdf0e10cSrcweir buffer += nname; 341*cdf0e10cSrcweir 342*cdf0e10cSrcweir parray = (char**)buffer; 343*cdf0e10cSrcweir result->h_aliases = parray; 344*cdf0e10cSrcweir data = buffer + (naliases+1)*sizeof(char*); 345*cdf0e10cSrcweir for ( p = res->h_aliases; *p != NULL; p++) { 346*cdf0e10cSrcweir n = strlen(*p)+1; 347*cdf0e10cSrcweir *parray++ = data; 348*cdf0e10cSrcweir memcpy(data, *p, n); 349*cdf0e10cSrcweir data += n; 350*cdf0e10cSrcweir } 351*cdf0e10cSrcweir *parray = NULL; 352*cdf0e10cSrcweir buffer = data; 353*cdf0e10cSrcweir parray = (char**)buffer; 354*cdf0e10cSrcweir result->h_addr_list = parray; 355*cdf0e10cSrcweir data = buffer + (naddr_list+1)*sizeof(char*); 356*cdf0e10cSrcweir for ( p = res->h_addr_list; *p != NULL; p++) { 357*cdf0e10cSrcweir *parray++ = data; 358*cdf0e10cSrcweir memcpy(data, *p, res->h_length); 359*cdf0e10cSrcweir data += res->h_length; 360*cdf0e10cSrcweir } 361*cdf0e10cSrcweir *parray = NULL; 362*cdf0e10cSrcweir 363*cdf0e10cSrcweir res = result; 364*cdf0e10cSrcweir } 365*cdf0e10cSrcweir else 366*cdf0e10cSrcweir { 367*cdf0e10cSrcweir errno = ERANGE; 368*cdf0e10cSrcweir res = NULL; 369*cdf0e10cSrcweir } 370*cdf0e10cSrcweir } 371*cdf0e10cSrcweir else 372*cdf0e10cSrcweir { 373*cdf0e10cSrcweir *h_errnop = h_errno; 374*cdf0e10cSrcweir } 375*cdf0e10cSrcweir 376*cdf0e10cSrcweir pthread_mutex_unlock(&getrtl_mutex); 377*cdf0e10cSrcweir 378*cdf0e10cSrcweir return res; 379*cdf0e10cSrcweir } 380*cdf0e10cSrcweir #endif /* !defined(FREEBSD) || (__FreeBSD_version < 601103) */ 381*cdf0e10cSrcweir 382*cdf0e10cSrcweir #if defined(MACOSX) 383*cdf0e10cSrcweir /* 384*cdf0e10cSrcweir * Add support for resolving Mac native alias files (not the same as unix alias files) 385*cdf0e10cSrcweir * returns 0 on success. 386*cdf0e10cSrcweir */ 387*cdf0e10cSrcweir int macxp_resolveAlias(char *path, int buflen) 388*cdf0e10cSrcweir { 389*cdf0e10cSrcweir FSRef aFSRef; 390*cdf0e10cSrcweir OSStatus nErr; 391*cdf0e10cSrcweir Boolean bFolder; 392*cdf0e10cSrcweir Boolean bAliased; 393*cdf0e10cSrcweir char *unprocessedPath = path; 394*cdf0e10cSrcweir 395*cdf0e10cSrcweir if ( *unprocessedPath == '/' ) 396*cdf0e10cSrcweir unprocessedPath++; 397*cdf0e10cSrcweir 398*cdf0e10cSrcweir int nRet = 0; 399*cdf0e10cSrcweir while ( !nRet && unprocessedPath && *unprocessedPath ) 400*cdf0e10cSrcweir { 401*cdf0e10cSrcweir unprocessedPath = strchr( unprocessedPath, '/' ); 402*cdf0e10cSrcweir if ( unprocessedPath ) 403*cdf0e10cSrcweir *unprocessedPath = '\0'; 404*cdf0e10cSrcweir 405*cdf0e10cSrcweir nErr = noErr; 406*cdf0e10cSrcweir bFolder = FALSE; 407*cdf0e10cSrcweir bAliased = FALSE; 408*cdf0e10cSrcweir if ( FSPathMakeRef( (const UInt8 *)path, &aFSRef, 0 ) == noErr ) 409*cdf0e10cSrcweir { 410*cdf0e10cSrcweir nErr = FSResolveAliasFileWithMountFlags( &aFSRef, TRUE, &bFolder, &bAliased, kResolveAliasFileNoUI ); 411*cdf0e10cSrcweir if ( nErr == nsvErr ) 412*cdf0e10cSrcweir { 413*cdf0e10cSrcweir errno = ENOENT; 414*cdf0e10cSrcweir nRet = -1; 415*cdf0e10cSrcweir } 416*cdf0e10cSrcweir else if ( nErr == noErr && bAliased ) 417*cdf0e10cSrcweir { 418*cdf0e10cSrcweir char tmpPath[ PATH_MAX ]; 419*cdf0e10cSrcweir if ( FSRefMakePath( &aFSRef, (UInt8 *)tmpPath, PATH_MAX ) == noErr ) 420*cdf0e10cSrcweir { 421*cdf0e10cSrcweir int nLen = strlen( tmpPath ) + ( unprocessedPath ? strlen( unprocessedPath + 1 ) + 1 : 0 ); 422*cdf0e10cSrcweir if ( nLen < buflen && nLen < PATH_MAX ) 423*cdf0e10cSrcweir { 424*cdf0e10cSrcweir if ( unprocessedPath ) 425*cdf0e10cSrcweir { 426*cdf0e10cSrcweir int nTmpPathLen = strlen( tmpPath ); 427*cdf0e10cSrcweir strcat( tmpPath, "/" ); 428*cdf0e10cSrcweir strcat( tmpPath, unprocessedPath + 1 ); 429*cdf0e10cSrcweir strcpy( path, tmpPath); 430*cdf0e10cSrcweir unprocessedPath = path + nTmpPathLen; 431*cdf0e10cSrcweir } 432*cdf0e10cSrcweir else if ( !unprocessedPath ) 433*cdf0e10cSrcweir { 434*cdf0e10cSrcweir strcpy( path, tmpPath); 435*cdf0e10cSrcweir } 436*cdf0e10cSrcweir } 437*cdf0e10cSrcweir else 438*cdf0e10cSrcweir { 439*cdf0e10cSrcweir errno = ENAMETOOLONG; 440*cdf0e10cSrcweir nRet = -1; 441*cdf0e10cSrcweir } 442*cdf0e10cSrcweir } 443*cdf0e10cSrcweir } 444*cdf0e10cSrcweir } 445*cdf0e10cSrcweir 446*cdf0e10cSrcweir if ( unprocessedPath ) 447*cdf0e10cSrcweir *unprocessedPath++ = '/'; 448*cdf0e10cSrcweir } 449*cdf0e10cSrcweir 450*cdf0e10cSrcweir return nRet; 451*cdf0e10cSrcweir } 452*cdf0e10cSrcweir 453*cdf0e10cSrcweir #endif /* defined MACOSX */ 454*cdf0e10cSrcweir 455*cdf0e10cSrcweir #endif /* NO_PTHREAD_RTL */ 456*cdf0e10cSrcweir 457*cdf0e10cSrcweir #if (defined (LINUX) && (GLIBC >= 2)) 458*cdf0e10cSrcweir /* The linux kernel thread implemention, always return the pid of the 459*cdf0e10cSrcweir thread subprocess and not of the main process. So we save the main 460*cdf0e10cSrcweir pid at startup 461*cdf0e10cSrcweir */ 462*cdf0e10cSrcweir 463*cdf0e10cSrcweir // Directly from libc.so.6, obviously missing from some unistd.h: 464*cdf0e10cSrcweir extern __pid_t __getpid(void); 465*cdf0e10cSrcweir 466*cdf0e10cSrcweir static pid_t pid = -1; 467*cdf0e10cSrcweir 468*cdf0e10cSrcweir static void savePid(void) __attribute__((constructor)); 469*cdf0e10cSrcweir 470*cdf0e10cSrcweir static void savePid(void) 471*cdf0e10cSrcweir { 472*cdf0e10cSrcweir if (pid == -1) 473*cdf0e10cSrcweir pid = __getpid(); 474*cdf0e10cSrcweir } 475*cdf0e10cSrcweir 476*cdf0e10cSrcweir pid_t getpid(void) 477*cdf0e10cSrcweir { 478*cdf0e10cSrcweir if (pid == -1) 479*cdf0e10cSrcweir savePid(); 480*cdf0e10cSrcweir 481*cdf0e10cSrcweir return (pid); 482*cdf0e10cSrcweir } 483*cdf0e10cSrcweir #endif /* (defined (LINUX) && (GLIBC >= 2)) */ 484*cdf0e10cSrcweir 485*cdf0e10cSrcweir #ifdef NO_PTHREAD_SEMAPHORES 486*cdf0e10cSrcweir int sem_init(sem_t* sem, int pshared, unsigned int value) 487*cdf0e10cSrcweir { 488*cdf0e10cSrcweir pthread_mutex_init(&sem->mutex, PTHREAD_MUTEXATTR_DEFAULT); 489*cdf0e10cSrcweir pthread_cond_init(&sem->increased, PTHREAD_CONDATTR_DEFAULT); 490*cdf0e10cSrcweir 491*cdf0e10cSrcweir sem->value = (int)value; 492*cdf0e10cSrcweir return 0; 493*cdf0e10cSrcweir } 494*cdf0e10cSrcweir 495*cdf0e10cSrcweir int sem_destroy(sem_t* sem) 496*cdf0e10cSrcweir { 497*cdf0e10cSrcweir pthread_mutex_destroy(&sem->mutex); 498*cdf0e10cSrcweir pthread_cond_destroy(&sem->increased); 499*cdf0e10cSrcweir sem->value = 0; 500*cdf0e10cSrcweir return 0; 501*cdf0e10cSrcweir } 502*cdf0e10cSrcweir 503*cdf0e10cSrcweir int sem_wait(sem_t* sem) 504*cdf0e10cSrcweir { 505*cdf0e10cSrcweir pthread_mutex_lock(&sem->mutex); 506*cdf0e10cSrcweir 507*cdf0e10cSrcweir while (sem->value <= 0) 508*cdf0e10cSrcweir { 509*cdf0e10cSrcweir pthread_cond_wait(&sem->increased, &sem->mutex); 510*cdf0e10cSrcweir } 511*cdf0e10cSrcweir 512*cdf0e10cSrcweir sem->value--; 513*cdf0e10cSrcweir pthread_mutex_unlock(&sem->mutex); 514*cdf0e10cSrcweir 515*cdf0e10cSrcweir return 0; 516*cdf0e10cSrcweir } 517*cdf0e10cSrcweir 518*cdf0e10cSrcweir int sem_trywait(sem_t* sem) 519*cdf0e10cSrcweir { 520*cdf0e10cSrcweir int result = 0; 521*cdf0e10cSrcweir 522*cdf0e10cSrcweir pthread_mutex_lock(&sem->mutex); 523*cdf0e10cSrcweir 524*cdf0e10cSrcweir if (sem->value > 0) 525*cdf0e10cSrcweir { 526*cdf0e10cSrcweir sem->value--; 527*cdf0e10cSrcweir } 528*cdf0e10cSrcweir else 529*cdf0e10cSrcweir { 530*cdf0e10cSrcweir errno = EAGAIN; 531*cdf0e10cSrcweir result = -1; 532*cdf0e10cSrcweir } 533*cdf0e10cSrcweir 534*cdf0e10cSrcweir pthread_mutex_unlock(&sem->mutex); 535*cdf0e10cSrcweir 536*cdf0e10cSrcweir return result; 537*cdf0e10cSrcweir } 538*cdf0e10cSrcweir 539*cdf0e10cSrcweir int sem_post(sem_t* sem) 540*cdf0e10cSrcweir { 541*cdf0e10cSrcweir pthread_mutex_lock(&sem->mutex); 542*cdf0e10cSrcweir 543*cdf0e10cSrcweir sem->value++; 544*cdf0e10cSrcweir 545*cdf0e10cSrcweir pthread_mutex_unlock(&sem->mutex); 546*cdf0e10cSrcweir 547*cdf0e10cSrcweir pthread_cond_signal(&sem->increased); 548*cdf0e10cSrcweir 549*cdf0e10cSrcweir return 0; 550*cdf0e10cSrcweir } 551*cdf0e10cSrcweir #endif 552*cdf0e10cSrcweir 553*cdf0e10cSrcweir #if defined(FREEBSD) 554*cdf0e10cSrcweir char *fcvt(double value, int ndigit, int *decpt, int *sign) 555*cdf0e10cSrcweir { 556*cdf0e10cSrcweir static char ret[256]; 557*cdf0e10cSrcweir char buf[256],zahl[256],format[256]="%"; 558*cdf0e10cSrcweir char *v1,*v2; 559*cdf0e10cSrcweir 560*cdf0e10cSrcweir if (value==0.0) value=1e-30; 561*cdf0e10cSrcweir 562*cdf0e10cSrcweir if (value<0.0) *sign=1; else *sign=0; 563*cdf0e10cSrcweir 564*cdf0e10cSrcweir if (value<1.0) 565*cdf0e10cSrcweir { 566*cdf0e10cSrcweir *decpt=(int)log10(value); 567*cdf0e10cSrcweir value*=pow(10.0,1-*decpt); 568*cdf0e10cSrcweir ndigit+=*decpt-1; 569*cdf0e10cSrcweir if (ndigit<0) ndigit=0; 570*cdf0e10cSrcweir } 571*cdf0e10cSrcweir else 572*cdf0e10cSrcweir { 573*cdf0e10cSrcweir *decpt=(int)log10(value)+1; 574*cdf0e10cSrcweir } 575*cdf0e10cSrcweir 576*cdf0e10cSrcweir sprintf(zahl,"%d",ndigit); 577*cdf0e10cSrcweir strcat(format,zahl); 578*cdf0e10cSrcweir strcat(format,"."); 579*cdf0e10cSrcweir strcat(format,zahl); 580*cdf0e10cSrcweir strcat(format,"f"); 581*cdf0e10cSrcweir 582*cdf0e10cSrcweir sprintf(buf,format,value); 583*cdf0e10cSrcweir 584*cdf0e10cSrcweir if (ndigit!=0) 585*cdf0e10cSrcweir { 586*cdf0e10cSrcweir v1=strtok(buf,"."); 587*cdf0e10cSrcweir v2=strtok(NULL,"."); 588*cdf0e10cSrcweir strcpy(ret,v1); 589*cdf0e10cSrcweir strcat(ret,v2); 590*cdf0e10cSrcweir } 591*cdf0e10cSrcweir else 592*cdf0e10cSrcweir { 593*cdf0e10cSrcweir strcpy(ret,buf); 594*cdf0e10cSrcweir } 595*cdf0e10cSrcweir 596*cdf0e10cSrcweir return(ret); 597*cdf0e10cSrcweir } 598*cdf0e10cSrcweir 599*cdf0e10cSrcweir #endif 600