Replaced readsome() with read() and gcount()
authorClifford Wolf <clifford@clifford.at>
Tue, 14 Oct 2014 23:12:53 +0000 (01:12 +0200)
committerClifford Wolf <clifford@clifford.at>
Tue, 14 Oct 2014 23:12:53 +0000 (01:12 +0200)
frontends/verilog/preproc.cc
kernel/yosys.cc
kernel/yosys.h
passes/cmds/write_file.cc

index b4e77c31bf53af4c3c5c2dc53f252a354fd61303..da658410d4993a35aa8a99d57fcc555c6d687bc0 100644 (file)
@@ -196,14 +196,16 @@ static std::string next_token(bool pass_newline = false)
 static void input_file(std::istream &f, std::string filename)
 {
        char buffer[513];
-       int rc;
 
        insert_input("");
        auto it = input_buffer.begin();
 
        input_buffer.insert(it, "`file_push " + filename + "\n");
-       while ((rc = readsome(f, buffer, sizeof(buffer)-1)) > 0) {
-               buffer[rc] = 0;
+       while (1) {
+               f.read(buffer, sizeof(buffer)-1);
+               if (f.gcount() <= 0)
+                       break;
+               buffer[f.gcount()] = 0;
                input_buffer.insert(it, buffer);
        }
        input_buffer.insert(it, "\n`file_pop\n");
index e50bfcbe67d9f67ee22c05014821fb37632dd705..ba3049c538d74014b6d807d4909d7793e08bbd89 100644 (file)
@@ -172,22 +172,6 @@ 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 run_command(const std::string &command, std::function<void(const std::string&)> process_line)
 {
        if (!process_line)
index 37d3e52f49d72d3d6bc95fbe07a30ed9914ff8f8..83230cbfbf3ed770e5e7c58d43e7b38338637869 100644 (file)
@@ -94,7 +94,6 @@ std::string stringf(const char *fmt, ...) __attribute__ ((format (printf, 1, 2))
 std::string vstringf(const char *fmt, va_list ap);
 std::string next_token(std::string &text, const char *sep);
 bool patmatch(const char *pattern, const char *string);
-int readsome(std::istream &f, char *s, int n);
 int run_command(const std::string &command, std::function<void(const std::string&)> process_line = std::function<void(const std::string&)>());
 std::string make_temp_file(std::string template_str = "/tmp/yosys_XXXXXX");
 std::string make_temp_dir(std::string template_str = "/tmp/yosys_XXXXXX");
index 3f441972420d8086d0e7a5c2cdc0e5053e4c320b..9bf1a75a8803eecae4642abf0d5fff41cc410f3b 100644 (file)
@@ -68,10 +68,13 @@ struct WriteFileFrontend : public Frontend {
 
                FILE *of = fopen(output_filename.c_str(), append_mode ? "a" : "w");
                char buffer[64 * 1024];
-               size_t bytes;
 
-               while (0 < (bytes = readsome(*f, buffer, sizeof(buffer))))
-                       fwrite(buffer, bytes, 1, of);
+               while (1) {
+                       f->read(buffer, sizeof(buffer));
+                       if (f->gcount() <= 0)
+                               break;
+                       fwrite(buffer, f->gcount(), 1, of);
+               }
 
                fclose(of);
        }