[DEBUG] Triggering hook for import test

This commit is contained in:
2026-01-27 10:12:49 +00:00
parent d418f48481
commit 8c281551c8

View File

@@ -1,32 +1,21 @@
#!/usr/bin/env python3
import os
import sys
import json
import subprocess
import os
from datetime import datetime # datetime kann direkt importiert werden
from datetime import datetime
# Ermittle das Git-Projekt-Root-Verzeichnis
try:
PROJECT_ROOT = subprocess.check_output(["git", "rev-parse", "--show-toplevel"]).decode("utf-8").strip()
# Stelle sicher, dass PROJECT_ROOT am Anfang von sys.path steht
if PROJECT_ROOT not in sys.path:
sys.path.insert(0, PROJECT_ROOT)
# DEBUG prints
print(f"DEBUG: PROJECT_ROOT = {PROJECT_ROOT}", file=sys.stderr)
print(f"DEBUG: sys.path = {sys.path}", file=sys.stderr)
except subprocess.CalledProcessError:
print("Fehler: Nicht in einem Git-Repository. Kann notion_commit_hook nicht ausführen.", file=sys.stderr)
sys.exit(1)
# Fügen Sie das Projekt-Stammverzeichnis zum Python-Pfad hinzu
# Das ist das Verzeichnis, in dem sich das Hook-Skript befindet
sys.path.append(os.path.dirname(os.path.abspath(__file__)))
try:
import dev_session
# Greife auf Funktionen über dev_session.function_name zu
append_blocks_to_notion_page = dev_session.append_blocks_to_notion_page
decimal_hours_to_hhmm = dev_session.decimal_hours_to_hhmm
except ImportError as e:
print(f"Fehler: Konnte dev_session.py nicht importieren. Stelle sicher, dass dev_session.py im Projekt-Root liegt. Details: {e}", file=sys.stderr)
from dev_session import append_blocks_to_notion_page, decimal_hours_to_hhmm
except ImportError:
print("Fehler: Konnte dev_session.py nicht importieren.", file=sys.stderr)
sys.exit(1)
SESSION_DIR = os.path.join(PROJECT_ROOT, ".dev_session")
SESSION_DIR = ".dev_session"
SESSION_FILE_PATH = os.path.join(SESSION_DIR, "SESSION_INFO")
def get_last_commit_message() -> str:
@@ -42,9 +31,18 @@ def get_last_commit_message() -> str:
except (subprocess.CalledProcessError, FileNotFoundError):
return ""
def is_merge_commit() -> bool:
"""Prüft, ob der letzte Commit ein Merge-Commit ist."""
try:
result = subprocess.run(["git", "rev-parse", "--quiet", "--verify", "MERGE_HEAD"], capture_output=True, check=False)
return result.returncode == 0
except Exception:
return False
def main():
"""Hauptfunktion des Git-Hooks."""
if not os.path.exists(SESSION_FILE_PATH):
# Führe den Hook nur aus, wenn eine aktive Session existiert und es kein Merge-Commit ist
if not os.path.exists(SESSION_FILE_PATH) or is_merge_commit():
sys.exit(0)
try:
@@ -67,7 +65,7 @@ def main():
elapsed_time = datetime.now() - session_start_time
elapsed_hours = elapsed_time.total_seconds() / 3600
elapsed_hhmm = decimal_hours_to_hhmm(elapsed_hours)
time_comment = f"⏱️ Arbeitszeit in dieser Session: {elapsed_hhmm}\\n"
time_comment = f"⏱️ Arbeitszeit in dieser Session: {elapsed_hhmm}\n"
report_content = f"✅ New Commit:\n{time_comment}---\n{commit_message}"
timestamp = datetime.now().strftime('%Y-%m-%d %H:%M')
@@ -92,6 +90,7 @@ def main():
append_blocks_to_notion_page(token, task_id, notion_blocks)
except (FileNotFoundError, json.JSONDecodeError):
# Wenn die Datei nicht existiert oder fehlerhaft ist, einfach beenden
sys.exit(0)
if __name__ == "__main__":