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.4.tar.gz (2.4 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.4-py3-none-any.whl (2.5 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mc_shell-0.6.4.tar.gz
  • Upload date:
  • Size: 2.4 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.4.tar.gz
Algorithm Hash digest
SHA256 0c468b526a1051c0f22768f1ed9278a72a4f15ee6cc625018eb6ac82dd258476
MD5 02dcc6d90122fe5eb4dd08eaad118a58
BLAKE2b-256 448265bb22678609c709243cd4b38ec8119a099f91fe4bcb276f3eb10eed2b28

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mc_shell-0.6.4-py3-none-any.whl
  • Upload date:
  • Size: 2.5 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7436936c05a104b3f8e35ed00f27e1ef5073bf3d681211e2575df5e29f2f7214
MD5 3ccdfa42020b96def0a23e71a5ae4f4c
BLAKE2b-256 3e4262b92d848b5ef6669ce6b07b077ffc20890c5552a9c05f262489f3b7c557

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