Some checks failed
CI / test (push) Has been cancelled
핵심 기능: - 단축근무·표준·반일 등 다양한 근무 패턴 (5개 프리셋 + 사용자 정의) - Windows 이벤트 뷰어 자동 출퇴근 감지 - 30분 단위 연장근무 적립/사용 시스템 - 1.0/0.5/0.25일 연차·반차·반반차 - 자동 점심·저녁·외출·자동 백업·화면 잠금 자동 외출 - 한국 공휴일 자동 등록 (음력 포함, holidays 패키지) - matplotlib 차트 기반 주간/월간/패턴 통계 - 미니 위젯 + 시스템 트레이 통합 - 한국어/English i18n - 자가 업데이트 (updater.exe + Gitea Releases) 아키텍처: - core/ (db, time_calculator, notifier, i18n, version, settings_keys) - ui/ (main_window + 9 dialogs + 3 controllers) - utils/ (backup, lock_detector, debug_log, updater_client, time_format) - tests/ (66 pytest 단위) + 통합/i18n GUI 검증 CI/CD: - .gitea/workflows/ci.yml: push 시 pytest + 통합 테스트 - .gitea/workflows/release.yml: v* 태그 push 시 두 .exe 자동 빌드 + Releases 첨부 Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
34 lines
1.0 KiB
Python
34 lines
1.0 KiB
Python
"""
|
|
환경변수 게이트 디버그 로깅.
|
|
|
|
`CLOCKOUT_DEBUG=1` 환경변수가 설정된 경우에만 stderr/파일로 출력.
|
|
프로덕션 빌드(PyInstaller)에서 항상 켜두지 않도록 게이트 처리.
|
|
"""
|
|
import os
|
|
import sys
|
|
from datetime import datetime
|
|
from pathlib import Path
|
|
|
|
_DEBUG_ENV = os.environ.get('CLOCKOUT_DEBUG', '').strip() in ('1', 'true', 'yes')
|
|
_LOG_DIR = Path(os.environ.get('CLOCKOUT_DEBUG_DIR') or Path.home() / '.clockout_logs')
|
|
_LOG_FILE = _LOG_DIR / 'debug.log'
|
|
|
|
|
|
def is_debug() -> bool:
|
|
return _DEBUG_ENV
|
|
|
|
|
|
def dlog(*args, file: str = None) -> None:
|
|
"""디버그 모드에서만 stderr + 파일로 기록. 비활성화 시 no-op."""
|
|
if not _DEBUG_ENV:
|
|
return
|
|
msg = f"[{datetime.now().strftime('%H:%M:%S')}] " + ' '.join(str(a) for a in args)
|
|
print(msg, file=sys.stderr)
|
|
try:
|
|
target = Path(file) if file else _LOG_FILE
|
|
target.parent.mkdir(parents=True, exist_ok=True)
|
|
with open(target, 'a', encoding='utf-8') as f:
|
|
f.write(msg + '\n')
|
|
except OSError:
|
|
pass
|