summaryrefslogtreecommitdiff
path: root/tools/pyboard.py
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2015-04-19 21:31:28 +0100
committerDamien George <damien.p.george@gmail.com>2015-04-19 21:31:28 +0100
commit2bb5f41611ddc90cf44090e87efd94523580008b (patch)
tree913391edbebc05e629b57797eea06d34718493d2 /tools/pyboard.py
parentf35b5d28db9da41d4f5bbd2647df6bab7ddfe9d4 (diff)
tools/pyboard.py: Make it 8-bit clean, so it works with unicode chars.
Addresses issue #1190.
Diffstat (limited to 'tools/pyboard.py')
-rwxr-xr-xtools/pyboard.py21
1 files changed, 12 insertions, 9 deletions
diff --git a/tools/pyboard.py b/tools/pyboard.py
index 77f397b6e..0374893a8 100755
--- a/tools/pyboard.py
+++ b/tools/pyboard.py
@@ -33,6 +33,9 @@ import sys
import time
import serial
+def stdout_write_bytes(b):
+ sys.stdout.buffer.write(b)
+
class PyboardError(BaseException):
pass
@@ -101,7 +104,7 @@ class Pyboard:
if isinstance(command, bytes):
command_bytes = command
else:
- command_bytes = bytes(command, encoding='ascii')
+ command_bytes = bytes(command, encoding='utf8')
# write command
for i in range(0, len(command_bytes), 256):
@@ -128,19 +131,19 @@ class Pyboard:
return ret
def execfile(self, filename):
- with open(filename) as f:
+ with open(filename, 'rb') as f:
pyfile = f.read()
return self.exec(pyfile)
def get_time(self):
- t = str(self.eval('pyb.RTC().datetime()'), encoding='ascii')[1:-1].split(', ')
+ t = str(self.eval('pyb.RTC().datetime()'), encoding='utf8')[1:-1].split(', ')
return int(t[4]) * 3600 + int(t[5]) * 60 + int(t[6])
def execfile(filename, device='/dev/ttyACM0'):
pyb = Pyboard(device)
pyb.enter_raw_repl()
output = pyb.execfile(filename)
- print(str(output, encoding='ascii'), end='')
+ stdout_write_bytes(output)
pyb.exit_raw_repl()
pyb.close()
@@ -214,7 +217,7 @@ def main():
if len(args.files) == 0:
try:
pyb = Pyboard(args.device)
- ret, ret_err = pyb.follow(timeout=None, data_consumer=lambda d:print(str(d, encoding='ascii'), end=''))
+ ret, ret_err = pyb.follow(timeout=None, data_consumer=stdout_write_bytes)
pyb.close()
except PyboardError as er:
print(er)
@@ -222,16 +225,16 @@ def main():
except KeyboardInterrupt:
sys.exit(1)
if ret_err:
- print(str(ret_err, encoding='ascii'), end='')
+ stdout_write_bytes(ret_err)
sys.exit(1)
for filename in args.files:
try:
pyb = Pyboard(args.device)
pyb.enter_raw_repl()
- with open(filename) as f:
+ with open(filename, 'rb') as f:
pyfile = f.read()
- ret, ret_err = pyb.exec_raw(pyfile, timeout=None, data_consumer=lambda d:print(str(d, encoding='ascii'), end=''))
+ ret, ret_err = pyb.exec_raw(pyfile, timeout=None, data_consumer=stdout_write_bytes)
pyb.exit_raw_repl()
pyb.close()
except PyboardError as er:
@@ -240,7 +243,7 @@ def main():
except KeyboardInterrupt:
sys.exit(1)
if ret_err:
- print(str(ret_err, encoding='ascii'), end='')
+ stdout_write_bytes(ret_err)
sys.exit(1)
if __name__ == "__main__":