Skip to main content

The GMDM CLI tool for managing dependencies of GameMaker projects and files.

Project description

GmDm

A GameMaker Dependency Management system

Installation

To install this project as a global Python package, you need to have Python installed on your system. Then, follow these steps:

  1. Install the package using pip install gmdm

Otherwise, you can create a virtual environment By following these steps:

  1. Create a virtual environment using python -m venv venv
  2. Activate the virtual environment using source venv/bin/activate (Linux/Mac) or venv\Scripts\activate (Windows)
  3. Install the package using pip install gmdm

In the second way, you will have to activate the virtual environment every time you want to use gmdm

Usage

Now that you have installed this package, you will have to set up the projects that do the imports (current project) to work with it.

For any GameMaker project to be compatible with GmDm, you don't have to create a gmdm.yml file inside each GameMaker project's folder. This file is optional. It defines the yyp file name, optionally imports and exports, if any, of your GameMaker project(s).

It simply tells GmDm that this project imports a GameMaker "Folder" or Group of resources from other projects. These other projects should be GmDm compatible.

Projects to be imported are looked up in multiple directories:

  1. ${GMDM_IMPORT_DIRS} env variable. Which is string of paths delimited by ;
  2. Absolute path.
  3. relative to current directory.
  4. ~/Documents/GameMakerStudio2/Projects.

Basic Usage

To make your project GmDm compatible at least it should have this content at minimum:

File: C:/path/to/My Project/My Project.yyp
File: C:/path/to/My Project/gmdm.yml
name: My Project.yyp

Another example where you define a project that is to be a dependency for other projects:

name: Core.yyp
exports:
  - Sprites/My Group
  - Objects/My Group
  - Scripts/My Group

Now to import the project's exports:

name: Second Project.yyp
imports:
    - path/to/core

Basically the same as:

name: Second Project.yyp
imports:
    - path/to/core:
      - Sprites/My Group
      - Objects/My Group
      - Scripts/My Group

For advance usage, you can see the file gmdm.yml.EXAMPLE.

Now you can use gmdm sync, or any of these commands when inside your project directory:

gmdm sync --fake    # displays operations without actually performing any. Useful for visualization of what will happen.
gmdm sync           # performs reimporting (newely modified assets from the imported projects)

To show the help, you can use the following command:

gmdm --help

Advanced Usage

Consider using to in order to have the same path from multiple projects.

name: Project1.yyp
imports:
  - path/to/project2:
    - My Main Folder/My Folder:
      to: Extensions/My Project 2 Folder
  - ../project3:
    - My Main Folder/My Different Folder:
      to: Extensions/My Project 3 Folder
  - !ENV '${MY_DIR}/project5'

  - AWellKnownProject

Notes

Do:

  • Keep things simple.
  • Use this for your own local machine package management.
  • Know what you are importing.

Do not:

  • Do not import the same assets or folders that have the same assets from multiple projects.
  • Do not import the same folder path from multiple projects. Use to in this case.

Other:

  • Zombie files are kept.
  • GmDm is intelligent enough to handle renamed imports when syncing.
  • If a project does not have specific exports, it is thoroughly imported.
  • If a project does not have a gmdm.yml file, it will still be able to be a dependency.
  • For best usage, clone the repos of projects, that you want as dependencies, to a specific directory. Then use gmdm to import them. It is best to set up an environment variable GMDM_IMPORT_DIRS=/d/Projects/;/e/GameMaker/

Contributing

This project is open for contributions. If you want to contribute, please follow these steps:

  1. Fork this repository and create a new branch
  2. Make your changes and commit them with a descriptive message
  3. Push your branch to your forked repository
  4. Create a pull request and explain your changes

License

This project is licensed under the MIT License. See the LICENSE file for more details.

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

gmdm-0.2.8.tar.gz (14.6 kB view details)

Uploaded Source

Built Distribution

gmdm-0.2.8-py3-none-any.whl (15.1 kB view details)

Uploaded Python 3

File details

Details for the file gmdm-0.2.8.tar.gz.

File metadata

  • Download URL: gmdm-0.2.8.tar.gz
  • Upload date:
  • Size: 14.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for gmdm-0.2.8.tar.gz
Algorithm Hash digest
SHA256 fa22e04a4d37c6570dfb51d07d7bc359b8a2bbe8fc486b6190c1135e1ef684bb
MD5 359a3f2e931488c236025c1936d600a7
BLAKE2b-256 d49755f0f95ce990b7d1773c0b8f549b76628c7056b9fdebb0bdeda01681d93f

See more details on using hashes here.

File details

Details for the file gmdm-0.2.8-py3-none-any.whl.

File metadata

  • Download URL: gmdm-0.2.8-py3-none-any.whl
  • Upload date:
  • Size: 15.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for gmdm-0.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 bb5e6794c19cd21d463284170f31532d21723d8e384168956a11677d5ee559cd
MD5 daab2ef7059fe602c4279a71eed83112
BLAKE2b-256 9e3b847b3cea1f9bc2ca794a8c0ec990feec86767ac3ecd32b258a52b926986c

See more details on using hashes here.

Supported by

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