summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2020-08-12 15:33:09 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2020-08-12 15:33:09 -0700
commitb74b7dfc2d2065eebc800c9165a3e15caeb4453d (patch)
tree20b8cebe1340b0f3ebac2650f93e420bd7b83f4a
parent5c8ee4a2c142d133afe4cbfe567b300fe4d040a8 (diff)
downloadabc-b74b7dfc2d2065eebc800c9165a3e15caeb4453d.tar.gz
abc-b74b7dfc2d2065eebc800c9165a3e15caeb4453d.tar.bz2
abc-b74b7dfc2d2065eebc800c9165a3e15caeb4453d.zip
Extending &sim_read to use non-64-divisible pattern counts.
-rw-r--r--src/misc/vec/vecWrd.h16
1 files changed, 13 insertions, 3 deletions
diff --git a/src/misc/vec/vecWrd.h b/src/misc/vec/vecWrd.h
index 3e25c066..663b7a88 100644
--- a/src/misc/vec/vecWrd.h
+++ b/src/misc/vec/vecWrd.h
@@ -1300,10 +1300,20 @@ static inline Vec_Wrd_t * Vec_WrdReadHex( char * pFileName, int * pnWords, int f
p = Vec_WrdAlloc( 1000 );
while ( (c = fgetc(pFile)) != EOF )
{
- if ( c == '\n' && nWords == -1 )
- nWords = Vec_WrdSize(p);
- if ( c == '\n' || c == '\r' || c == '\t' || c == ' ' )
+ if ( c == '\r' || c == '\t' || c == ' ' )
continue;
+ if ( c == '\n' )
+ {
+ if ( nChars > 0 )
+ {
+ Vec_WrdPush( p, Num );
+ nChars = 0;
+ Num = 0;
+ }
+ if ( nWords == -1 && Vec_WrdSize(p) > 0 )
+ nWords = Vec_WrdSize(p);
+ continue;
+ }
Num |= (word)Vec_WrdReadHexOne((char)c) << (nChars * 4);
if ( ++nChars < 16 )
continue;