Skip to main content

An interactive shell and editor for controlling Minecraft servers and creating powers.

Project description

MC-Shell: A Minecraft Power Development Environment

Welcome to mc-shell! This project provides an interactive environment for creating, debugging, and using "powers" in Minecraft. It combines a powerful command-line shell with a visual block-based editor and a touch-friendly control panel.

This guide will walk you through installing the software, managing your own Minecraft worlds, and using the tools to bring your creations to life.

Quick Start

This guide will get you running in just a few minutes. Each step is linked to a more detailed section below.

  1. Install the Software:
    pip install --user mc-shell
    
  2. Enter the Shell:
    mcshell start
    
  3. Create Your First World:
    %pp_create_world my_first_world
    
  4. Start Your World:
    %pp_start_world my_first_world
    
  5. Use the Editor: Open a browser and go to http://localhost:5001.
  6. Exit Cleanly: Type exit or hit Ctrl-D in the shell to stop your world and the application server.

Getting Started

Installation

Before you begin, you will need a few things installed on your system (Linux, macOS, or Windows Subsystem for Linux):

  • Python (version 3.9 or higher)

Once the prerequisites are met, run the following commands in your terminal to download and install the project and all its dependencies. Note the recommended
--user option: this will install in ~/.local/bin so make sure your PATH includes this directory! And notice the package is called mc-shell but the executable program is called mcshell. If you choose not to install with --user then the executable should be in your PATH automatically.

pip install --user mc-shell

Running and Updating

To run the application, use the following command

mcshell start

If the command is not found, your must add ~/.local/bin to your PATH environment variable or use the following invocation

~/.local/bin/mcshell start

Entering the Shell

Running the application will drop you into mc-shell, an enhanced IPython terminal. From here, you can manage your Minecraft worlds and the mc-ed application using special "magic commands" that start with a % symbol.


Managing Your Worlds (The "Atomic Multi-verse")

This section covers all the %pp_ commands for managing your personal Paper server instances.

Creating and Listing Worlds

To create a new, self-contained world, use the %pp_create_world command. This will create a new folder in your home directory (~/mc-worlds), download the appropriate Paper server, and set up all the necessary configuration files. The current default version (which the client must match) is 1.21.4.

%pp_create_world my_creative_build --version=1.21.4

To see a list of all the worlds you have created, use the %pp_list_worlds command.

Starting and Stopping Worlds

The main command to start a session is %pp_start_world. This launches the specified Paper server in the background and starts the mc-ed application server, which provides the Editor and Control Panel UIs.

This command ensures only one world is active at a time. If you start a new world, it will automatically stop your previous session.

%pp_start_world my_creative_build

To manually stop the current session (both the Paper server and the app server), use %pp_stop_world.

Deleting Worlds

To permanently delete a world and all its files, use the %pp_delete_world command. You will be asked for confirmation before any files are removed.

%pp_delete_world my_old_world

Joining Worlds

This section covers how to connect to a running server. The %mc_login magic configures your shell to talk to a specific server, while %mc_invite_player allows you to send your connection details to a friend so they can join you.

Exiting the Shell

When you are finished, you can exit the shell by typing exit() or pressing Ctrl+D. This will automatically trigger a clean shutdown of any running world and the application server.


Using the Tools

This section focuses on the two main graphical interfaces, which are available in your browser once a world is started.

Using the Editor

The Editor is a powerful visual environment for creating "powers." You can access it at http://localhost:5001.

The interface consists of two main panels: the Power Library on the left, which lists your saved powers, and the main Workspace on the right. The workspace contains the Blockly editor for visually composing programs and a live Python code preview that updates as you work.

To create a functional power, you must follow the "Debug-to-Define" workflow:

  1. Create a function definition block (e.g., def BuildTower(height)).
  2. Create a function call block as a "test harness" and connect blocks with the correct types to its inputs (e.g., a math_number block for height).
  3. Click the "Execute (Debug)" button. This runs the code in-game and "type-stamps" your power's parameters with the correct types.
  4. Click "Save Power As..." to save this newly defined power to your library, ready to be used by the Control Panel.

Using the Control

The Control Panel is a touch-friendly UI for executing your saved powers in-game. Access it at http://localhost:5001/control.

The interface has two modes:

  • Run Mode: The main grid displays your power "widgets." If a power has parameters, the widget will have interactive controls like sliders or pickers. Simply set the parameters and click "Execute."
  • Edit Mode: Click "Edit Layout" to customize your grid. You can open a library of all your saved powers, add them as new widgets to your grid, and drag-and-drop them to arrange your layout.

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

mc_shell-0.6.7.tar.gz (13.7 MB view details)

Uploaded Source

Built Distribution

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

mc_shell-0.6.7-py3-none-any.whl (13.9 MB view details)

Uploaded Python 3

File details

Details for the file mc_shell-0.6.7.tar.gz.

File metadata

  • Download URL: mc_shell-0.6.7.tar.gz
  • Upload date:
  • Size: 13.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mc_shell-0.6.7.tar.gz
Algorithm Hash digest
SHA256 7b34945b24570f81d78f949137ce9339b04c5ba557e039b29e16ea473f967ee6
MD5 32fa09046f080001e266f02949ab502d
BLAKE2b-256 fc167677548f7322024c02b6e9999e1d5b2b8f3170624f2dada10b853416c2c3

See more details on using hashes here.

File details

Details for the file mc_shell-0.6.7-py3-none-any.whl.

File metadata

  • Download URL: mc_shell-0.6.7-py3-none-any.whl
  • Upload date:
  • Size: 13.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mc_shell-0.6.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ae4451cc427043acda9a43a1803324bc9d10437fa15268e858f15942459621dc
MD5 5c1ced1c6b104664449f3ee2ed7d8c95
BLAKE2b-256 dc69ef52b85cfeae8865e625d736246636799c8ae22deb77ef5cb269015fa6ee

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