diff options
author | Niklas Een <niklas@een.se> | 2012-09-11 18:48:43 -0700 |
---|---|---|
committer | Niklas Een <niklas@een.se> | 2012-09-11 18:48:43 -0700 |
commit | 1c865bf2298233ccad6f6ace730a882e0c4f7f9c (patch) | |
tree | 302dae06812a595586b0687cf676d2aac6b0b83c /src/base/main/main.c | |
parent | 784a3579e578a0c1b44abf60df74e9de54f8b37b (diff) | |
download | abc-1c865bf2298233ccad6f6ace730a882e0c4f7f9c.tar.gz abc-1c865bf2298233ccad6f6ace730a882e0c4f7f9c.tar.bz2 abc-1c865bf2298233ccad6f6ace730a882e0c4f7f9c.zip |
Added -C to command line for running commands, then staying in interactive mode
Diffstat (limited to 'src/base/main/main.c')
-rw-r--r-- | src/base/main/main.c | 67 |
1 files changed, 39 insertions, 28 deletions
diff --git a/src/base/main/main.c b/src/base/main/main.c index ebab4ee8..41836681 100644 --- a/src/base/main/main.c +++ b/src/base/main/main.c @@ -90,14 +90,14 @@ int Abc_RealMain( int argc, char * argv[] ) char * sCommand; int fStatus = 0; int c, fBatch, fInitSource, fInitRead, fFinalWrite; - + // added to detect memory leaks // watch for {,,msvcrtd.dll}*__p__crtBreakAlloc() // (http://support.microsoft.com/kb/151585) -#if defined(_DEBUG) && defined(_MSC_VER) +#if defined(_DEBUG) && defined(_MSC_VER) _CrtSetDbgFlag( _CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF ); #endif - + // Npn_Experiment(); // Npn_Generate(); @@ -136,15 +136,20 @@ int Abc_RealMain( int argc, char * argv[] ) sInFile = sOutFile = NULL; sprintf( sReadCmd, "read" ); sprintf( sWriteCmd, "write" ); - + Extra_UtilGetoptReset(); - while ((c = Extra_UtilGetopt(argc, argv, "c:hf:F:o:st:T:xb")) != EOF) { + while ((c = Extra_UtilGetopt(argc, argv, "c:C:hf:F:o:st:T:xb")) != EOF) { switch(c) { case 'c': strcpy( sCommandUsr, globalUtilOptarg ); fBatch = 1; break; - + + case 'C': + strcpy( sCommandUsr, globalUtilOptarg ); + fBatch = 2; + break; + case 'f': sprintf(sCommandUsr, "source %s", globalUtilOptarg); fBatch = 1; @@ -154,20 +159,20 @@ int Abc_RealMain( int argc, char * argv[] ) sprintf(sCommandUsr, "source -x %s", globalUtilOptarg); fBatch = 1; break; - + case 'h': goto usage; break; - + case 'o': sOutFile = globalUtilOptarg; fFinalWrite = 1; break; - + case 's': fInitSource = 0; break; - + case 't': if ( TypeCheck( pAbc, globalUtilOptarg ) ) { @@ -182,7 +187,7 @@ int Abc_RealMain( int argc, char * argv[] ) } fBatch = 1; break; - + case 'T': if ( TypeCheck( pAbc, globalUtilOptarg ) ) { @@ -197,17 +202,17 @@ int Abc_RealMain( int argc, char * argv[] ) } fBatch = 1; break; - + case 'x': fFinalWrite = 0; fInitRead = 0; fBatch = 1; break; - + case 'b': Abc_FrameSetBridgeMode(); break; - + default: goto usage; } @@ -220,7 +225,7 @@ int Abc_RealMain( int argc, char * argv[] ) } else if ( fBatch && sCommandUsr[0] ) Abc_Print( 1, "ABC command line: \"%s\".\n\n", sCommandUsr ); - + if ( fBatch ) { pAbc->fBatchMode = 1; @@ -239,20 +244,20 @@ int Abc_RealMain( int argc, char * argv[] ) { Abc_UtilsPrintUsage( pAbc, argv[0] ); } - + // source the resource file if ( fInitSource ) { Abc_UtilsSource( pAbc ); } - + fStatus = 0; if ( fInitRead && sInFile ) { sprintf( sCommandTmp, "%s %s", sReadCmd, sInFile ); fStatus = Cmd_CommandExecute( pAbc, sCommandTmp ); } - + if ( fStatus == 0 ) { /* cmd line contains `source <file>' */ @@ -263,9 +268,15 @@ int Abc_RealMain( int argc, char * argv[] ) fStatus = Cmd_CommandExecute( pAbc, sCommandTmp ); } } - + + if (fBatch == 2){ + fBatch = 0; + pAbc->fBatchMode = 0; + } + } - else + + if ( !fBatch ) { // start interactive mode @@ -273,28 +284,28 @@ int Abc_RealMain( int argc, char * argv[] ) Abc_UtilsPrintHello( pAbc ); // print history of the recent commands Cmd_HistoryPrint( pAbc, 10 ); - + // source the resource file if ( fInitSource ) { Abc_UtilsSource( pAbc ); } - + // execute commands given by the user while ( !feof(stdin) ) { // print command line prompt and // get the command from the user sCommand = Abc_UtilsGetUsersInput( pAbc ); - + // execute the user's command fStatus = Cmd_CommandExecute( pAbc, sCommand ); - + // stop if the user quitted or an error occurred if ( fStatus == -1 || fStatus == -2 ) break; } - } + } #ifdef ABC_PYTHON_EMBED { @@ -305,9 +316,9 @@ int Abc_RealMain( int argc, char * argv[] ) // if the memory should be freed, quit packages // if ( fStatus < 0 ) { - Abc_Stop(); - } - return 0; + Abc_Stop(); + } + return 0; usage: Abc_UtilsPrintHello( pAbc ); |