idx_map = NULL;
for( i = 0; i < idx_length; \
- i += (sizeof(lar_index) - sizeof(char))
+ i += (sizeof(lar_index) - sizeof(char *))
) {
idx_ptr = (lar_index *)malloc(sizeof(lar_index));
return 0;
}
-lar_archive * lar_find_archive( const char *package )
+lar_archive * lar_find_archive( const char *package, const char *path )
{
int seg = 1;
- int i, j, len;
+ int len = 0;
+ int pln = 0;
+ int i, j;
struct stat s;
LAR_FNAME(buffer);
+ if( path )
+ {
+ for( pln = 0; path[pln] != '\0'; pln++ )
+ if( pln >= (sizeof(buffer) - 5) )
+ LAR_DIE("Library path exceeds maximum allowed length");
+
+ memcpy(buffer, path, pln);
+ }
+
for( len = 0; package[len] != '\0'; len++ )
+ {
+ if( len >= (sizeof(buffer) - 5 - pln) )
+ LAR_DIE("Package name exceeds maximum allowed length");
+
if( package[len] == '.' ) seg++;
+ }
while( seg > 0 )
{
if( j < seg ) j++; else break;
}
- buffer[i] = ( package[i] == '.' ) ? '/' : package[i];
+ buffer[pln+i] = ( package[i] == '.' ) ? LAR_DIRSEP : package[i];
}
- buffer[i+0] = '.'; buffer[i+1] = 'l'; buffer[i+2] = 'a';
- buffer[i+3] = 'r'; buffer[i+4] = '\0';
+ buffer[pln+i+0] = '.'; buffer[pln+i+1] = 'l'; buffer[pln+i+2] = 'a';
+ buffer[pln+i+3] = 'r'; buffer[pln+i+4] = '\0';
if( (stat(buffer, &s) > -1) && (s.st_mode & S_IFREG) )
return lar_open(buffer);
LAR_FNAME(buffer);
for( len = 0; package[len] != '\0'; len++ )
+ {
+ if( len >= (sizeof(buffer) - 5) )
+ LAR_DIE("Package name exceeds maximum allowed length");
+
buffer[len] = ( package[len] == '.' ) ? '/' : package[len];
+ }
buffer[len+0] = '.'; buffer[len+1] = 'l'; buffer[len+2] = 'u';
buffer[len+3] = 'a'; buffer[len+4] = '\0';