From aa7d359cf62dbc6ffd17815ec72eea564c2495ce Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?=E6=B2=88=E7=91=97=E6=9D=B0?= <3695888@qq.com>
Date: Mon, 23 Jan 2023 13:54:05 +0800
Subject: [PATCH] gogogo
anti 996!
---
Difficult_Rocket/api/types/__init__.py | 25 ++++++++++++++++---
Difficult_Rocket/client/__init__.py | 18 +++++++++++++-
Difficult_Rocket/client/render/sr1_ship.py | 6 +++++
README.md | 1 +
docs/README-en.md | 1 +
libs/MCDR/version.py | 11 +++++++++
requirement-build.txt | 26 ++++++++++----------
requirement-dev.txt | 28 +++++++++++-----------
requirement.txt | 14 +++++------
9 files changed, 92 insertions(+), 38 deletions(-)
diff --git a/Difficult_Rocket/api/types/__init__.py b/Difficult_Rocket/api/types/__init__.py
index 350eb55..4d137eb 100644
--- a/Difficult_Rocket/api/types/__init__.py
+++ b/Difficult_Rocket/api/types/__init__.py
@@ -11,8 +11,9 @@ github: @shenjackyuanjie
gitee: @shenjackyuanjie
"""
+import traceback
from dataclasses import dataclass
-from typing import get_type_hints, Type, List, Union, Dict, Any, Callable, Tuple, Optional
+from typing import get_type_hints, Type, List, Union, Dict, Any, Callable, Tuple, Optional, TYPE_CHECKING
# from Difficult Rocket
@@ -67,10 +68,23 @@ class Options:
setattr(self, option, value)
if hasattr(self, 'init'):
self.init(**kwargs)
+ if hasattr(self, 'load_file'):
+ try:
+ self.load_file()
+ except:
+ traceback.print_exc()
self.flush_option()
- def init(self, **kwargs) -> None:
- ...
+ if TYPE_CHECKING:
+ def init(self, **kwargs) -> None:
+ """ 如果子类定义了这个函数,则会在 __init__ 之后调用这个函数 """
+
+ def load_file(self) -> bool:
+ """
+ 如果子类定义了这个函数,则会在 __init__ 和 init 之后再调用这个函数
+
+ 请注意,这个函数请尽量使用 try 包裹住可能出现错误的部分
+ 否则会在控制台输出你的报错"""
def option(self) -> Dict[str, Any]:
"""
@@ -98,6 +112,11 @@ class Options:
raise OptionNotFound(f'Option {option} is not found in {self.name}') from None
return values
+ def format(self, text: str) -> str:
+ cache_option = self.flush_option()
+ for option in cache_option:
+ text.replace(f'\{{option}\}')
+
def flush_option(self) -> Dict[str, Any]:
"""
刷新缓存 options 的内容
diff --git a/Difficult_Rocket/client/__init__.py b/Difficult_Rocket/client/__init__.py
index ab694ac..78be364 100644
--- a/Difficult_Rocket/client/__init__.py
+++ b/Difficult_Rocket/client/__init__.py
@@ -25,12 +25,13 @@ from decimal import Decimal
import rtoml
import pyglet
# from pyglet import gl
-from pyglet.gl import glClearColor
+# from pyglet.gl import glClearColor
# from pyglet.libs.win32 import _user32
from pyglet.window import Window
from pyglet.window import key, mouse
# Difficult_Rocket function
+from Difficult_Rocket.api.types import Options
from Difficult_Rocket.command import line, tree
from Difficult_Rocket.utils.translate import tr
from Difficult_Rocket import DR_runtime, DR_option
@@ -43,6 +44,21 @@ from Difficult_Rocket.client.render.sr1_ship import SR1ShipRender
from Difficult_Rocket.client.screen import BaseScreen, DRScreen, DRDEBUGScreen
+class ClientOption(Options):
+ fps: int = 60
+ width: int = 1024
+ height: int = 768
+ file_drop: bool = True
+ fullscreen: bool = False
+ resizeable: bool = True
+ visible: bool = True
+ gui_scale: float = 1.0
+ caption: str = "Difficult Rocket {version}"
+
+ def load_file(self) -> None:
+ ...
+
+
class Client:
def __init__(self, net_mode='local'):
start_time = time.time_ns()
diff --git a/Difficult_Rocket/client/render/sr1_ship.py b/Difficult_Rocket/client/render/sr1_ship.py
index 6af123c..d55175d 100644
--- a/Difficult_Rocket/client/render/sr1_ship.py
+++ b/Difficult_Rocket/client/render/sr1_ship.py
@@ -260,3 +260,9 @@ class SR1ShipRender(BaseScreen):
break
self.render_ship()
print(paths)
+
+
+if __name__ == '__main__':
+ from objprint import op
+
+ op(SR1ShipRender_Option)
diff --git a/README.md b/README.md
index 3e141dd..c0d4353 100644
--- a/README.md
+++ b/README.md
@@ -9,6 +9,7 @@
- [discord](https://discord.gg/kWzw2JrG6M)
- [kook](https://kook.top/sRPjFG)
+
[![Generic badge](https://img.shields.io/badge/SemVer-2.0.0-blue.svg)](https://Semver.org/)
[![Generic badge](https://img.shields.io/badge/编写于_Python_版本-3.8.10-blue.svg)](https://Python.org)
[![Generic badge](https://img.shields.io/badge/编写于_Pyglet_版本-2.0.2.1-blue.svg)](https://pyglet.org)
diff --git a/docs/README-en.md b/docs/README-en.md
index 37788be..8c99a52 100644
--- a/docs/README-en.md
+++ b/docs/README-en.md
@@ -9,6 +9,7 @@
- [discord](https://discord.gg/kWzw2JrG6M)
- [kook](https://kook.top/sRPjFG)
+
[![Generic badge](https://img.shields.io/badge/SemVer-2.0.0-blue.svg)](https://Semver.org/)
[![Generic badge](https://img.shields.io/badge/Write_with_Python-3.8.10-blue.svg)](https://Python.org)
[![Generic badge](https://img.shields.io/badge/Write_with_Pyglet-2.0.2.1-blue.svg)](https://pyglet.org)
diff --git a/libs/MCDR/version.py b/libs/MCDR/version.py
index e7c4982..56e1cb9 100644
--- a/libs/MCDR/version.py
+++ b/libs/MCDR/version.py
@@ -197,3 +197,14 @@ class VersionRequirement:
class VersionParsingError(ValueError):
pass
+
+
+if __name__ == '__main__':
+ from objprint import op
+ test_list = ['1.1.1',
+ '1.0',
+ '1.11.1.11.1']
+
+ for a_test in test_list:
+ version_a = Version(a_test)
+ op(version_a)
diff --git a/requirement-build.txt b/requirement-build.txt
index 79943d9..892d1eb 100644
--- a/requirement-build.txt
+++ b/requirement-build.txt
@@ -3,26 +3,26 @@
# DR build (by nuitka)
# for phy simulation
-pymunk
+pymunk >= 6.4.0
# for images
-pillow
+pillow >= 9.4.0
# for sys info
-psutil
+psutil >= 5.9.4
# for files
-rtoml
-tomlkit
-defusedxml
+rtoml >= 0.9.0
+tomlkit >= 0.11.6
+defusedxml >= 0.7.1
# for report error
-objprint
+objprint >= 0.2.2
# for compile
-nuitka
-ordered-set
-imageio
-setuptools
-wheel
-setuptools-rust
+nuitka >= 1.3.8
+ordered-set >= 4.1.0
+imageio >= 2.25.0
+wheel >= 0.38.4
+setuptools >= 66.1.1
+setuptools-rust >= 1.5.2
diff --git a/requirement-dev.txt b/requirement-dev.txt
index f71a706..b050660 100644
--- a/requirement-dev.txt
+++ b/requirement-dev.txt
@@ -4,27 +4,27 @@
# DR contributing
# for phy simulation
-pymunk
+pymunk >= 6.4.0
# for images
-pillow
+pillow >= 9.4.0
# for sys info
-psutil
+psutil >= 5.9.4
# for files
-rtoml
-tomlkit
-defusedxml
+rtoml >= 0.9.0
+tomlkit >= 0.11.6
+defusedxml >= 0.7.1
# for debug
-objprint
-viztracer
+objprint >= 0.2.2
+viztracer >= 0.15.6
# for compile
-nuitka
-ordered-set
-imageio
-wheel
-setuptools
-setuptools-rust
+nuitka >= 1.3.8
+ordered-set >= 4.1.0
+imageio >= 2.25.0
+wheel >= 0.38.4
+setuptools >= 66.1.1
+setuptools-rust >= 1.5.2
diff --git a/requirement.txt b/requirement.txt
index aa4f7c1..708172c 100644
--- a/requirement.txt
+++ b/requirement.txt
@@ -2,18 +2,18 @@
# DR basic running from source
# for phy simulation
-pymunk
+pymunk >= 6.4.0
# for images
-pillow
+pillow >= 9.4.0
# for sys info
-psutil
+psutil >= 5.9.4
# for files
-rtoml
-tomlkit
-defusedxml
+rtoml >= 0.9.0
+tomlkit >= 0.11.6
+defusedxml >= 0.7.1
# for report error
-objprint
\ No newline at end of file
+objprint >= 0.2.2