Replies: 6 comments 29 replies
-
I may have misunderstood, but judging by the image having the stubs folders marked as source root, I got the impression that the proposed solution entails uploading stubs directly onto the device filesystem. If that is the case, I would avoid doing so. Microcontrollers are by definitions working with restricted resources, and any amount of free storage space is valuable, this is especially true for some ESP8266 devices. If I have indeed misunderstood or if there is a way to do what you propose without uploading stubs on the device file system, then I believe that this is actually the best practice - involving the user in selecting the stub device type. There are a few edge case scenarios to handle that come to mind. The plugin probably should allow the user to somehow manually select/search for the specific device type, if for whatever reason the detection fails or the user has some kind of alternative intent. This could be handled together with manually selecting one's own local stubs. Aside from uploading stubs directly onto the device, which might just be my misunderstanding, this solution seems like the best way to handle stubs in this plugin. |
Beta Was this translation helpful? Give feedback.
-
There is an alternative approach to auto-detection compared to the old one. I personally go back and forth between multiple ESP32 devices and USB ports when working with MicroPython. Different USB hub at work, different USB hub at home and even switching to a different USB port on my computer changes the device path of the Microcontroller I am working with. Perhaps a different form of auto-detection could be implemented in the new plugin. It would make things a tad bit easier if there was a way to track one device even after it pops up under a different device path. Known devices could be saved as device presets, or just the last connected device could be remembered and searched for in the available device paths. It doesn't really matter how complex the functionality built around this device tracking would be. Something like this could theoretically even be used to narrow down the USB serial port selection drop-down list to just devices that can somehow be verified as having MicroPython installed. Now implementing this is where things can get more difficult. Telling apart devices which have MicroPython installed is possible. The unique ID can be used and relied upon on most if not all device types. So some combination of the USB VID:PID and unique ID could be used. I can, however, see how scanning all serial port paths might not be practical. I will leave the question of whether or not this is plausible up to you, you are better suited to answer it than me. But talking about autodetect approach this is what comes to mind for me. If this would indeed be possible and wouldn't require a terribly overcomplicated solution, then some really cool features could be built around it. |
Beta Was this translation helpful? Give feedback.
-
If there are plans to take this approach ,
I have a preference for MIT, mostly to avoid carrying too many different license types into the micropython repo. If that is not possible, then most likely I'll go back to the the somewhat older version from https://github.com/hlovatt/PyBoardTypeshed instead. But before that we need to discuss that with the MicroPython core team as well. Also see: Josverl/micropython-stubs#762 |
Beta Was this translation helpful? Give feedback.
-
Hey @elmot could I ask about the reason you want to switch to using mpremote? What are the benefits over the existing Kotlin implementation? |
Beta Was this translation helpful? Give feedback.
-
In the last few days I've been considering how stubs and device type detection could be handled. Firstly, I would welcome moving the port selector drop down left of the connect/disconnect button in the MicroPython plugin window. This would make it easier to work with, as I often find myself having to go to the settings multiple times in a day, which can get annoying. I understand that this could be difficult and that it has plenty of considerations, here are a few problems and their solutions I thought of:
For both of these problems I would go with an approach similar to how thonny does it. In Thonny you have the bottom right serial port drop down, which is the default quick access. Then its interpreter settings allow you to select a device manufacturer, specific communication type and then either the serial device or WebREPL credentials. The way this then propagates is that the main quick access serial device drop down is switched to displaying This plugin's implementation could be expanded for choosing the MicroPython version as well, so that users have more control over specific stub settings should they need it. |
Beta Was this translation helpful? Give feedback.
-
I have a question regarding two functions that could be added to the plugin.
|
Beta Was this translation helpful? Give feedback.
-
The problem:
There are numerous Micropython boards nowadays, and a number of Micropython forks. There is a number of additional libraries to be installed.
As a result, now it's virtually impossible to maintain a comprehensive set of python stubs inside the plugin. Additionally, that diversity of boards makes board detection by USB VID:PID useless in many cases.
Proposed solution
os.uname()
pip
into the project structureAs the result, a typical project layout with `main.py` and compiled `ssd1306` library would look like:
Device layout looks like
Any thoughts or concerns?
Related to #220, #240, #141, #114, #326, #319, #316, and many others
Beta Was this translation helpful? Give feedback.
All reactions