Skip to content

joewez/AmpyFileManager

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

66 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ampy File Manager

Windows GUI for the Adafruit MicroPython Utility

Screenshot

A simple GUI wrapper that executes the AMPY (https://github.com/scientifichackers/ampy) command to manipulate the files on an ESP8266 board running MicroPython.

It was written in C# in Visual Studio 2019, so you will need VS Express or better to compile it. It uses the Scintilla editor control (https://github.com/jacobslusser/ScintillaNET) which allows for MicroPython syntax highlighting.

As a development tool, I wrote the utility to mainly just edit the files directly off of the device. I have also embedded a simple terminal emulator to send commands to the serial REPL. The program works better though when paired with an external terminal such as puTTY or TeraTerm. See the configuration notes below on how to set this up.

A precompiled binary is available for download here:

http://wezensky.no-ip.org/shared/afm.zip

Just unzip to a convenient location and run the AmpyFileManager.exe. NOTE: The latest .Net Framework is required for this application to run.

HOW TO START:

  • Plug your MicroPython device into your computer and determine what com port it was assigned to
  • Start the application.
  • Select the com port for your device (if there is more than one)
  • The main window should appear with the files on the root of the device listed
  • If there was a problem and the files were not listed, click on the Refresh button (If you still do not see any files on your device your version of AMPY may be incompatible. See below.)

HOW TO USE:

All the features are pretty self-explanatory, but here is just a short description of it's general use.

  • Navigation

    • To open a file for viewing or editing, select the file and click "Open" (or just double-click the filename)
    • To go into a sub-folder select the folder and click "Open" (or just double-click the folder name)
    • To go back one directory click on the [..] entry at the top of the file list
  • Main Commands

    • New will prepare a new file for editing
    • Open will open a file for editing or change the directory
    • Load will allow you to import a file from your computer
    • Export will save the selected file to your computer
    • Delete will delete the file or directory from the device
    • Move will move (rename) the selected file
    • MKDIR will allow you to create a sub-folder
    • Refresh will re-read the file list of the current directory
    • Run will attempt to import/run the selected file
    • REPL will open a MicroPython REPL window
  • Editing Commands

    • Replace All will do a simple search and replace on the current file being edited
    • Save As will save the current file to the device using the name you give it in the current directory
    • Save will save the current file to the device

ADDITIONAL INFO:

  • AMPY is an active project and as such, will change in a way that sometimes breaks this application. Currently this application is compatible with version 1.0.7.
  • Configuration setting are located in the AmpyFilemanager.exe.config file
    • The application defaults to 115200 baud for serial communications
    • Most settings are self-explanatory
    • If ExternalTerminal is set to "Y" the TerminalApp, TerminalAppArgs and TerminalAppTitle settings are used
      • TerminalApp is the EXE to run

      • TerminalAppArgs are the arguments to run the terminal app with

        • The term {PORT} in this setting will be replaced at runtime with the current port
        • The term {PORTNUM} in this setting will be replaced at runtime with the current port number
      • TerminalAppTitle is the title of the external window

      • Example:

        <add key="ExternalTerminal" value="Y" />
        <add key="TerminalApp" value="putty" />
        <add key="TerminalAppArgs" value="-load "repl" -serial {PORT}" />
        <add key="TerminalAppTitle" value="PuTTY" />

        Invokes the putty.exe application and uses the "repl" session

    • The EditExtensions setting determines what types of files are editable (text)
    • The SaveDir setting determines where session files are created, if blank the EXE location is used
    • UniqueSessions indicates if a single session directory is used or a new one for each program start
      • The "session" directory is where a file is stored while being edited
    • Color settings may be a WebColor name or a 3 value, comma-separated list of the RGB values to use

CAVEATS:

  • This editor is only meant to edit a single file at a time
  • Because of some limitations, in order to use this tool you must follow this guideline...
    • Directories will be recognized by their lack of an extension
    • Editable files are recognized by their use of an extension
  • Although it should work with any device that AMPY works with, it has only been tested with...
    • Wemos D1 Mini
    • Witty Cloud Board
    • Generic NodeMCU Board.
    • (Primarily ESP8266 Boards)
  • This is mainly for text files (binary files will upload to the device but will not download correctly)
  • Switching between the REPL and the editor (and back) is a little rough... especially with the limited built-in serial terminal.
    • You may have to "Refresh" or try again to get a feature to work.
    • Sometimes the software will pause until the device is momentarily unplugged
    • This is highly dependent on the type of application that is running
    • It is recommended you use an external application (such as putty or TeraTerm) for the REPL

ROADMAP:

  • Support multiple files editing at one time
    • Split window functionality for file compares
  • Provide proper editing functions
    • Simple edit commands
    • Simple find
    • Python formatting cleanup
    • Highlighting support for other text file types (html, xml, etc,,,)
  • Replace AMPY with integral communication routines to the ESP8266
    • Remove directory naming limitation
  • Proper options selection window.

About

Windows GUI for the Adafruit MicroPython Utility

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages