micropython/windows
Jan Čapek d76c65f599 py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file

- add special rule for generating a central header that contains all
  extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
  variable. Each platform appends a list of sources that may contain
  qstrings into a new build variable: SRC_QSTR. Any autogenerated
  prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.

- remove most qstrings from py/qstrdefs, keep only qstrings that
  contain special characters - these cannot be easily detected in the
  sources without additional annotations

- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
  stmhal, teensy, unix, windows, pic16bit:

   - remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
   - remove all port specific qstrdefs except for special strings
   - append sources for qstr generation in platform makefiles (SRC_QSTR)
2016-04-16 13:18:09 +01:00
..
msvc windows/msvc: Add modurandom.c to list of source files. 2016-01-26 19:38:59 +00:00
.appveyor.yml windows: Add Appveyor CI builds for msvc port. 2015-12-18 21:49:35 +00:00
.gitignore Windows MSVC port 2014-05-08 10:06:43 +02:00
init.c windows/msvc: Nicer handling of asserts and 'invalid' parameters 2015-12-26 22:14:16 +00:00
init.h windows: Add modtime implementation 2014-05-09 13:58:15 +02:00
Makefile py: Add rules for automated extraction of qstrs from sources. 2016-04-16 13:18:09 +01:00
micropython.vcxproj Fix project file for Visual Studio 2015 2015-11-10 17:36:08 +02:00
mpconfigport.h py: Declare help, input, open builtins in core. 2016-04-15 00:07:56 +03:00
mpconfigport.mk windows: Implement the mp_hal_xxx functions and enable mp-readline 2015-06-04 19:22:13 +03:00
README windows/py: Support 64bit mingw-w64 builds 2015-11-24 17:34:14 +02:00
realpath.c windows: Make unistd.h more posix compatible 2015-08-14 12:04:23 +02:00
realpath.h Add license header to (almost) all files. 2014-05-03 23:27:38 +01:00
sleep.c windows: Add usleep() implementation for msvc port 2015-10-25 15:42:19 +03:00
sleep.h windows: Add usleep() implementation for msvc port 2015-10-25 15:42:19 +03:00
windows_mphal.c windows: Better handling of Ctrl-C 2015-12-21 20:51:27 +02:00
windows_mphal.h windows: Define ssize_t and use renamed mphal header 2015-11-14 02:06:55 +02:00

This is experimental, community-supported Windows port of MicroPython.
It is based on Unix port, and expected to remain so.
The port requires additional testing, debugging, and patches. Please
consider to contribute.


To cross-compile under Debian/Ubuntu Linux system:

sudo apt-get install gcc-mingw-w64
make CROSS_COMPILE=i686-w64-mingw32-

If for some reason the mingw-w64 crosscompiler is not available, you can try
mingw32 instead, but it comes with a really old gcc which may produce some
spurious errors (you may need to disable -Werror):

sudo apt-get install mingw32 mingw32-binutils mingw32-runtime
make CROSS_COMPILE=i586-mingw32msvc-


To compile under Cygwin:

Install following packages using cygwin's setup.exe:
mingw64-i686-gcc-core, mingw64-x86_64-gcc-core, make
Build using:

make CROSS_COMPILE=i686-w64-mingw32-

or for 64bit:

make CROSS_COMPILE=x86_64-w64-mingw32-


To compile using Visual Studio 2013 (or higher):

Open micropython.vcxproj and build


To compile using Visual Studio 2013 (or higher) commandline:

msbuild micropython.vcxproj


To run on Linux using Wine:

The default build (MICROPY_USE_READLINE=1) uses extended Windows console
functions and thus should be run using "wineconsole" tool. Depending
on the Wine build configuration, you may also want to select the curses
backend which has the look&feel of a standard Unix console:

    wineconsole --backend=curses ./micropython.exe

For more info, see https://www.winehq.org/docs/wineusr-guide/cui-programs

If built without line editing and history capabilities
(MICROPY_USE_READLINE=0), the resulting binary can be built using standard
"wine" tool.