- May 23, 2016
-
-
Damien George authored
Freezing mpy files using mpy-tool.py now works again.
-
- May 22, 2016
-
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
In particular, disclose the fact that server certificates are not validated.
-
Paul Sokolovsky authored
-
- May 21, 2016
-
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
Dave Hylands authored
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
Disabled by default, enabled in unix port. Need for this method easily pops up when working with text UI/reporting, and coding workalike manually again and again counter-productive.
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
These are workarounds required until frozen .mpy loading following standard frozen modules code path.
-
Paul Sokolovsky authored
Frozen modules are now stored with extensions and with '/' as path separator. In other words, frozen modules paths stored as they are in normal filesystem.
-
Paul Sokolovsky authored
Now frozen modules is treated just as a kind of VFS, and all operations performed on it correspond to operations on normal filesystem. This allows to support packages properly, and potentially also data files. This change also have changes to rework frozen bytecode modules support to use the same framework, but it's not finished (and actually may not work, as older adhox handling of any type of frozen modules is removed).
-
- May 20, 2016
-
-
Paul Sokolovsky authored
Similar to existing mp_hal_ticks_ms().
-
Paul Sokolovsky authored
Similar to existing mp_hal_delay_ms/mp_hal_ticks_ms.
-
Paul Sokolovsky authored
Make dupterm subsystem close a term stream object when EOF or error occurs. There's no other party than dupterm itself in a better position to do this, and this is required to properly reclaim stream resources, especially if multiple dupterm sessions may be established (e.g. as networking connections).
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
Damien George authored
-
Damien George authored
Otherwise some compilers (eg without optimisation) will put this read-only data in RAM instead of ROM.
-
- May 19, 2016
- May 17, 2016
-
-
Paul Sokolovsky authored
Both read and write operations support variants where either a) a single call is made to the undelying stream implementation and returned buffer length may be less than requested, or b) calls are repeated until requested amount of data is collected, shorter amount is returned only in case of EOF or error. These operations are available from the level of C support functions to be used by other C modules to implementations of Python methods to be used in user-facing objects. The rationale of these changes is to allow to write concise and robust code to work with *blocking* streams of types prone to short reads, like serial interfaces and sockets. Particular object types may select "exact" vs "once" types of methods depending on their needs. E.g., for sockets, revc() and send() methods continue to be "once", while read() and write() thus converted to "exactly" versions. These changes don't affect non-blocking handling, e.g. trying "exact" method on the non-blocking socket will return as much data as available without blocking. No data available is continued to be signaled as None return value to read() and write(). From the point of view of CPython compatibility, this model is a cross between its io.RawIOBase and io.BufferedIOBase abstract classes. For blocking streams, it works as io.BufferedIOBase model (guaranteeing lack of short reads/writes), while for non-blocking - as io.RawIOBase, returning None in case of lack of data (instead of raising expensive exception, as required by io.BufferedIOBase). Such a cross-behavior should be optimal for MicroPython needs.
-
Paul Sokolovsky authored
This allows to enable the options which aren't enabled in the normal unix config (as unix port is no longer an enable-all port).
-
- May 16, 2016
-
-
Paul Sokolovsky authored
modwebrepl truncates password to 9 chars, and that led people to confusion.
-
Damien George authored
To use frozen bytecode make a subdirectory under the unix/ directory (eg frozen/), put .py files there, then run: make FROZEN_MPY_DIR=frozen Be sure to build from scratch. The .py files will then be available for importing.
-
Damien George authored
When an mpy file is frozen it must know the values of certain configuration variables. This patch provides an explicit check in the generated C file that the configuration variables are what they are supposed to be.
-
Paul Sokolovsky authored
That was the intent for the initial user setup, but didn't work before due to lwIP issues. Enable now that they're fixed.
-
Paul Sokolovsky authored
-
Robert HH authored
That one was missing in the module, even if it was available in the vfs object. The change consist of adding the name and preparing the call to the underlying vfs module, similar to what was already implemented e.g. for remove. Rename is useful by itself, or for instance for a safe file replace, consisting of the sequence: write to a temp file delete the original file rename the temp file to the original file's name
-
- May 15, 2016
-
-
Paul Sokolovsky authored
Calling it from lwIP accept callback will lead incorrect functioning and/or packet leaks if Python callback has any networking calls, due to lwIP non-reentrancy. So, instead schedule "poll" callback to do that, which will be called by lwIP when it does not perform networking activities. "Poll" callback is called infrequently though (docs say every 0.5s by default), so for better performance, lwIP needs to be patched to call poll callback soon after accept callback, but when current packet is already processed.
-
- May 14, 2016
-
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
It allows to "import foo.bar", but not "from foo import bar".
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
Paul Sokolovsky authored
-
- May 13, 2016
-
-
Radomir Dopieralski authored
Since the ``stop`` parameter has been dropped.
-
Damien George authored
For example, the following code now works with a file on the SD card: f = open('test', 'rb') # test must be 1024 bytes or more in size f.seek(511) f.read(513) Also works for writing. Fixes issue #1863.
-