Skip to main content

Coding IDE/Client for LambdaMOO style servers

Project description

MooCoderPy

Python/Tkinter version of Moocoder

MooCoder is an IDE for programming MOO Code in LambdaMOO or similar servers. It incorporates a built in MOO/MUSH client, supports the local edit option, and allows you to load and edit object verbs in different tabs. It supports syntax highlighting, jump to error location and a stack trace window.

This should run on Python 3.6 (or better) and uses the tkinter with no external dependencies.

The original Delphi implementation can be found at https://github.com/rjmatthews62/MooCoder

Installation

Can be installed via pip:

  • pip install moocoderpy-rjmatthews62
  • python -m MooCoderPy

Setup

  • Settings -> Server Config : set server address (and port). You can also set font size.
  • File -> Connect - Connect to server
  • File -> Disconnect - Disconnect from server
  • File -> Open - Open a local file in the editor

External Editor support:

If you set @edit-option local+ on your MOO server, the @edit command will be redirected to MooCoderPy's internal editor. Selecting Edit->Send Update (or F5) will issue the correct command to update whatever you are currently editing. Each edited item will have its own tab, and you can use the test line as for the verbs.

Project->New Tab (Ctrl+N) - Loads a verb into its own tab. Press F5 to compile.

Project->Get Verbs (Ctrl+Shift+V) - Load all the verbs for an object into the verbs window. You can double click in the Verbs pane to edit that verb.

Project->Clear Project - Close all code windows and clear verb list

View->Toggle View Ctrl+Shift+Y - Toggle between terminal and previous edit view.

Basic error checking and stack trace implemented.

Syntax Highlighting implemented.

Command History is supported using the up and down arrow keys

Each code window has an optional single-line test command which will run on successful compile (F5)

Bracket Matching implemented

Right-Click in code window will bring up a context menu.

  • Goto Line Ctrl+G will got to a line no in a code window.
  • Find Ctrl+F - find text in current window
  • Find Again F3 - repeat last find
  • Replace Ctrl+H - search and replace text
  • Refresh Ctrl+R - Reload page from server
  • Redo Syntax - redo syntax highlighting on page
  • Close - Close current window.
  • Undo - Ctrl+Z - undo last changes
  • Redo - Shift+Ctrl+Z - redo last changes

A double-click on an error message or stack trace in either the stack or the main terminal window will go the the relevent source code.

Release History

0.3.6 - Adjustable font size (in Setup-->Server Config). Local Edit refresh now works

0.3.5 - Fixed bug with Ctrl+N adding to verb list

0.3.4 - External edit can have test lines, Ctrl+Shift+T toggle view, additional detail shown in edit window.

0.3.3 - External edit now opens in a seperate tab per item, supports syntax.

0.3.2 - Double-click on error messages or stack to go to source line.

0.3.1 - Fixed windows maximized for linux environment

0.3.0 - Fixed disconnect handling issue, set default window state to maximized.

0.2.9 - Tweaked selection handling.

0.2.8 - Replace working, Undo and Redo implemented

0.2.7 - Additional icon error checking.,

0.2.6 - Bracket Matching

0.2.5 - removed unwanted checkbox import

0.2.4 - Edit find, context menu, refresh, close, clear

0.2.3 - Added Syntax highlighting, Goto Line, Cursor Location

0.2.2 - Added Auto-test functionality

0.2.1 - Sorting out window icon on linux

0.2.0 - Fighting with packaging tools

0.1.9 - Type definition fix for older pythons and include icon in package.

0.1.5 - Added icon, tidied up Verb window sizing and include docstring in verb window.

0.1.4 - Get Verb and Verbs window working.

0.1.3 - Edit Verb (Edit->New Tab)

0.1.2 - Show version, added F5 shortcut, save recent history, set config file to home folder.

0.1.1 - Added external editor support, command history

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

MooCoderPy-rjmatthews62-0.3.6.tar.gz (136.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

MooCoderPy_rjmatthews62-0.3.6-py3-none-any.whl (135.2 kB view details)

Uploaded Python 3

File details

Details for the file MooCoderPy-rjmatthews62-0.3.6.tar.gz.

File metadata

  • Download URL: MooCoderPy-rjmatthews62-0.3.6.tar.gz
  • Upload date:
  • Size: 136.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for MooCoderPy-rjmatthews62-0.3.6.tar.gz
Algorithm Hash digest
SHA256 151e2c9ebf9cabd40c20062018c7e1b92a1b70d3c119930da81b2595c7c1e9df
MD5 830b326e65a2f6536d60438f0f8051c0
BLAKE2b-256 15c40483d048a4800d9f320b10607e9f98cd5e511eda84f083bb2426af0ae614

See more details on using hashes here.

File details

Details for the file MooCoderPy_rjmatthews62-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: MooCoderPy_rjmatthews62-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 135.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for MooCoderPy_rjmatthews62-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e62c6188fe509a264a28d0dbbac1cb339732ca98d7b796548c8b7bb0f9975234
MD5 6b53c0a3a5a76cf1498ab6d50ee680cd
BLAKE2b-256 60f1f5f8aa3c3d435b23f5053d185de5c1a6e20ab4bfce938e012c0d656c1313

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page