summaryrefslogtreecommitdiff
path: root/src/paramproc.cpp
diff options
context:
space:
mode:
authorMike Buland <eichlan@xagasoft.com>2006-06-29 05:34:39 +0000
committerMike Buland <eichlan@xagasoft.com>2006-06-29 05:34:39 +0000
commitdcd914665f6e8ea6ea4e648f7357f1c842273d87 (patch)
treedf65caa1914fafdc68ec55b56524edfc7469321e /src/paramproc.cpp
parent9b52daa8512c34b9484ea43302578bc879d212da (diff)
downloadlibbu++-dcd914665f6e8ea6ea4e648f7357f1c842273d87.tar.gz
libbu++-dcd914665f6e8ea6ea4e648f7357f1c842273d87.tar.bz2
libbu++-dcd914665f6e8ea6ea4e648f7357f1c842273d87.tar.xz
libbu++-dcd914665f6e8ea6ea4e648f7357f1c842273d87.zip
All done with all of the basic and some nice, extended functionality, now I
just need to update our other projects...
Diffstat (limited to '')
-rw-r--r--src/paramproc.cpp82
1 files changed, 78 insertions, 4 deletions
diff --git a/src/paramproc.cpp b/src/paramproc.cpp
index eaaf466..85274e2 100644
--- a/src/paramproc.cpp
+++ b/src/paramproc.cpp
@@ -141,6 +141,12 @@ void ParamProc::addParam( const char *lpWord, char cChar, Proc proc,
141 as->sValue = lpValue; 141 as->sValue = lpValue;
142 142
143 lArg.push_back( as ); 143 lArg.push_back( as );
144
145 if( !lBan.empty() )
146 {
147 if( lBan.back()->pBefore == NULL )
148 lBan.back()->pBefore = as;
149 }
144} 150}
145 151
146void ParamProc::addParam( const char *lpWord, char cChar, Proc proc, 152void ParamProc::addParam( const char *lpWord, char cChar, Proc proc,
@@ -203,7 +209,7 @@ void ParamProc::process( int argc, char *argv[] )
203{ 209{
204 for( int arg = 1; arg < argc; arg++ ) 210 for( int arg = 1; arg < argc; arg++ )
205 { 211 {
206 printf(":::%d:::%s\n", arg, argv[arg] ); 212 //printf(":::%d:::%s\n", arg, argv[arg] );
207 if( argv[arg][0] == '-' ) 213 if( argv[arg][0] == '-' )
208 { 214 {
209 if( argv[arg][1] == '-' ) 215 if( argv[arg][1] == '-' )
@@ -270,6 +276,10 @@ void ParamProc::process( int argc, char *argv[] )
270 } 276 }
271 continue; 277 continue;
272 } 278 }
279 else
280 {
281 unknownParam( argc-arg, argv+arg );
282 }
273 } 283 }
274 else 284 else
275 { 285 {
@@ -347,15 +357,23 @@ void ParamProc::process( int argc, char *argv[] )
347 } 357 }
348 } 358 }
349 } 359 }
360 else
361 {
362 unknownParam( argc-arg, argv+arg );
363 }
350 } 364 }
351 } 365 }
352 } 366 }
367 else
368 {
369 cmdParam( argc-arg, argv+arg );
370 }
353 } 371 }
354} 372}
355 373
356ParamProc::ArgSpec *ParamProc::checkWord( const char *arg ) 374ParamProc::ArgSpec *ParamProc::checkWord( const char *arg )
357{ 375{
358 printf("Checking \"%s\"...\n", arg ); 376 //printf("Checking \"%s\"...\n", arg );
359 std::list<ArgSpec *>::const_iterator i; 377 std::list<ArgSpec *>::const_iterator i;
360 for( i = lArg.begin(); i != lArg.end(); i++ ) 378 for( i = lArg.begin(); i != lArg.end(); i++ )
361 { 379 {
@@ -380,7 +398,7 @@ ParamProc::ArgSpec *ParamProc::checkWord( const char *arg )
380 398
381ParamProc::ArgSpec *ParamProc::checkLetr( const char arg ) 399ParamProc::ArgSpec *ParamProc::checkLetr( const char arg )
382{ 400{
383 printf("Checking \'%c\'...\n", arg ); 401 //printf("Checking \'%c\'...\n", arg );
384 std::list<ArgSpec *>::const_iterator i; 402 std::list<ArgSpec *>::const_iterator i;
385 for( i = lArg.begin(); i != lArg.end(); i++ ) 403 for( i = lArg.begin(); i != lArg.end(); i++ )
386 { 404 {
@@ -408,6 +426,62 @@ int ParamProc::unknownParam( int argc, char *argv[] )
408 426
409int ParamProc::help( int argc, char *argv[] ) 427int ParamProc::help( int argc, char *argv[] )
410{ 428{
411 // Insert help here later on 429 std::list<Banner *>::const_iterator b = lBan.begin();
430 std::list<ArgSpec *>::const_iterator i;
431 int len=0;
432 for( i = lArg.begin(); i != lArg.end(); i++ )
433 {
434 if( len < (*i)->sWord.getLength() )
435 len = (*i)->sWord.getLength();
436 }
437 char fmt[10];
438 sprintf( fmt, "%%-%ds ", len );
439
440 for( i = lArg.begin(); i != lArg.end(); i++ )
441 {
442 if( b != lBan.end() )
443 {
444 if( (*b)->pBefore == (*i) )
445 {
446 printf( (*b)->sBanner.getString() );
447 b++;
448 }
449 }
450 printf(" ");
451 if( (*i)->cChar )
452 {
453 printf("-%c, ", (*i)->cChar );
454 }
455 else
456 {
457 printf(" ");
458 }
459 if( (*i)->sWord.getString() )
460 {
461 printf("--");
462 printf( fmt, (*i)->sWord.getString() );
463 }
464 else
465 {
466 printf(" ");
467 printf(fmt, "" );
468 }
469 printf("%s\n", (*i)->sDesc.getString() );
470 }
471 if( b != lBan.end() )
472 {
473 if( (*b)->pBefore == NULL )
474 {
475 printf( (*b)->sBanner.getString() );
476 }
477 }
478}
479
480void ParamProc::addHelpBanner( const char *sHelpBanner )
481{
482 Banner *pBan = new Banner;
483 pBan->sBanner = sHelpBanner;
484 pBan->pBefore = NULL;
485 lBan.push_back( pBan );
412} 486}
413 487