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.
- Install the Software:
pip install --user mc-shell
- Enter the Shell:
mcshell start - Create Your First World:
%pp_create_world my_first_world - Start Your World:
%pp_start_world my_first_world - Use the Editor: Open a browser and go to
http://localhost:5001. - Exit Cleanly: Type
exitor hitCtrl-Din 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.10 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.11 but you can specify any version you want with the --version option, for example 1.21.4.
%pp_create_world my_creative_build --version=1.21.4
You can apply any set of datapacks that appear in your ~/mc-worlds/datapacks-library directory. mc-shell ships with three datapacks: flat_world,void_world and a version of OneBlock by IJAMinecraft called oneblock.
To create a totally flat world, use the following command:
%pp_create_world my_flat_creative_build --datapacks=flat_world
To create a OneBlock world, use the following command. Note we overlay the void datapack to clear the world.
%pp_create_world my_OneBlock --datapacks=void_world,oneblock
You can download and apply any datapack you want by unzip it to a folder inside ~/mc-worlds/datapacks-library and then passing the name of the folder to the --datapacks option as described above.
You can also add PaperMC plugins to your ~/mc-worlds/<world_name>/plugins folder.
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:
- Create a function definition block (e.g.,
def BuildTower(height)). - Create a function call block as a "test harness" and connect blocks with the correct types to its inputs (e.g., a
math_numberblock forheight). - Click the "Execute (Debug)" button. This runs the code in-game and "type-stamps" your power's parameters with the correct types.
- 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, a long press on the widget will make interactive controls like sliders or pickers appear. Simply set the parameters and click 'Load Configuration.' Then a quick press of the widget will execute that power.
- 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mc_shell-0.8.0.tar.gz.
File metadata
- Download URL: mc_shell-0.8.0.tar.gz
- Upload date:
- Size: 13.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b6bb6199753b102cc6fd8ab8b306d5b3d07f4386e8c6d8ff3a1f33a1cfb3c29
|
|
| MD5 |
9fe74eb2cde62d2d1a8b219dcfc76176
|
|
| BLAKE2b-256 |
fef55f42cd501012283c44a877456e615c53993b060dd0e3d419b3dc4ea725ea
|
File details
Details for the file mc_shell-0.8.0-py3-none-any.whl.
File metadata
- Download URL: mc_shell-0.8.0-py3-none-any.whl
- Upload date:
- Size: 14.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
635d36fa9716e8cf06fdd77cfb47d6f333031edce27f328d359771ddfaaea999
|
|
| MD5 |
8b1337d5053a7b05c0db468c494f2635
|
|
| BLAKE2b-256 |
fa541e5141bf591ced594c20c7416e634a4e1164ae3ba23906818928ede7517a
|