summaryrefslogtreecommitdiff
path: root/kernel/yosys.cc
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2014-10-11 11:36:22 +0200
committerClifford Wolf <clifford@clifford.at>2014-10-11 11:36:22 +0200
commit8263f6a74a822579f3c1da7d8b128ea8ab7b4d79 (patch)
treedbeedfef238d40f2c882779cb6128346998dce71 /kernel/yosys.cc
parenta32e067e5c96bacc1f0280f9f1bfd979af2171db (diff)
Fixed win32 troubles with f.readsome()
Diffstat (limited to 'kernel/yosys.cc')
-rw-r--r--kernel/yosys.cc16
1 files changed, 16 insertions, 0 deletions
diff --git a/kernel/yosys.cc b/kernel/yosys.cc
index 921f2b38..a40ad437 100644
--- a/kernel/yosys.cc
+++ b/kernel/yosys.cc
@@ -166,6 +166,22 @@ bool patmatch(const char *pattern, const char *string)
return false;
}
+int readsome(std::istream &f, char *s, int n)
+{
+ int rc = f.readsome(s, n);
+
+ // win32 sometimes returns 0 on a non-empty stream..
+ if (rc == 0) {
+ int c = f.get();
+ if (c != EOF) {
+ *s = c;
+ rc = 1;
+ }
+ }
+
+ return rc;
+}
+
int GetSize(RTLIL::Wire *wire)
{
return wire->width;