diff options
author | Anthony Thibault <ajt@hyperlogic.org> | 2013-05-19 10:23:38 -0700 |
---|---|---|
committer | Anthony Thibault <ajt@hyperlogic.org> | 2013-05-19 10:23:38 -0700 |
commit | 179dfed363127088299179f252b88e8abc3ff3be (patch) | |
tree | 6e994e92dc5314f1e97cf2255e7f3e3d945ccd3a | |
parent | 4e66f07c04a2fd118b7f7aa1280f62974b77e48d (diff) |
Issue #1172: fix for fscanf
-rw-r--r-- | src/library.js | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/library.js b/src/library.js index 344ec8d6..275132e5 100644 --- a/src/library.js +++ b/src/library.js @@ -3576,14 +3576,14 @@ LibraryManager.library = { return -1; }, fscanf__deps: ['$FS', '__setErrNo', '$ERRNO_CODES', - '_scanString', 'getc', 'ungetc'], + '_scanString', 'fgetc', 'fseek', 'ftell'], fscanf: function(stream, format, varargs) { // int fscanf(FILE *restrict stream, const char *restrict format, ... ); // http://pubs.opengroup.org/onlinepubs/000095399/functions/scanf.html if (FS.streams[stream]) { - var stack = []; - var get = function() { var ret = _fgetc(stream); stack.push(ret); return ret }; - var unget = function(c) { return _ungetc(stack.pop(), stream) }; + var i = _ftell(stream), SEEK_SET = 0; + var get = function () { i++; return _fgetc(stream); }; + var unget = function () { _fseek(stream, --i, SEEK_SET); }; return __scanString(format, get, unget, varargs); } else { return -1; |