summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/base/io/io.c31
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;
}