feat: 增加构建脚本
This commit is contained in:
32
build.bat
Normal file
32
build.bat
Normal file
@@ -0,0 +1,32 @@
|
||||
@echo off
|
||||
set PYTHONWARNINGS=ignore::SyntaxWarning:DrissionPage
|
||||
echo Building Cursor Keep Alive...
|
||||
|
||||
:: Check if virtual environment exists
|
||||
if not exist "venv" (
|
||||
python -m venv venv
|
||||
if errorlevel 1 (
|
||||
echo Failed to create virtual environment!
|
||||
exit /b 1
|
||||
)
|
||||
)
|
||||
|
||||
:: Activate virtual environment and wait for activation to complete
|
||||
call venv\Scripts\activate.bat
|
||||
timeout /t 2 /nobreak > nul
|
||||
|
||||
:: Install dependencies
|
||||
echo Installing dependencies...
|
||||
python -m pip install --upgrade pip
|
||||
pip install -r requirements.txt
|
||||
|
||||
:: Run build script
|
||||
echo Starting build process...
|
||||
python build.py
|
||||
|
||||
:: Deactivate virtual environment
|
||||
deactivate
|
||||
|
||||
:: Keep window open
|
||||
echo Build completed!
|
||||
pause
|
||||
33
build.mac.command
Normal file
33
build.mac.command
Normal file
@@ -0,0 +1,33 @@
|
||||
#!/bin/bash
|
||||
export PYTHONWARNINGS=ignore::SyntaxWarning:DrissionPage
|
||||
|
||||
# Get script directory
|
||||
cd "$(dirname "$0")"
|
||||
|
||||
echo "Creating virtual environment..."
|
||||
|
||||
# Check if virtual environment exists
|
||||
if [ ! -d "venv" ]; then
|
||||
python3 -m venv venv
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Failed to create virtual environment!"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Activate virtual environment
|
||||
source venv/bin/activate
|
||||
|
||||
# Install dependencies
|
||||
echo "Installing dependencies..."
|
||||
python -m pip install --upgrade pip
|
||||
pip install -r requirements.txt
|
||||
|
||||
# Run build script
|
||||
echo "Starting build process..."
|
||||
python build.py
|
||||
|
||||
# Keep window open
|
||||
echo "Build completed!"
|
||||
echo "Press any key to exit..."
|
||||
read -n 1
|
||||
154
build.py
Normal file
154
build.py
Normal file
@@ -0,0 +1,154 @@
|
||||
import warnings
|
||||
import os
|
||||
import platform
|
||||
import subprocess
|
||||
import sys
|
||||
import time
|
||||
import threading
|
||||
|
||||
# Ignore specific SyntaxWarning
|
||||
warnings.filterwarnings("ignore", category=SyntaxWarning, module="DrissionPage")
|
||||
|
||||
CURSOR_LOGO = """
|
||||
██████╗██╗ ██╗██████╗ ███████╗ ██████╗ ██████╗
|
||||
██╔════╝██║ ██║██╔══██╗██╔════╝██╔═══██╗██╔══██╗
|
||||
██║ ██║ ██║██████╔╝███████╗██║ ██║██████╔╝
|
||||
██║ ██║ ██║██╔══██╗╚════██║██║ ██║██╔══██╗
|
||||
╚██████╗╚██████╔╝██║ ██║███████║╚██████╔╝██║ ██║
|
||||
╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝ ╚═════╝ ╚═╝ ╚═╝
|
||||
"""
|
||||
|
||||
class LoadingAnimation:
|
||||
def __init__(self):
|
||||
self.is_running = False
|
||||
self.animation_thread = None
|
||||
|
||||
def start(self, message="Building"):
|
||||
self.is_running = True
|
||||
self.animation_thread = threading.Thread(target=self._animate, args=(message,))
|
||||
self.animation_thread.start()
|
||||
|
||||
def stop(self):
|
||||
self.is_running = False
|
||||
if self.animation_thread:
|
||||
self.animation_thread.join()
|
||||
print("\r" + " " * 70 + "\r", end="", flush=True) # Clear the line
|
||||
|
||||
def _animate(self, message):
|
||||
animation = "|/-\\"
|
||||
idx = 0
|
||||
while self.is_running:
|
||||
print(f"\r{message} {animation[idx % len(animation)]}", end="", flush=True)
|
||||
idx += 1
|
||||
time.sleep(0.1)
|
||||
|
||||
def print_logo():
|
||||
print("\033[96m" + CURSOR_LOGO + "\033[0m")
|
||||
print("\033[93m" + "Building Cursor Keep Alive...".center(56) + "\033[0m\n")
|
||||
|
||||
def progress_bar(progress, total, prefix='', length=50):
|
||||
filled = int(length * progress // total)
|
||||
bar = '█' * filled + '░' * (length - filled)
|
||||
percent = f"{100 * progress / total:.1f}"
|
||||
print(f'\r{prefix} |{bar}| {percent}% Complete', end='', flush=True)
|
||||
if progress == total:
|
||||
print()
|
||||
|
||||
def simulate_progress(message, duration=1.0, steps=20):
|
||||
print(f"\033[94m{message}\033[0m")
|
||||
for i in range(steps + 1):
|
||||
time.sleep(duration / steps)
|
||||
progress_bar(i, steps, prefix='Progress:', length=40)
|
||||
|
||||
def filter_output(output):
|
||||
"""ImportantMessage"""
|
||||
if not output:
|
||||
return ""
|
||||
important_lines = []
|
||||
for line in output.split('\n'):
|
||||
# Only keep lines containing specific keywords
|
||||
if any(keyword in line.lower() for keyword in ['error:', 'failed:', 'completed', 'directory:']):
|
||||
important_lines.append(line)
|
||||
return '\n'.join(important_lines)
|
||||
|
||||
def build():
|
||||
# Clear screen
|
||||
os.system('cls' if platform.system().lower() == "windows" else 'clear')
|
||||
|
||||
# Print logo
|
||||
print_logo()
|
||||
|
||||
system = platform.system().lower()
|
||||
spec_file = os.path.join("CursorKeepAlive.spec")
|
||||
|
||||
if system not in ["darwin", "windows"]:
|
||||
print(f"\033[91mUnsupported operating system: {system}\033[0m")
|
||||
return
|
||||
|
||||
output_dir = f"dist/{system if system != 'darwin' else 'mac'}"
|
||||
|
||||
# Create output directory
|
||||
os.makedirs(output_dir, exist_ok=True)
|
||||
simulate_progress("Creating output directory...", 0.5)
|
||||
|
||||
# Run PyInstaller with loading animation
|
||||
pyinstaller_command = [
|
||||
"pyinstaller",
|
||||
spec_file,
|
||||
"--distpath",
|
||||
output_dir,
|
||||
"--workpath",
|
||||
f"build/{system}",
|
||||
"--noconfirm"
|
||||
]
|
||||
|
||||
loading = LoadingAnimation()
|
||||
try:
|
||||
simulate_progress("Running PyInstaller...", 2.0)
|
||||
loading.start("Building in progress")
|
||||
result = subprocess.run(
|
||||
pyinstaller_command,
|
||||
check=True,
|
||||
capture_output=True,
|
||||
text=True
|
||||
)
|
||||
loading.stop()
|
||||
|
||||
if result.stderr:
|
||||
filtered_errors = [line for line in result.stderr.split('\n')
|
||||
if any(keyword in line.lower()
|
||||
for keyword in ['error:', 'failed:', 'completed', 'directory:'])]
|
||||
if filtered_errors:
|
||||
print("\033[93mBuild Warnings/Errors:\033[0m")
|
||||
print('\n'.join(filtered_errors))
|
||||
|
||||
except subprocess.CalledProcessError as e:
|
||||
loading.stop()
|
||||
print(f"\033[91mBuild failed with error code {e.returncode}\033[0m")
|
||||
if e.stderr:
|
||||
print("\033[91mError Details:\033[0m")
|
||||
print(e.stderr)
|
||||
return
|
||||
except FileNotFoundError:
|
||||
loading.stop()
|
||||
print("\033[91mError: Please ensure PyInstaller is installed (pip install pyinstaller)\033[0m")
|
||||
return
|
||||
except KeyboardInterrupt:
|
||||
loading.stop()
|
||||
print("\n\033[91mBuild cancelled by user\033[0m")
|
||||
return
|
||||
finally:
|
||||
loading.stop()
|
||||
|
||||
# Copy config file
|
||||
if os.path.exists("config.ini.example"):
|
||||
simulate_progress("Copying configuration file...", 0.5)
|
||||
if system == "windows":
|
||||
subprocess.run(["copy", "config.ini.example", f"{output_dir}\\config.ini"], shell=True)
|
||||
else:
|
||||
subprocess.run(["cp", "config.ini.example", f"{output_dir}/config.ini"])
|
||||
|
||||
print(f"\n\033[92mBuild completed successfully! Output directory: {output_dir}\033[0m")
|
||||
|
||||
if __name__ == "__main__":
|
||||
build()
|
||||
28
build.sh
Normal file
28
build.sh
Normal file
@@ -0,0 +1,28 @@
|
||||
#!/bin/bash
|
||||
export PYTHONWARNINGS=ignore::SyntaxWarning:DrissionPage
|
||||
|
||||
echo "Creating virtual environment..."
|
||||
|
||||
# Check if virtual environment exists
|
||||
if [ ! -d "venv" ]; then
|
||||
python3 -m venv venv
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Failed to create virtual environment!"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Activate virtual environment
|
||||
source venv/bin/activate
|
||||
|
||||
# Install dependencies
|
||||
echo "Installing dependencies..."
|
||||
python -m pip install --upgrade pip
|
||||
pip install -r requirements.txt
|
||||
|
||||
# Run build script
|
||||
echo "Starting build process..."
|
||||
python build.py
|
||||
|
||||
# Complete
|
||||
echo "Build completed!"
|
||||
Reference in New Issue
Block a user