Difficult-Rocket/DR-start.py

72 lines
2.0 KiB
Python
Raw Normal View History

2022-07-04 15:12:04 +08:00
# -------------------------------
# Difficult Rocket
2023-01-20 14:08:12 +08:00
# Copyright © 2020-2023 by shenjackyuanjie 3695888@qq.com
2022-07-04 15:12:04 +08:00
# All rights reserved
# -------------------------------
2023-07-11 18:34:43 +08:00
2022-11-11 09:33:34 +08:00
import os
import sys
import time
2023-07-11 18:54:26 +08:00
import traceback
import threading
2022-11-11 09:33:34 +08:00
2023-07-11 18:34:43 +08:00
from pathlib import Path
2022-11-11 09:33:34 +08:00
hi = """Difficult Rocket is writen by shenjackyuanjie
2023-01-02 19:46:25 +08:00
email: 3695888@qq.com or shyj3695888@163.com
2022-11-11 09:33:34 +08:00
QQ: 3695888"""
def print_path() -> None:
print(f'{__file__=}')
print(f'{sys.path=}')
print(f'{sys.path[0]=}')
print(f'{sys.argv[0]=}')
2023-07-11 18:34:43 +08:00
print(f'{Path.cwd()=}')
print(f'{Path(__file__).absolute()=}')
def modify_path() -> None:
2023-07-11 18:34:43 +08:00
os.chdir(Path(__file__)) # 将运行路径切换到文件位置 防止bug
sys.path.append(f'./Difficult_Rocket') # 添加local path
sys.path.append(f'./libs') # 添加 libs path
def start(start_time_ns: int) -> None:
2023-07-11 18:54:26 +08:00
from Difficult_Rocket import crash, DR_status
2023-07-11 18:34:43 +08:00
from Difficult_Rocket.runtime import DR_runtime
2023-07-11 18:54:26 +08:00
from Difficult_Rocket.exception import TestError
2023-07-11 18:34:43 +08:00
DR_runtime.start_time_ns = start_time_ns
try:
2023-07-11 18:54:26 +08:00
from Difficult_Rocket import main
2023-07-11 18:34:43 +08:00
main_game = main.Game()
2023-07-11 18:54:26 +08:00
main_game.start()
if DR_status.crash_report_test:
raise TestError('debug crash test')
except:
trace = traceback.format_exc()
crash.create_crash_report(trace)
crash.write_info_to_cache(sys.stdout)
print(crash.all_thread)
print(crash.all_process)
for a_thread in threading.enumerate():
print(a_thread)
if a_thread.is_alive() and a_thread != threading.current_thread() and a_thread != threading.main_thread():
a_thread.join(2) # wait for 2 sec
import pyglet
pyglet.app.exit() # make sure that pyglet has stopped
2023-07-11 18:54:26 +08:00
def main() -> int:
2023-07-11 18:34:43 +08:00
print(hi, f"\n{time.ctime()}") # hi
2022-11-11 09:33:34 +08:00
# 记录启动信息
start_time_ns = time.time_ns()
print_path()
modify_path()
2023-07-11 18:34:43 +08:00
start(start_time_ns)
2023-07-11 18:54:26 +08:00
return 0
2023-07-11 18:34:43 +08:00
2023-07-11 18:54:26 +08:00
if __name__ == '__main__':
sys.exit(main())