Skip to main content

Create directory and file architecture from a tree structure text file

Project description

๐Ÿ—๏ธ mkarchi

mkarchi (make architecture) is a command-line tool that generates complete project structures from simple tree-format text files.
Define your entire project architecture โ€” folders, files, and even file contents โ€” in one readable text file, then generate it instantly with a single command.


โœจ Features

  • ๐Ÿ“ Create directories from a tree structure
  • ๐Ÿ“„ Create empty files automatically
  • โœ๏ธ Create files with content using intuitive { } syntax
  • ๐ŸŽฏ Preserve indentation (perfect for Python, YAML, JSON, etc.)
  • ๐Ÿ’ฌ Support comments in structure files
  • ๐Ÿš€ Fast & simple โ€” build your whole project in one command

๐Ÿ“ฆ Installation

โœ… Recommended (via pip)

pip install mkarchi

Option 2: Install from source

git clone https://github.com/yourusername/mkarchi.git
cd mkarchi
pip install -e .

Option 3: Run as module (no installation)

git clone https://github.com/yourusername/mkarchi.git
cd mkarchi
python -m mkarchi apply structure.txt

๐Ÿš€ Quick Start

1๏ธโƒฃ Create a structure file

Create a file called structure.txt:

my_project/
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ main.py{
โ”‚   โ”‚   def main():
โ”‚   โ”‚       print("Hello, World!")
โ”‚   โ”‚
โ”‚   โ”‚   if __name__ == "__main__":
โ”‚   โ”‚       main()
โ”‚   }
โ”‚   โ””โ”€โ”€ utils.py{
โ”‚       def helper():
โ”‚           return "Helper function"
โ”‚   }
โ”œโ”€โ”€ tests/
โ”‚   โ””โ”€โ”€ test_main.py
โ”œโ”€โ”€ README.md{
โ”‚   # My Project
โ”‚
โ”‚   This is an awesome project!
โ”‚   }
โ””โ”€โ”€ requirements.txt{
    pytest>=7.0.0
    requests>=2.28.0
}

2๏ธโƒฃ Run mkarchi

mkarchi apply structure.txt

3๏ธโƒฃ See the magic โœจ

Copy code
๐Ÿš€ Creating structure from structure.txt...

๐Ÿ“ Created directory: my_project
๐Ÿ“ Created directory: my_project/src
๐Ÿ“„ Created file with content: my_project/src/main.py
๐Ÿ“„ Created file with content: my_project/src/utils.py
๐Ÿ“ Created directory: my_project/tests
๐Ÿ“„ Created file: my_project/tests/test_main.py
๐Ÿ“„ Created file with content: my_project/README.md
๐Ÿ“„ Created file with content: my_project/requirements.txt

โœ… Architecture created successfully!

๐Ÿ“– Usage

# Generate structure
mkarchi apply structure.txt

# Help
mkarchi --help

# Version
mkarchi --version

๐Ÿ“„ Structure File Format

๐Ÿ“ Create Directories

Directories must end with /:

Copy code
my_folder/
โ”œโ”€โ”€ subfolder/
โ””โ”€โ”€ another_folder/

๐Ÿ“„ Create Empty Files

Files without { } are created empty:

my_folder/
โ”œโ”€โ”€ empty_file.txt
โ””โ”€โ”€ config.json

โœ๏ธ Create Files with Content

Use { } to define file content:

script.py{
    print("Hello!")
    print("This is Python code")
}

๐ŸŽฏ Indentation Preservation

mkarchi automatically preserves indentation:

utils.py{
    def greet(name):
        if name:
            print(f"Hello, {name}!")
        else:
            print("Hello, World!")
}

Result (utils.py):

def greet(name):
    if name:
        print(f"Hello, {name}!")
    else:
        print("Hello, World!")

๐Ÿ’ฌ Comments Support

Use # for comments in your structure file:

project/
โ”œโ”€โ”€ src/          # Source code
โ”‚   โ””โ”€โ”€ main.py   # Entry point
โ””โ”€โ”€ tests/        # Tests

๐ŸŽฏ Use Cases

โšก Quick Prototyping

๐Ÿ“ฆ Reusable project templates

๐Ÿ“˜ Documentation & tutorials

๐Ÿงฉ Microservices setup

Copy code
mkarchi apply service1.txt
mkarchi apply service2.txt

๐Ÿ”ง Advanced Example (Python Project)

python_project/
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ””โ”€โ”€ main.py{
โ”‚       """Main module."""
โ”‚
โ”‚       def main():
โ”‚           print("Starting application...")
โ”‚   }
โ”œโ”€โ”€ tests/
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ””โ”€โ”€ test_main.py{
โ”‚       import pytest
โ”‚       from src.main import main
โ”‚
โ”‚       def test_main():
โ”‚           assert main() is None
โ”‚   }
โ”œโ”€โ”€ setup.py{
โ”‚   from setuptools import setup, find_packages
โ”‚
โ”‚   setup(
โ”‚       name="my-project",
โ”‚       version="0.1.0",
โ”‚       packages=find_packages(),
โ”‚   )
โ”‚   }
โ””โ”€โ”€ README.md

๐Ÿค Contributing

Contributions are welcome! ๐Ÿš€

Fork the repository

Create a feature branch:

git checkout -b feature/amazing-feature

Commit your changes:

git commit -m "Add amazing feature"

Push to your branch:

git push origin feature/amazing-feature

Open a Pull Request

๐Ÿ“ License

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

๐Ÿ› Issues & Feedback

Found a bug or have a feature request? Please open an issue on GitHub Issues.

โญ Support the Project

If you find mkarchi useful, please consider giving it a โญ on GitHub!


โค๏ธ Made with passion by Soufyan Rachdi

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

mkarchi-0.1.3.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

mkarchi-0.1.3-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file mkarchi-0.1.3.tar.gz.

File metadata

  • Download URL: mkarchi-0.1.3.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for mkarchi-0.1.3.tar.gz
Algorithm Hash digest
SHA256 a7c0f85b4b60216fd8d63aabf4b5f965a4a9d4c9043e15bda755009dceb88680
MD5 9fa33023860a0fae7cb1aca5a7f78075
BLAKE2b-256 42e83b62ad2a76801fc9c41da88e5d8c28003f37df0b8a5a1923ba5ad1c2555d

See more details on using hashes here.

File details

Details for the file mkarchi-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: mkarchi-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for mkarchi-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f22b739b5ab19a3fd75f3660e87598beeea50ac7bca4bab749ab845f90db2521
MD5 16a9f6f7e671735c2d967a3c089508cd
BLAKE2b-256 866d76fa61cb134360807e210f951227da308e31a3b99eecbf5f3634a2ac6ccd

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