Metadata-Version: 2.3
Name: project-aggregator
Version: 0.1.3
Summary: 폴더 구조와 코드들을 하나의 txt 파일에 작성해주는 도구
License: MIT
Keywords: cli,code-aggregator,utility,project-structure
Author: 👻👽🤖🧙‍♂️🫠
Author-email: sprain6628@gmail.com
Requires-Python: >=3.12
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Requires-Dist: coloredlogs (>=15.0,<16.0.0)
Requires-Dist: pathspec (>=0.12.1,<0.13.0)
Requires-Dist: platformdirs (>=4.0.0,<5.0.0)
Requires-Dist: typer[all] (>=0.9.0,<1.0.0)
Project-URL: Homepage, https://github.com/authentic0376/project_aggregator
Project-URL: Repository, https://github.com/authentic0376/project_aggregator
Description-Content-Type: text/markdown

# pagr (Project Aggregator) 📄➡️📦

`pagr`는 프로젝트의 디렉토리 구조와 선택된 파일들의 내용을 하나의 텍스트 파일로 깔끔하게 취합해주는 명령줄 도구입니다. ChatGPT와 같은 AI 모델에게 프로젝트 전체 컨텍스트를 효율적으로 전달해야 할 때 유용하게 사용할 수 있습니다. `.gitignore` 파일과 추가적인 `.pagrignore` 파일을 통해 취합 대상에서 제외할 파일이나 디렉토리를 유연하게 관리할 수 있습니다.

## 🚀 설치 (Installation)

`pipx`를 사용하여 `pagr`를 설치하는 것을 강력히 권장합니다. `pipx`는 CLI 도구를 시스템의 다른 라이브러리와 격리된 환경에 설치하고 실행해주어, 파이썬 환경의 충돌을 방지합니다.

1.  **`pipx` 설치 (아직 없다면):**
    ```bash
    # pip를 통해 pipx 설치
    pip install --user pipx
    # PATH 환경변수에 pipx 경로 추가 (필요시)
    python -m pipx ensurepath
    ```
    (설치 후 터미널을 재시작해야 할 수도 있습니다. 자세한 내용은 [pipx 공식 문서](https://pypa.github.io/pipx/)를 참고하세요.)

2.  **`pagr` 설치 (via pipx):**
    ```bash
    pipx install project-aggregator
    ```
    이제 터미널 어디서든 `pagr` 명령어를 사용할 수 있습니다! 🎉

### 🤔 다른 설치 방법

*   **pip 사용 (가상환경 권장):**
    ```bash
    # 가상환경 생성 및 활성화 (예: venv)
    # python -m venv .venv
    # source .venv/bin/activate # Linux/macOS
    # .venv\Scripts\activate # Windows

    pip install project-aggregator
    ```
*   **최신 개발 버전 설치 (GitHub 직접):**
    ```bash
    pipx install git+https://github.com/authentic0376/project_aggregator.git
    ```

## 💡 사용법 (Usage)

### 🏃 파일 취합 실행 (`run`)

프로젝트 디렉토리 구조와 필터링된 파일 내용을 취합하여 하나의 파일로 만듭니다.

**기본 사용법:**

*   **루트 디렉토리**: 취합을 시작할 최상위 디렉토리입니다. `--root <경로>` 옵션으로 지정하며, 생략 시 현재 작업 디렉토리가 사용됩니다.
*   **출력 파일**: 결과가 저장될 파일입니다. `--output <파일경로>` 옵션으로 지정하며, 생략 시 기본적으로 사용자 Downloads 폴더의 `pagr_output.txt`에 저장됩니다.

```bash
# 1. 현재 디렉토리의 모든 파일(무시 규칙 제외) 취합
# 결과는 기본 Downloads 폴더의 pagr_output.txt 에 저장됩니다.
pagr run

# 2. 특정 디렉토리를 루트로 지정하고, 그 안의 모든 파일(무시 규칙 제외) 취합
pagr run --root /path/to/your/project

# 3. 현재 디렉토리에서 취합하여 결과를 특정 파일로 저장
pagr run --output my_project_bundle.txt

# 4. 루트 지정과 출력 파일 지정을 동시에 사용
pagr run --root /path/to/your/project --output /path/to/output/bundle.md
```


**특정 파일/디렉토리만 취합하기:**

`--root, --output` 같은 옵션 외에 추가로 제공되는 인자들은 루트 디렉토리 내에서 취합할 대상을 명시적으로 지정하는 상대 경로 또는 Glob 패턴 (*, ** 등)입니다. 이 인자들이 주어지면, 지정된 패턴에 맞는 파일들만 (무시 규칙을 통과한 후) 코드 취합 대상이 됩니다.

이 인자들이 주어지지 않으면, 루트 디렉토리 내의 모든 파일 (무시 규칙 제외)이 취합 대상이 됩니다 (위의 기본 사용법 예시처럼).
```bash
# 5. 현재 디렉토리(--root 생략)에서 'src' 폴더 전체와 최상위 '.py' 파일들만 취합
pagr run src *.py

# 6. 특정 루트 디렉토리 내에서 'app/main.py' 파일과 'lib' 폴더 내의 모든 파일만 취합
pagr run --root /my/project app/main.py lib

# 7. 특정 루트 내의 모든 파이썬 파일(`**/*.py`)과 `requirements.txt` 파일만 취합하여 특정 파일에 저장
pagr run --root /my/project "**/*.py" requirements.txt --output python_files.txt
# (참고: 쉘 환경에 따라 Glob 패턴에 따옴표가 필요할 수 있습니다)

# 8. 현재 디렉토리에서 특정 패턴의 파일들만 취합하여 기본 출력 위치에 저장
pagr run "docs/**/*.md" "examples/*.py"
```
**도움말:**
```
# run 명령어의 상세 도움말 보기 (모든 옵션 및 인자 설명 확인 가능)
pagr run --help
```

### 🛠️ 무시 규칙 편집 (ignore)

`.gitignore` 외에 `pagr` 도구 자체의 무시 규칙을 담는 `.pagrignore` 파일을 편집합니다. 이 파일은 Git으로 관리할 필요가 없거나, AI 컨텍스트에 특히 불필요한 파일(예: `*.lock, *.log, build/, dist/`, 테스트 데이터 등)을 지정하기 좋습니다.

```bash
# 현재 디렉토리의 .pagrignore 파일을 기본 편집기로 엽니다 (파일이 없으면 새로 생성).
pagr ignore

# 도움말 보기
pagr ignore --help
```

`.pagrignore` 파일의 형식은 `.gitignore`와 동일합니다 (Git 와일드카드 패턴 사용).

### ℹ️ 기타 명령어
```bash
# 버전 확인
pagr --version

# 전체 도움말 보기
pagr --help
```
