]> git.sur5r.net Git - openldap/commitdiff
Use getopt()
authorHallvard Furuseth <hallvard@openldap.org>
Sun, 29 Nov 2009 09:59:22 +0000 (09:59 +0000)
committerHallvard Furuseth <hallvard@openldap.org>
Sun, 29 Nov 2009 09:59:22 +0000 (09:59 +0000)
tests/progs/ldif-filter.c

index 932b46e3c0f761bdf10bd1414462d2683e869bf6..24a784628013d02819b0479e6759917a23c61f82 100644 (file)
@@ -20,6 +20,7 @@
 #include <ac/ctype.h>
 #include <ac/stdlib.h>
 #include <ac/string.h>
+#include <ac/unistd.h>
 
 #define DEFAULT_SPECS "ndb=a,null=n"
 
@@ -37,7 +38,7 @@ static void
 usage( void )
 {
        fprintf( stderr, "\
-Usage: %s [backend] [spec[,spec]...]\n\
+Usage: %s [-b backend] [-s spec[,spec]...]\n\
 Filter standard input by first <spec> matching '[<backend>]=[a][e][n]':\n\
   - Remove LDIF comments.\n\
   - 'a': Sort attributes in entries.\n\
@@ -205,18 +206,32 @@ filter_stdin( unsigned flags )
 int
 main( int argc, char **argv )
 {
-       const char *backend, *specs, *tmp;
+       const char *backend = getenv( "BACKEND" ), *specs = "", *tmp;
        unsigned flags;
+       int i;
 
        if ( argc > 0 ) {
                progname = (tmp = strrchr( argv[0], '/' )) ? tmp+1 : argv[0];
        }
-       specs = (argc > 1 && strchr( argv[argc-1], '=' )) ? argv[--argc] : "";
-       backend = (argc > 1 && isalnum( (unsigned char) *argv[argc-1] ))
-               ? argv[--argc] : (tmp = getenv( "BACKEND" )) ? tmp : "";
-       if ( argc > 1 ) {
+
+       while ( (i = getopt( argc, argv, "b:s:" )) != EOF ) {
+               switch ( i ) {
+               case 'b':
+                       backend = optarg;
+                       break;
+               case 's':
+                       specs = optarg;
+                       break;
+               default:
+                       usage();
+               }
+       }
+       if ( optind < argc ) {
                usage();
        }
+       if ( backend == NULL ) {
+               backend = "";
+       }
 
        flags = get_flags( backend, specs );
        filter_stdin( flags ? flags : get_flags( backend, DEFAULT_SPECS ));