contrib/lar:

- add lar_find_archive() and lar_find_member() to get a member handle from a packagename
	- extend cli to cover new operations
This commit is contained in:
Jo-Philipp Wich 2009-04-06 14:28:17 +00:00
parent 1744f962b0
commit 50ccdfccce
3 changed files with 100 additions and 18 deletions

View file

@ -30,6 +30,27 @@ int do_print_index( lar_archive *ar )
return 0;
}
int do_require( const char *package )
{
int stat = 1;
lar_archive *ar;
lar_member *mb;
if( (ar = lar_find_archive(package)) != NULL )
{
if( (mb = lar_find_member(ar, package)) != NULL )
{
write(fileno(stdout), mb->data, mb->length);
lar_close_member(mb);
stat = 0;
}
lar_close(ar);
}
return stat;
}
int main( int argc, const char* argv[] )
{
lar_archive *ar;
@ -37,27 +58,40 @@ int main( int argc, const char* argv[] )
if( argv[1] != NULL )
{
if( (ar = lar_open(argv[1])) != NULL )
switch(argv[1][0])
{
if( argv[2] )
stat = do_print_member(ar, argv[2]);
case 's':
if( (ar = lar_open(argv[2])) != NULL )
{
if( argv[3] != NULL )
stat = do_print_member(ar, argv[3]);
else
stat = do_print_index(ar);
lar_close(ar);
return stat;
}
else
{
LAR_DIE("Failed to open archive");
}
break;
case 'r':
stat = do_require(argv[2]);
break;
}
return stat;
}
else
{
printf("Usage: lar <archive> [<member>]\n");
printf("Usage:\n");
printf("\tlar show <archive> [<member>]\n");
printf("\tlar require <package>\n");
return 1;
}
return 0;
}

View file

@ -174,3 +174,49 @@ int lar_close( lar_archive *ar )
return 0;
}
lar_archive * lar_find_archive( const char *package )
{
int seg = 1;
int i, j, len;
struct stat s;
LAR_FNAME(buffer);
for( len = 0; package[len] != '\0'; len++ )
if( package[len] == '.' ) seg++;
while( seg > 0 )
{
for( i = 0, j = 1; (i < len) && (j <= seg); i++ )
{
if( package[i] == '.' ) {
if( j < seg ) j++; else break;
}
buffer[i] = ( package[i] == '.' ) ? '/' : package[i];
}
buffer[i+0] = '.'; buffer[i+1] = 'l'; buffer[i+2] = 'a';
buffer[i+3] = 'r'; buffer[i+4] = '\0';
if( (stat(buffer, &s) > -1) && (s.st_mode & S_IFREG) )
return lar_open(buffer);
seg--;
}
return NULL;
}
lar_member * lar_find_member( lar_archive *ar, const char *package )
{
int len;
LAR_FNAME(buffer);
for( len = 0; package[len] != '\0'; len++ )
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';
return lar_open_member(ar, buffer);
}

View file

@ -73,4 +73,6 @@ lar_archive * lar_open( const char *filename );
int lar_close( lar_archive *ar );
lar_archive * lar_find_archive( const char *package );
lar_member * lar_find_member( lar_archive *ar, const char *package );