You are reading a single comment by @Gordon and its replies. Click here to read the full conversation.
  • Hi there,

    Just a quick explanation of some of the stuff that's in 1v63:

    First the fun stuff...

    Streaming File API

    While you could load files before, you could only load an entire file into memory - you couldn't load a bit at a time.

    Cephdon's done a bunch of work on this, and I just integrated it. We've settled on a nice simple file API:

    f = E.openFile("hi.txt", "w");
    f.write("Hello World");
    f.close();
    
    f = E.openFile("hi.txt", "r");
    f.read(5) // .. "Hello"
    f.read(5) // .. " Worl"
    f.read(5) // .. "d"
    f.read(5) // .. undefined
    f.close();
    

    I don't like deviating from the standards that everyone else has, but in this case every JavaScript file API I've come across seems unsuitable, so coming up with a nice clean File API seemed the best way forwards.

    Piping files

    This is where the streaming file API really shines. Because you couldn't load part of a file into memory before, you couldn't do things like serve up a webpage that wouldn't fit into memory. Now it's dead easy:

    function onPageRequest(req, res) {
      res.writeHead(200, {'Content-Type': 'video/webm'});
      E.openFile("rick.webm").pipe(res);
    }
    require('http').createServer(onPageRequest).listen(80);
    

    The code above will serve an arbitrarily-sized file directly from the SD card.

    This uses standard JavaScript too, so you can actually make your own endpoints for pipes if you want to. I'll be working on making more of Espruino's built-in classes accept piping in the future - for example the Waveform class could stream sound directly from the SD card, or could even record sound and output it over HTTP!

    Better HTTP stream support

    Part of the work above involved tweaking the HTTP server and client to allow streaming. They now emit drain events when they're empty, so you can easily not just serve, but compute webpages that would never have fitted into memory before.

    For example, perhaps you're making a data logger and storing the last 10,000 samples in RAM. This is fine, but you can't send a webpage full of them, because if you convert that binary data to ascii, it could take up 40,000 bytes and use up all your memory.

    Instead, you can use the drain event to send the data in chunks...

    var history = new Uint8Array(10000);
    
    // ...
    
    function onPageRequest(req, res) {
      res.writeHead(200, {'Content-Type': 'text/plain'});
      var n = 0;
      res.on('drain',function() {
        for (var i=0;i<10;i++)
          res.write(history[n++]+",");
        if (n>=history.length) res.end(" ];");
      });
      res.write("var data = [");
    }
    require('http').createServer(onPageRequest).listen(80);
    

    Fixes/tweaks

    And finally, I guess you won't notice these, but:

    • edit(...) is now able to edit functions that are in use in callbacks - for example with setInterval
    • Sparse arrays - raybellis contributed some code that really helped out here. There was some non-standard behaviour before when adding/removing elements, and it's basically sorted now.
    • Faster Utility timer (so the max speed for waveforms should have gone up)
    • Errors on long lines now display nicely, and the pointer to the error location is better aligned in all cases
    • When you get an error in one function called from another, stack traces are a lot more useful now too
    • Added HIGH/LOW constants for better Arduino compatibility (a few people had bumped into that)
    • Improved documentation on SPI/I2C/Serial
    • CC3000 auto-reconnect - this seems to fix a lot of outstanding WiFi issues. It's been running for 48 hours non-stop not without issues.
    • Martin's put in a load of time and has fixed a lot of the problems that were plagueing WIZnet Ethernet. It's looking really good now.
    • E.reverseByte has now been added - it's ends up being quite useful, especially when dealing with displays.
    • Support for bigger Espruino chips. We've found that a lot of you (maybe all of you) actually have chips on your Espruino boards with 64kB of RAM (even though they're marked as having 48kB). While the existing binary won't use this memory automatically, you can now compile your own binaries (or use someone else's) that will.
    • Fixed the header sent by the HTTP client when accessing ports that aren't 80
About

Avatar for Gordon @Gordon started