Commit Graph

47 Commits

Author SHA1 Message Date
acc8533ef2 refactor: .agents + .agent 단일 .agent 디렉토리로 통합 (agent_guide 포맷, 12→7 워크플로우 축소) 2026-03-11 01:04:52 +09:00
CD
d50d3d86af docs: devlog 커밋 해시 업데이트 2026-03-10 22:51:49 +09:00
CD
044200a786 chore: Agent Guide 셋업 — agent_guide.git 기반 .agents 재구성 + 프로젝트별 설정 2026-03-10 22:51:14 +09:00
CD
e1aca2b79f docs: devlog 커밋 해시 업데이트 2026-03-08 17:44:50 +09:00
CD
1dab257401 fix(tools): 애니 파이프라인 버그 4건 수정 — Unicode SyntaxError, 카타카나 변환, Nyaa 검색 전략 + Python 환경 설정 2026-03-08 17:43:54 +09:00
CD
a3a083f6da chore: vikunja PROJECT_ID 설정 (7) 2026-03-08 16:09:17 +09:00
CD
c92433b0b1 feat(tools): 애니메이션 자동화 파이프라인 구현
- tools/anissia_client.py: Anissia API 클라이언트 (편성표/자막)
- tools/nyaa_client.py: Nyaa.si RSS 토렌트 검색
- tools/qbit_client.py: qBittorrent Web API 클라이언트
- tools/subtitle_downloader.py: Google Drive/Tistory/Naver 자막 파서
- tools/title_matcher.py: 제목 매칭 + NAS 폴더명 생성
- tools/anime_pipeline.py: 전체 파이프라인 오케스트레이터
- tools/nas_scanner.py: NAS 폴더/파일 스캔
- prompts/unified.md: anime 모드 추가 (AI 평문 의도 분류)
- api/discord_bot.py: AI 평문 anime 핸들러 + /anime 슬래시 커맨드
- config.py: qBittorrent/NAS 설정 추가
- .agents/: agent_guide 워크플로우 통합
- docs/devlog: 세션 기록
2026-03-08 16:07:16 +09:00
CD
49ee5f397c fix: reviewer 타임아웃 300초, unified에 workspace 경로 추가
- reviewer agent timeout: 180s → 300s (에이전트 시작 오버헤드 고려)
- unified context에 workspace path 명시 → 경로 질문에 정확한 답변
- planner agent timeout 유지: 180s
2026-03-07 01:37:48 +09:00
CD
e65e2250a3 feat: Planner direct 모드 + Reviewer 검증
- direct 모드: Planner 직접 처리 → Reviewer 검증 → 완료 (2단계)
- tasks 모드: 기존대로 full pipeline (5단계)
- 대화 히스토리 embed 내용 포함 (clarify 맥락 유지)
2026-03-07 01:26:32 +09:00
CD
80a5560134 fix: 대화 히스토리에서 embed 내용 유실 - clarify 맥락 보존
- _get_channel_history에서 embed title/description/fields 추출
- 봇의 clarify 질문이 히스토리에 포함되어 맥락 유지
- planner 프롬프트 강화: 불필요한 태스크 분할 방지
2026-03-07 01:22:08 +09:00
CD
0fa62d24e9 revert: unified 프롬프트에서 모델명 제거 (인위적) 2026-03-07 00:53:02 +09:00
CD
4dc75804ad fix: unified 프롬프트에 모델 정체성 추가 (Gemini 3 Flash) 2026-03-07 00:51:35 +09:00
CD
01bf8aa258 feat: gemini-3-flash-preview + 역할별 thinkingBudget
- 모델: gemini-3-flash-preview (2.0 Flash → 3 Flash 업그레이드)
- 역할별 thinkingBudget 동적 조절:
  unified/summarizer = 512  (가벼운 분류/요약)
  planner            = 4096 (계획/검수)
  coder/reviewer     = 8192 (구현/비평)
- ~/.gemini/settings.json에 호출 직전 반영
- Docker에서도 settings.json 마운트로 동작
2026-03-07 00:48:30 +09:00
CD
fcd3ebfd41 fix: docs_manager 세션 기록 크래시 방지
- record_session을 try/except로 감싸서 실패해도 봇 지속
- mkdir 안전장치 추가 (에이전트가 docs/ 삭제할 수 있음)
- em-dash → ASCII dash 변경
2026-03-06 23:42:06 +09:00
CD
a408bb32fe refactor: 전체 구조 점검 - 데드코드 제거, 에이전트 모드 통일, 취소 기능
1. 데드 코드 제거: execute() 146줄, _read_project_files() 31줄
2. 전 역할 agent 모드: summarize도 call_agent로 변경
3. 작업 취소: 취소/stop/cancel 입력으로 실행 중 작업 중단
4. 중복 방지: 채널당 1작업만 허용
2026-03-06 23:30:00 +09:00
CD
5f669117b2 feat: Planner/Reviewer 에이전트 모드 + 직접 파일 접근 2026-03-06 23:25:30 +09:00
CD
52402065f3 feat: Planner 오케스트레이션 루프 구현
이중 루프 구조:
- 내부 루프 (Planner 자가검증, 최대 3회):
  계획 → 코딩 → Planner가 결과 검증 → 미달 시 추가 태스크 → 반복
  Planner가 만족할 때까지 자체적으로 보완 작업 진행
- 외부 루프 (Reviewer, 최대 2회):
  Planner 만족 → Reviewer 검토 → 반려 시 피드백으로 재계획

새 메서드:
- planner_verify(): Planner가 계획 달성도 자가 검증
- _read_recent_files(): 프로젝트 파일 읽기 공용 헬퍼
2026-03-06 23:14:05 +09:00
CD
47a8c41a81 feat: Coder 자가검증 루프 추가
구현 → 자가검증 → 자가수정 → 검증통과 → 완료보고
- 2단계: 파일 다시 읽어 완전성/참조/문법 확인
- 3단계: 문제 있으면 직접 수정 후 다시 검증
- 4단계: 검증 통과 후에만 리뷰어에게 전달
외부 리뷰 재시도 비용을 줄이는 내부 품질 루프
2026-03-06 23:07:57 +09:00
CD
69e3a051f7 refactor: 전체 프롬프트 점검 및 수정
- reviewer.md: 에이전트 모드에 맞게 전면 개편
  - 실제 파일 기반 리뷰로 변경
  - 명확한 통과/반려 기준 (critical만 반려, 스타일은 통과)
  - '의심이 되면 통과시키세요' 원칙
- coder.md: 완성도 요구사항 추가
  - 빈 폴더(새 프로젝트) 대응 안내
  - TODO/뼈대 금지 — 완성된 코드 요구
  - 파일 간 참조 확인 지시
- summarizer.md: 입력 설명을 에이전트 모드에 맞게 수정
- router.md: 삭제 (unified.md가 대체)
2026-03-06 22:51:19 +09:00
CD
3d2af29a0a fix: 태스크 과분할 방지 - unified/planner 프롬프트 대폭 수정
- unified.md: tasks 배열 완전 제거, mode+summary만 출력
- planner.md: '대부분 1개 태스크로 충분' 원칙 강화
  테트리스=1개, 파일삭제+재생성=1개, 독립기능만 분할
2026-03-06 22:47:00 +09:00
CD
a6e9f31244 fix: Planner 최소분할 원칙 - 하나의 기능은 하나의 태스크로
- planner.md: 파일 단위 분할 → 기능 단위 분할로 변경
  예: 테트리스 = 1태스크 (HTML+CSS+JS 한 에이전트가 처리)
- unified.md: task 모드에서 tasks 배열 강제 제거 (Planner에 위임)
2026-03-06 22:44:51 +09:00
CD
b2cf38b5ff fix: Coder 프롬프트 - 코드 주석/문서 한국어 작성 지시 추가 2026-03-06 22:40:27 +09:00
CD
173e1a6a54 fix: AI 플로우 전체 truncation 제거 + Discord 메시지 분할
- task_pipeline.py: summarize()에서 리뷰/코딩 결과 자르기 제거
- discord_bot.py: safe_send_embed() 추가 (4096자 초과 시 분할 전송)
- 리뷰 피드백 자르기 제거 (재시도 시 전체 피드백 전달)
2026-03-06 22:32:22 +09:00
CD
7777ca1ba7 fix: 리뷰어에게 전체 내용 전달 - 모든 truncation 제거 2026-03-06 22:28:50 +09:00
CD
ee71d7713d fix: 리뷰 파일 cutoff 600초로 확장 2026-03-06 22:27:21 +09:00
CD
8140f75c7f fix: 리뷰어가 실제 파일 읽기로 변경
- batch_review: Gemini stdout 대신 프로젝트의 최근 변경 파일(60초)을 읽어 리뷰
- 파일 삭제/변경 없는 작업은 자동 통과
- 에이전트 보고 + 실제 파일 내용을 함께 전달
- 최대 10개 파일, 파일당 3000자 제한
2026-03-06 22:25:26 +09:00
CD
a54a9096ef fix: 단계별 진행 표시 + em-dash 인코딩 수정
- _handle_task: pipeline.execute() 대신 단계별 호출로 변경
  -> 계획/코딩/리뷰/재시도 각 단계를 Discord에 실시간 표시
  -> 코딩 중.../리뷰 중... Embed가 완료 시 업데이트됨
- em-dash -> ASCII dash (cp949 인코딩 오류 방지)
2026-03-06 22:22:41 +09:00
CD
bccc673713 feat: Coder를 에이전트 모드로 전환 + 리뷰 재시도 루프
핵심 변경:
- gemini_caller.py: call_agent() 추가 (cwd 지원, 5분 타임아웃)
  Gemini가 프로젝트 디렉토리에서 직접 파일 읽기/쓰기/실행
- task_pipeline.py: Coder가 call_agent() 사용, file_applier 의존 제거
  리뷰 실패 시 최대 2회 재시도 (피드백 포함)
- discord_bot.py: pipeline.execute() 호출로 단순화
- coder.md: 파일 직접 쓰기 지시 (코드블록 출력 금지)
- 검증: echo prompt | gemini --cwd=VW_Proj → test_agent.txt 생성 확인
2026-03-06 22:13:06 +09:00
CD
83c043863c fix: 슬래시 커맨드 길드별 즉시 동기화
- copy_global_to + guild sync로 변경 (글로벌 1시간 캐시 문제 해결)
- name optional 변경이 즉시 반영됨
2026-03-06 21:55:41 +09:00
CD
3f69b6a47a feat: 채널 이름 변경 시 워크스페이스+폴더 자동 연동
- on_guild_channel_update 이벤트로 이름 변경 감지
- workspace.rename_workspace(): 이름+폴더 변경 (VW_Proj 하위에만)
- 변경 완료 시 채널에 알림 Embed 전송
2026-03-06 21:52:10 +09:00
CD
63a12d9078 feat: /workspace set 이름 자동화 - 채널 이름을 기본값으로 사용
- name 파라미터 선택적으로 변경
- 미입력 시 채널 이름 자동 사용
- /workspace set만 치면 끝
2026-03-06 21:49:26 +09:00
CD
889badc52b feat: Git/Vikunja 미설정 시 차단 대신 안내 후 로컬 작업 진행
- 작업 실행 차단 제거 -> 안내 메시지만 표시
- /workspace set만으로 바로 작업 가능
- 나중에 /workspace git, /workspace vikunja로 등록 가능
2026-03-06 21:47:24 +09:00
CD
8bd7dcab3f feat: 출력 파싱 4패턴 지원 + 실패 기록 + Gemini CLI Windows 호환
- file_applier.py: === FILE ===, `lang:path, // file: comment, **header**+code 4패턴
  경로 검증, 중복 제거, 빈 내용 스킵, 소스 추적
- task_pipeline.py: try/except/finally로 성공/실패 모두 docs 기록
  파싱 실패 추적, 에러를 총평 warnings에 전파
- gemini_caller.py: Windows에서 cmd /c gemini 사용 (PS ExecutionPolicy 우회)
- Gemini CLI stdin 파이프 동작 검증 완료
2026-03-06 21:38:08 +09:00
CD
f0656d54de fix: 유령 워크스페이스 폴더도 함께 이름 변경
- cleanup_orphans: JSON 이름 + 실제 폴더 모두 _orphan_YYYYMMDD 접미사
- 같은 이름 재생성 시 새 폴더가 만들어짐 (충돌 없음)
- 폴더 이름 중복 시 숫자 카운터 추가
2026-03-06 21:27:23 +09:00
CD
1e8e8c324f fix: 유령 워크스페이스 삭제 대신 이름 변경으로 보존
- cleanup_orphans: 삭제 -> _orphan_YYYYMMDD 접미사 추가
- Git/Vikunja 설정 등 모든 데이터 보존됨
- 이름 충돌 없이 같은 이름으로 새 채널 등록 가능
2026-03-06 21:22:39 +09:00
CD
b9e4a94e9a feat: 워크스페이스 이름충돌 감지 + 기본경로(VW_Proj) + 유령채널 자동정리
- workspace.py: find_by_name() 이름충돌, cleanup_orphans() 유령정리, 경로 자동생성
- config.py: WORKSPACE_BASE_DIR = VW_Proj
- discord_bot.py: /workspace set path 선택적, 이름충돌 안내, on_ready 유령정리
- VW_Proj 폴더 생성
2026-03-06 21:19:42 +09:00
CD
a9bdce90f4 feat: 워크스페이스 시스템 + 통합 프롬프트 + Docs 기록 관리
- workspace.py: 채널별 워크스페이스 모델 + JSON 영속 저장
- discord_bot.py: /workspace 슬래시 커맨드 (set/git/vikunja/info/remove/list)
  - 등록 채널만 자동 응답, 미등록 채널 무시
  - Git/Vikunja 미설정 시 작업 차단 + 안내
  - 통합 프롬프트 1회 호출 (router+planner+chat 통합)
- docs_manager.py: Wiki 인덱스, 세션 기록, Changelog 자동 업데이트
- task_pipeline.py: 모든 Gemini 호출에 docs 컨텍스트 주입, 완료 시 기록
- unified.md: 분류+즉답/계획 통합 프롬프트
2026-03-06 21:12:50 +09:00
CD
752d851f9f feat: Pipeline 전면 개선 — 병렬실행, Batch Review, 총평, 대화기억, 스마트라우팅
- GeminiCaller: cmd/c 제거, 인자 분리, Semaphore(4) 동시성 제어, GeminiCallError
- TaskPipeline: asyncio.gather 병렬 코딩, batch_review 1회, summarize 총평
- FileApplier: Coder 출력 파싱 → 실제 파일 적용 (경로 보안 체크)
- Discord Bot: on_message 자동채팅, 의도분류(chat/task/clarify), 대화기억(10메시지)
- Prompts: router.md (의도분류), summarizer.md (총평)
- Workflows: agent_chat 환경 경로 업데이트
2026-03-06 20:46:58 +09:00
quantlab
4c0f5ec9c7 chore: 이식성 개선 — 하드코딩 경로 제거, .env.example 추가, README 시작 가이드 2026-03-06 20:11:54 +09:00
quantlab
ee01a13129 feat(integration): Gitea + Vikunja + CI 클라이언트 구현 #task-192 #task-193 2026-03-06 20:01:00 +09:00
quantlab
26cef9bb11 feat(api): !chat 명령어 추가 — 단순 대화용 Gemini 직접 호출 #task-191 2026-03-06 18:59:34 +09:00
quantlab
427763c493 feat(api): API Server + Discord Bot 구현 #task-191 2026-03-06 18:52:11 +09:00
quantlab
5a931a5480 fix: .gitignore에서 .agent/ 트래킹 + 테스트 절대경로 제거 (이식성 보장) 2026-03-06 17:58:11 +09:00
quantlab
b6ed432fe3 test: Full E2E Pipeline 성공 (Plan→Code→Review) — 3호출 219초 #task-190 2026-03-06 17:46:45 +09:00
quantlab
57c9cb6143 feat: Task Pipeline + Planner E2E 성공 — stdin기반 GeminiCaller 확정 #task-189 #task-190 2026-03-06 17:37:06 +09:00
quantlab
9192770300 feat: Project Indexer + Context Manager + GeminiCaller 구현 및 테스트 #task-187 #task-188 #task-189 2026-03-06 17:15:54 +09:00
quantlab
0e3d85f9da chore: 프로젝트 초기 구조 + .agent 워크플로우 + 설계 문서 2026-03-06 16:57:14 +09:00