diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2019-04-15 20:20:26 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2019-04-15 20:20:26 -0700 |
commit | f5320744fa986eb08495f079717c483f1871cfc8 (patch) | |
tree | 6dfa3a6ef31d802a1c5fd34765d5f0ca146b522f /src | |
parent | 1b59ec57da3f6299f7c0e40aee5546c748b57e41 (diff) | |
download | abc-f5320744fa986eb08495f079717c483f1871cfc8.tar.gz abc-f5320744fa986eb08495f079717c483f1871cfc8.tar.bz2 abc-f5320744fa986eb08495f079717c483f1871cfc8.zip |
Adding switch 'read_truth -f <file_name>' to read truth table from file.
Diffstat (limited to 'src')
-rw-r--r-- | src/base/io/io.c | 31 |
1 files changed, 22 insertions, 9 deletions
diff --git a/src/base/io/io.c b/src/base/io/io.c index 2984e785..5ba7f32c 100644 --- a/src/base/io/io.c +++ b/src/base/io/io.c @@ -1102,19 +1102,23 @@ usage: int IoCommandReadTruth( Abc_Frame_t * pAbc, int argc, char ** argv ) { Abc_Ntk_t * pNtk; + char * pStr = NULL; char * pSopCover; - int fHex; + int fHex = 1; + int fFile = 0; int c; - fHex = 1; Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "xh" ) ) != EOF ) + while ( ( c = Extra_UtilGetopt( argc, argv, "xfh" ) ) != EOF ) { switch ( c ) { case 'x': fHex ^= 1; break; + case 'f': + fFile ^= 1; + break; case 'h': goto usage; default: @@ -1123,15 +1127,22 @@ int IoCommandReadTruth( Abc_Frame_t * pAbc, int argc, char ** argv ) } if ( argc != globalUtilOptind + 1 ) - { goto usage; - } + + if ( fFile ) + pStr = Extra_FileReadContents( argv[globalUtilOptind] ); + else + pStr = argv[globalUtilOptind]; + while ( pStr[ strlen(pStr) - 1 ] == '\n' || pStr[ strlen(pStr) - 1 ] == '\r' ) + pStr[ strlen(pStr) - 1 ] = '\0'; // convert truth table to SOP if ( fHex ) - pSopCover = Abc_SopFromTruthHex(argv[globalUtilOptind]); + pSopCover = Abc_SopFromTruthHex(pStr); else - pSopCover = Abc_SopFromTruthBin(argv[globalUtilOptind]); + pSopCover = Abc_SopFromTruthBin(pStr); + if ( fFile ) + ABC_FREE( pStr ); if ( pSopCover == NULL || pSopCover[0] == 0 ) { ABC_FREE( pSopCover ); @@ -1152,11 +1163,13 @@ int IoCommandReadTruth( Abc_Frame_t * pAbc, int argc, char ** argv ) return 0; usage: - fprintf( pAbc->Err, "usage: read_truth [-xh] <truth>\n" ); + fprintf( pAbc->Err, "usage: read_truth [-xfh] <truth> <file>\n" ); fprintf( pAbc->Err, "\t creates network with node having given truth table\n" ); - fprintf( pAbc->Err, "\t-x : toggles between bin and hex representation [default = %s]\n", fHex? "hex":"bin" ); + fprintf( pAbc->Err, "\t-x : toggles between bin and hex representation [default = %s]\n", fHex? "hex":"bin" ); + fprintf( pAbc->Err, "\t-f : toggles reading truth table from file [default = %s]\n", fFile? "yes": "no" ); fprintf( pAbc->Err, "\t-h : prints the command summary\n" ); fprintf( pAbc->Err, "\ttruth : truth table with most signficant bit first (e.g. 1000 for AND(a,b))\n" ); + fprintf( pAbc->Err, "\tfile : file name with the truth table\n" ); return 1; } |