add new work flow1
算了,不需要 init sub modules 我的问题,没处理好依赖 some fix to make ruff happy remove ruff format
This commit is contained in:
parent
c12088697b
commit
eabcc82d0e
12
.github/workflows/dr_rs.yml
vendored
12
.github/workflows/dr_rs.yml
vendored
@ -25,7 +25,7 @@ jobs:
|
|||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
os: [macos-latest, ubuntu-latest, windows-latest]
|
os: [macos-latest, ubuntu-latest, windows-latest]
|
||||||
python-version: ["3.8", "3.10"] # 3.11 still not support by nuitka
|
python-version: ["3.8"] # 3.11 is now supported!, but just run 3.8
|
||||||
|
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
||||||
@ -35,10 +35,10 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
# check out submodule
|
# check out submodule
|
||||||
- name: init submodule
|
# - name: init submodule
|
||||||
run: |
|
# run: |
|
||||||
git submodule init
|
# git submodule init
|
||||||
git submodule update
|
# git submodule update
|
||||||
|
|
||||||
# 缓存 Rust 构建
|
# 缓存 Rust 构建
|
||||||
- name: Cache rust
|
- name: Cache rust
|
||||||
@ -70,12 +70,12 @@ jobs:
|
|||||||
cache: 'pip'
|
cache: 'pip'
|
||||||
cache-dependency-path: |
|
cache-dependency-path: |
|
||||||
**/requirement-dev.txt
|
**/requirement-dev.txt
|
||||||
.github/workflows/requirement.txt
|
|
||||||
|
|
||||||
# 安装依赖
|
# 安装依赖
|
||||||
- name: Install env
|
- name: Install env
|
||||||
run: |
|
run: |
|
||||||
pip install -r requirement-dev.txt
|
pip install -r requirement-dev.txt
|
||||||
|
pip install git+https://github.com/shenjackyuanjie/lib-not-dr.git
|
||||||
|
|
||||||
# 提取 DR 版本和其他信息
|
# 提取 DR 版本和其他信息
|
||||||
- name: Display Difficult-Rocket info
|
- name: Display Difficult-Rocket info
|
||||||
|
17
.github/workflows/nuitka.yml
vendored
17
.github/workflows/nuitka.yml
vendored
@ -39,10 +39,11 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
# 初始化子模块
|
# 初始化子模块
|
||||||
- name: Init submodules
|
# 暂时不需要 因为直接用 git install
|
||||||
run: |
|
# - name: Init submodules
|
||||||
git submodule init
|
# run: |
|
||||||
git submodule update
|
# git submodule init
|
||||||
|
# git submodule update
|
||||||
|
|
||||||
# 安装 Python
|
# 安装 Python
|
||||||
- name: Setup Python ${{ matrix.python-version }}
|
- name: Setup Python ${{ matrix.python-version }}
|
||||||
@ -53,12 +54,12 @@ jobs:
|
|||||||
cache: 'pip'
|
cache: 'pip'
|
||||||
cache-dependency-path: |
|
cache-dependency-path: |
|
||||||
**/requirement-dev.txt
|
**/requirement-dev.txt
|
||||||
.github/workflows/requirement.txt
|
|
||||||
|
|
||||||
# 安装 pyglet
|
# 安装特殊依赖
|
||||||
- name: Install pyglet
|
- name: Install git denpendencies
|
||||||
run: |
|
run: |
|
||||||
pip install git+https://github.com/shenjackyuanjie/pyglet.git
|
pip install git+https://github.com/shenjackyuanjie/pyglet.git
|
||||||
|
pip install git+https://github.com/shenjackyuanjie/lib-not-dr.git
|
||||||
|
|
||||||
# 安装依赖
|
# 安装依赖
|
||||||
- name: Install env
|
- name: Install env
|
||||||
@ -71,7 +72,7 @@ jobs:
|
|||||||
# 只在 windows 的 python 3.8 上检查 减少无用报错
|
# 只在 windows 的 python 3.8 上检查 减少无用报错
|
||||||
run: |
|
run: |
|
||||||
pip install ruff
|
pip install ruff
|
||||||
ruff check . --exit-zero --format github
|
ruff check . --exit-zero
|
||||||
|
|
||||||
# 提取 DR 版本和其他信息
|
# 提取 DR 版本和其他信息
|
||||||
- name: Display Difficult-Rocket info
|
- name: Display Difficult-Rocket info
|
||||||
|
113
.github/workflows/release.yml
vendored
Normal file
113
.github/workflows/release.yml
vendored
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
# 名称
|
||||||
|
name: Build DR release
|
||||||
|
|
||||||
|
# 运行条件
|
||||||
|
on:
|
||||||
|
# 触发条件
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
# 主任务
|
||||||
|
jobs:
|
||||||
|
build-release:
|
||||||
|
# 全都要!
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [macos-latest, ubuntu-latest, windows-latest]
|
||||||
|
python-version: ["3.8", "3.9", "3.10", "3.11"]
|
||||||
|
# 老子全都要 !
|
||||||
|
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
# Check-out repository
|
||||||
|
- name: Check out
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
# 初始化子模块
|
||||||
|
# - name: Init submodules
|
||||||
|
# run: |
|
||||||
|
# git submodule init
|
||||||
|
# git submodule update
|
||||||
|
|
||||||
|
# 缓存 Rust 构建
|
||||||
|
- name: Cache rust
|
||||||
|
uses: Swatinem/rust-cache@v2
|
||||||
|
with:
|
||||||
|
workspaces: mods/dr_game/Difficult_Rocket_rs
|
||||||
|
key: dr_release_v1
|
||||||
|
|
||||||
|
# 安装 Python
|
||||||
|
- name: Setup Python ${{ matrix.python-version }}
|
||||||
|
uses: actions/setup-python@v4
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }} # 为了支持 win7 我还是得用 3.8
|
||||||
|
architecture: 'x64' # optional x64 or x86. Defaults to x64 if not specified
|
||||||
|
cache: 'pip'
|
||||||
|
cache-dependency-path: |
|
||||||
|
**/requirement-dev.txt
|
||||||
|
|
||||||
|
# 安装特殊依赖
|
||||||
|
- name: Install git denpendencies
|
||||||
|
run: |
|
||||||
|
pip install git+https://github.com/shenjackyuanjie/pyglet.git
|
||||||
|
pip install git+https://github.com/shenjackyuanjie/lib-not-dr.git
|
||||||
|
|
||||||
|
# 安装依赖
|
||||||
|
- name: Install env
|
||||||
|
run: |
|
||||||
|
pip install -r requirement-dev.txt
|
||||||
|
|
||||||
|
# 提取 DR 版本和其他信息
|
||||||
|
- name: Display Difficult-Rocket info
|
||||||
|
id: DR_info
|
||||||
|
shell: pwsh
|
||||||
|
run: |
|
||||||
|
$infos = python .github/workflows/get_info.py -github
|
||||||
|
Write-Output $infos >> $env:GITHUB_ENV
|
||||||
|
python .github/workflows/get_info.py
|
||||||
|
|
||||||
|
# 使用新的 nuitka_build.py
|
||||||
|
- name: Build by nuitka
|
||||||
|
shell: pwsh
|
||||||
|
run: |
|
||||||
|
python nuitka_build.py --github
|
||||||
|
# 集成的构建脚本 好耶!
|
||||||
|
|
||||||
|
# 编译 dr_rs
|
||||||
|
- name: Build dr_rs
|
||||||
|
shell: pwsh
|
||||||
|
run: |
|
||||||
|
Set-Location mods/dr_game/Difficult_Rocket_rs/src
|
||||||
|
python setup.py build
|
||||||
|
python post_build.py
|
||||||
|
python setup.py clean
|
||||||
|
cd ..
|
||||||
|
Remove-Item -Recurse -Force src
|
||||||
|
|
||||||
|
# 获取短 sha
|
||||||
|
- name: Get short commit sha
|
||||||
|
id: get_short_sha
|
||||||
|
shell: pwsh
|
||||||
|
run: |
|
||||||
|
$short_sha = Write-Output $env:GITHUB_SHA
|
||||||
|
$short_sha = $short_sha.substring(1,7)
|
||||||
|
Write-Output $short_sha
|
||||||
|
Write-Output "short_sha=$short_sha" >> $env:GITHUB_ENV
|
||||||
|
|
||||||
|
# Uploads artifact
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: Difficult-Rocket_v${{env.DR_version}}-${{runner.os}}${{matrix.python-version}}.zip
|
||||||
|
path: |
|
||||||
|
build/github/DR.dist
|
||||||
|
|
||||||
|
|
||||||
|
# Uploads artifact
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: DR_rs${{env.DR_version}}-${{runner.os}}${{matrix.python-version}}-Build.${{github.run_number}}+${{env.short_sha}}
|
||||||
|
path: |
|
||||||
|
mods/dr_game
|
@ -7,11 +7,11 @@
|
|||||||
from typing import Dict, Union
|
from typing import Dict, Union
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
|
||||||
from libs.lib_not_dr.types.options import (Options,
|
from lib_not_dr.types.options import (Options,
|
||||||
OptionsError,
|
OptionsError,
|
||||||
OptionNameNotDefined,
|
OptionNameNotDefined,
|
||||||
OptionNotFound,
|
OptionNotFound,
|
||||||
get_type_hints_)
|
get_type_hints_)
|
||||||
from libs.MCDR.version import (Version,
|
from libs.MCDR.version import (Version,
|
||||||
VersionRequirement,
|
VersionRequirement,
|
||||||
VersionParsingError)
|
VersionParsingError)
|
||||||
|
@ -66,7 +66,7 @@ class SingleTextStyle:
|
|||||||
|
|
||||||
@tag.setter
|
@tag.setter
|
||||||
def tag(self, value: list):
|
def tag(self, value: list):
|
||||||
assert type(value) == list, 'SingleTextStyle.tag must be list'
|
assert isinstance(value, list), 'SingleTextStyle.tag must be list'
|
||||||
for tag in value:
|
for tag in value:
|
||||||
if tag not in self._tag:
|
if tag not in self._tag:
|
||||||
self._tag.append(tag)
|
self._tag.append(tag)
|
||||||
@ -82,7 +82,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 叠加后的字体样式
|
:return: 叠加后的字体样式
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle, f'SingleTextStyle + other\n other must be the same type, not a {type(other)}'
|
assert isinstance(other, SingleTextStyle), f'SingleTextStyle + other\n other must be the same type, not a {type(other)}'
|
||||||
return SingleTextStyle(
|
return SingleTextStyle(
|
||||||
font_name=other.font_name or self.font_name,
|
font_name=other.font_name or self.font_name,
|
||||||
font_size=other.font_size or self.font_size,
|
font_size=other.font_size or self.font_size,
|
||||||
@ -102,7 +102,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 叠加后的字体样式
|
:return: 叠加后的字体样式
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle, f'SingleTextStyle += other\n other must be the same type, not a {type(other)}'
|
assert isinstance(other, SingleTextStyle), f'SingleTextStyle += other\n other must be the same type, not a {type(other)}'
|
||||||
self.font_name = other.font_name or self.font_name
|
self.font_name = other.font_name or self.font_name
|
||||||
self.font_size = other.font_size or self.font_size
|
self.font_size = other.font_size or self.font_size
|
||||||
self.bold = other.bold or self.bold
|
self.bold = other.bold or self.bold
|
||||||
@ -125,7 +125,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 是否相同
|
:return: 是否相同
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle
|
assert isinstance(other, SingleTextStyle)
|
||||||
return other.tag in self.tag
|
return other.tag in self.tag
|
||||||
|
|
||||||
def same_font(self, other: 'SingleTextStyle') -> bool:
|
def same_font(self, other: 'SingleTextStyle') -> bool:
|
||||||
@ -134,7 +134,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 是否相同
|
:return: 是否相同
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle
|
assert isinstance(other, SingleTextStyle)
|
||||||
return (self.font_name == other.font_name and
|
return (self.font_name == other.font_name and
|
||||||
self.font_size == other.font_size and
|
self.font_size == other.font_size and
|
||||||
self.color == other.color and
|
self.color == other.color and
|
||||||
@ -146,7 +146,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 是否相同
|
:return: 是否相同
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle
|
assert isinstance(other, SingleTextStyle)
|
||||||
return self.bold == other.bold
|
return self.bold == other.bold
|
||||||
|
|
||||||
def same_italic(self, other: 'SingleTextStyle') -> bool:
|
def same_italic(self, other: 'SingleTextStyle') -> bool:
|
||||||
@ -155,7 +155,7 @@ class SingleTextStyle:
|
|||||||
:param other: 叠加的字体样式
|
:param other: 叠加的字体样式
|
||||||
:return: 是否相同
|
:return: 是否相同
|
||||||
"""
|
"""
|
||||||
assert type(other) == SingleTextStyle
|
assert isinstance(other, SingleTextStyle)
|
||||||
return self.italic == other.italic
|
return self.italic == other.italic
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
@ -125,7 +125,7 @@ class CommandLine(widgets.WidgetBase):
|
|||||||
|
|
||||||
@text.setter
|
@text.setter
|
||||||
def text(self, value):
|
def text(self, value):
|
||||||
assert type(value) is str, 'CommandLine\'s text must be string!'
|
assert isinstance(value, str), 'CommandLine\'s text must be string!'
|
||||||
self._text = value
|
self._text = value
|
||||||
self._line.text = value
|
self._line.text = value
|
||||||
|
|
||||||
@ -143,7 +143,7 @@ class CommandLine(widgets.WidgetBase):
|
|||||||
0 ~ (self.length-1) -> 切换视角到对应的行数
|
0 ~ (self.length-1) -> 切换视角到对应的行数
|
||||||
实际上还有一个限制
|
实际上还有一个限制
|
||||||
"""
|
"""
|
||||||
assert type(value) is int, 'Command View must be integer'
|
assert isinstance(value, int), 'Command View must be integer'
|
||||||
assert -self.length < value < self.length, f'Command View must be bigger than {-self.length} and smaller than {self.length}'
|
assert -self.length < value < self.length, f'Command View must be bigger than {-self.length} and smaller than {self.length}'
|
||||||
if value == -1: # flush command list
|
if value == -1: # flush command list
|
||||||
self._label.insert(0, self._label[-1])
|
self._label.insert(0, self._label[-1])
|
||||||
@ -168,7 +168,7 @@ class CommandLine(widgets.WidgetBase):
|
|||||||
|
|
||||||
@editing.setter
|
@editing.setter
|
||||||
def editing(self, value):
|
def editing(self, value):
|
||||||
assert type(value) is bool, 'Command editing must be bool!'
|
assert isinstance(value, bool), 'Command editing must be bool!'
|
||||||
self._editing = value
|
self._editing = value
|
||||||
self._line.visible = value
|
self._line.visible = value
|
||||||
self._outline.visible = value
|
self._outline.visible = value
|
||||||
|
@ -4,9 +4,8 @@
|
|||||||
# All rights reserved
|
# All rights reserved
|
||||||
# -------------------------------
|
# -------------------------------
|
||||||
|
|
||||||
from typing import Optional, Tuple
|
from typing import Tuple
|
||||||
|
|
||||||
from pyglet.shapes import Rectangle
|
|
||||||
from pyglet.graphics import Batch, Group
|
from pyglet.graphics import Batch, Group
|
||||||
|
|
||||||
from Difficult_Rocket.gui.widget.theme import BaseTheme, FontTheme
|
from Difficult_Rocket.gui.widget.theme import BaseTheme, FontTheme
|
||||||
|
@ -37,7 +37,7 @@ class TranslateConfig:
|
|||||||
|
|
||||||
def set(self, item: str, value: Union[bool, "Tr", "Translates"]) -> 'TranslateConfig':
|
def set(self, item: str, value: Union[bool, "Tr", "Translates"]) -> 'TranslateConfig':
|
||||||
assert getattr(self, item, None) is not None, f'Config {item} is not in TranslateConfig'
|
assert getattr(self, item, None) is not None, f'Config {item} is not in TranslateConfig'
|
||||||
assert type(value) is bool
|
assert isinstance(value, bool)
|
||||||
setattr(self, item, value)
|
setattr(self, item, value)
|
||||||
return self
|
return self
|
||||||
|
|
||||||
|
@ -5,8 +5,7 @@
|
|||||||
# -------------------------------
|
# -------------------------------
|
||||||
|
|
||||||
import math
|
import math
|
||||||
from typing import Dict, Union, Optional
|
from typing import Dict, Union
|
||||||
from dataclasses import dataclass
|
|
||||||
|
|
||||||
# pyglet
|
# pyglet
|
||||||
from pyglet.image import load, AbstractImage
|
from pyglet.image import load, AbstractImage
|
||||||
|
@ -40,11 +40,15 @@ build = [
|
|||||||
|
|
||||||
target-version = "py38"
|
target-version = "py38"
|
||||||
line-length = 150
|
line-length = 150
|
||||||
src = ["Difficult_Rocket", "libs/lib_not_dr", "libs/utils"]
|
src = ["Difficult_Rocket", "libs/utils"]
|
||||||
|
exclude = ['libs/pyglet',
|
||||||
|
'libs/pyperclip',
|
||||||
|
'libs/lib_not_dr',
|
||||||
|
'libs/MCDR/serializer.py',
|
||||||
|
'libs/utils/logger-old.py' # 旧版日志, 忽略他就好
|
||||||
|
]
|
||||||
|
|
||||||
exclude = ['libs/pyglet', 'libs/pyperclip', 'libs/MCDR/serializer.py']
|
[tool.lndl.nuitka]
|
||||||
|
|
||||||
[nuitka]
|
|
||||||
|
|
||||||
lto = "yes"
|
lto = "yes"
|
||||||
main = "DR.py"
|
main = "DR.py"
|
||||||
|
Loading…
Reference in New Issue
Block a user