Skip to content

MobileSuit provides an easy way to build Console App quickly. For python.

License

Notifications You must be signed in to change notification settings

HIT-ReFreSH/PyMobileSuit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ReFreSH.(Py)MobileSuit

PyPI GitHub GitHub last commit GitHub Workflow Status PyPI - Format PyPI - Wheel PyPI - Implementation GitHub repo size GitHub code size

View at PyPI

MobileSuit provides an easy way to build Console App quickly. For python.

This is the python version of ReFreSH.MobileSuit (For .NET).

Setup

pip install PyMobileSuit

Usage

There is a quite simple example:

# [Import and Configure]
from ReFreSH.MobileSuit import *

SuitConfig.LOCALE = 'en'  # 'zh' or 'en' (default if not set)


# [Write Application Class]
class Hello(object):
    def __init__(self):
        pass

    @SuitInfo("hello")
    def instance_func(self):
        print("this is instance function")

    @SuitInfo("async")
    @SuitAlias("async")
    async def async_func(self):
        print("this is async func")

    @SuitInfo("helo <name>")
    @SuitAlias("helo")
    def func_with_arg(self, name: str):
        print(f"this is async func {name}")

    @SuitInfo("helos <names>[]")
    @SuitAlias("helos")
    def func_with_list_arg(self, names: list[str]):
        print(f"this is async func {','.join(names)}")

    @SuitIgnore
    def ignored_func(self):
        print("this is func1")


# [Quick Start App]
Suit.QuickStart4BitPowerLine(Hello)
# Suit.QuickStart
# Suit.QuickStartPowerLine

# > type `help` after the prompt.

And this is the result:

Import and Configure

from ReFreSH.MobileSuit import * is ALL YOU NEED normally.

There are two configurations for PyMobileSuit:

  • LOCALE: en or zh to set language.
  • THROW: To determine whether Exceptions caught from Application methods should be thrown. To debug your application, you may need to set THROW=Ture

Write Application Class

Free to create your application class, write normal or asynchronous methods with or without parameters. Three basic decorators are available for your application methods:

  • @SuitInfo(expr: str, resourceType=None): expr is the description of the command shown in helpcommand's output by default. If you also set resourceType, getattr(resourceType,expr) will be the description.
  • @SuitAlias(alias: str): Add aliases to the command besides the method name
  • @SuitIgnore: Suppose the method is not a command.

Quick Start App

Use Suit.<QuickStartMethod>(<Your Class>) to quickly start the application. There are three built-in QuickStartMethod implementations:

  • Suit.QuickStart: Plain-text IO without powerline.
  • Suit.QuickStartPowerLine: True color Powerline supported IO.
  • Suit.QuickStart4BitPowerLine: ConsoleColor Powerline supported IO.

Normally, you should use Suit.QuickStart or Suit.QuickStart4BitPowerLine.

Notice

Although MobileSuit is easy to use, its features are very comprehensive, so I haven't had the time to write complete documentation.

The current version of PyMobileSuit is migrated from C# using ChatGPT and manual rather than rewritten so that it might be buggy.

About

MobileSuit provides an easy way to build Console App quickly. For python.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages