[update] micropython の開発環境をとりあえず整えた。Lチカができる。

This commit is contained in:
ocogeclub 2022-07-16 22:54:49 +09:00
parent c151546f3e
commit 5cc7bb9662
7 changed files with 176 additions and 25 deletions

View File

@ -323,12 +323,14 @@ const ugj_loadWorkspace = () => {
const ugj_pyBeautify = (code) => { const ugj_pyBeautify = (code) => {
let formatted = ''; let formatted = '';
// // formatted = window.ocogeapi.child_process.spawnSync('python3', ['-m', 'black', '-'], { input: code }).stdout.toString(); // // formatted = window.ocogeapi.child_process.spawnSync('python3', ['-m', 'black', '-'], { input: code }).stdout.toString();
try { // try {
// formatted = require('child_process').spawnSync('python3', ['-m', 'black', '-'], { input: code }).stdout.toString();
// } catch (e) {
// formatted = code;
// console.log('Python formatter "Black" is not found.');
// }
formatted = require('child_process').spawnSync('python3', ['-m', 'black', '-'], { input: code }).stdout.toString(); formatted = require('child_process').spawnSync('python3', ['-m', 'black', '-'], { input: code }).stdout.toString();
} catch (e) { if (!formatted) formatted = code;
formatted = code;
console.log('Python formatter "Black" is not found.');
}
return formatted; return formatted;
} }
@ -436,7 +438,7 @@ const ugj_runCode = async () => {
// Pyboard ocoge // Pyboard ocoge
const ugj_spawnPyboard = (code, mode) => { const ugj_spawnPyboard = (code, mode) => {
let script_path = elutil.path.join(elutil.library_path, 'pyboard_ocoge.py'); let script_path = elutil.path.join(elutil.library_path, 'pybtool.py');
let p = require('child_process').spawn('python3', [script_path, mode]); let p = require('child_process').spawn('python3', [script_path, mode]);
p.stdin.write(code); p.stdin.write(code);
p.stdin.end(); p.stdin.end();

View File

@ -314,6 +314,12 @@ class elUtil {
} }
// PyBfm を起動
launchPyBfm() {
let script_path = this.path.join(elutil.library_path, 'pybfm.py');
require('child_process').spawn('python3', [script_path]);
}
// ファイル名にアプリケーションのドキュメントルートまでのパスをつけて返す // ファイル名にアプリケーションのドキュメントルートまでのパスをつけて返す
getDocPath(filename) { getDocPath(filename) {
return this.path.join(this.appDocRoot, filename); return this.path.join(this.appDocRoot, filename);

View File

@ -1,2 +0,0 @@
# test
import test

View File

@ -1,16 +0,0 @@
from machine import Pin
from utime import sleep
pin = None
pin = 25
_pin = {}
_pin[pin] = Pin(pin, Pin.OUT)
for count2 in range(5):
for count in range(2):
_pin[pin].value(1)
sleep(0.1)
_pin[pin].value(0)
sleep(0.1)
sleep(0.6)

150
lib/pybfm.py Normal file
View File

@ -0,0 +1,150 @@
#!/usr/bin/python3
# coding: utf-8
from tkinter import *
from tkinterdnd2 import *
import os
import sys
import pyboard
import serial.tools.list_ports
from tkinter import messagebox
##### グローバル変数 #####
gport = None
##### イベントハンドラ #####
# リストボックスにドロップ
def listbox_drop(event):
files = listbox.tk.splitlist(event.data)
for f in files:
if os.path.exists(f):
print('Dropped file: "%s"' % f)
if os.path.isfile(f):
putfile(f)
filelist()
else:
messagebox.showwarning('Warning', 'フォルダは転送できません')
else:
print('Not dropping file "%s": file does not exist.' % f)
def input_key(ev):
# print(ev)
if ev.keysym == 'F5':
filelist()
elif ev.keysym == 'Delete':
selected = listbox.curselection()
for i in selected:
src = listbox.get(i)
call_pybfunc('fs_rm', src)
print('Deleted %s' % src)
if len(selected):
filelist()
def on_closing(errmsg=''):
if errmsg:
messagebox.showerror('Error', errmsg)
root.destroy()
sys.exit(0)
##### pyboard関数 #####
def connect():
global gport
try:
pyb = pyboard.Pyboard(gport)
pyb.enter_raw_repl()
return pyb
except:
on_closing('デバイスに接続できません')
def disconnect(pyb):
try:
pyb.exit_raw_repl()
pyb.close()
except:
on_closing('切断に失敗しました')
# コマンド実行
def exec_command(cmd):
pyb = connect()
try:
retval = pyb.exec_(cmd)
except:
on_closing('コマンド実行時にエラーが発生しました')
disconnect(pyb)
return retval.decode('utf-8')
# pyboard.py の関数をコール
def call_pybfunc(funcname, *args):
pyb = connect()
if funcname=='fs_put':
pyb.fs_put(args[0], args[1])
elif funcname=='fs_rm':
pyb.fs_rm(args[0])
disconnect(pyb)
def initialize():
global gport
for p in sorted(serial.tools.list_ports.comports()):
if p.hwid.startswith('USB'):
gport = p.device
set_title(gport)
filelist()
break
else:
on_closing('デバイスがみつかりません')
def list_clear():
listbox.delete(0, END)
def filelist():
list_clear()
files = ls()
for f in files:
listbox.insert(END, f)
def ls(src='/'):
cmd = (
"import uos\nfor f in uos.listdir(%s):\n"
" print(f)"
% (("'%s'" % src) if src else "")
)
retval = exec_command(cmd)
return retval.splitlines()
def putfile(src):
dest = os.path.basename(src)
call_pybfunc('fs_put', src, dest)
def set_title(title):
root.title('PyBfm - ' + title)
##### メイン #####
# メインウィンドウの生成
root = TkinterDnD.Tk()
root.protocol("WM_DELETE_WINDOW", on_closing)
root.title('PyBfm')
root.geometry('400x300')
# root.config(bg='#cccccc')
# Frameウィジェットの生成
frame = Frame(root)
# Listboxウィジェットの生成
listbox = Listbox(frame, selectmode=EXTENDED)
listbox.drop_target_register(DND_FILES)
listbox.dnd_bind('<<Drop>>', listbox_drop)
listbox.bind("<KeyPress>", input_key)
# スクロールバーの生成
scroll = Scrollbar(frame, orient=VERTICAL)
listbox.configure(yscrollcommand=scroll.set)
scroll.config(command=listbox.yview)
# ウィジェットの配置
frame.pack(expand=True,fill=BOTH)
listbox.pack(expand=True,fill=BOTH, side=LEFT)
scroll.pack(side=RIGHT, fill=Y)
initialize()
root.mainloop()

11
main.js
View File

@ -217,6 +217,17 @@ let template = [
} }
] ]
}, },
{
label: "Tools",
submenu: [
{
label: "Launch PyBfm",
click: (item, focusedWindow) => {
focusedWindow.webContents.executeJavaScript('elutil.launchPyBfm()');
},
},
]
}
] ]
const menu = Menu.buildFromTemplate(template) const menu = Menu.buildFromTemplate(template)
Menu.setApplicationMenu(menu) Menu.setApplicationMenu(menu)