npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

git-repo-summarizer

v1.1.8

Published

A tool to summarize Git repositories and make requests to Google Gemini.

Downloads

202

Readme

Gitリポジトリドキュメント自動生成ツール

概要

このツールは、Google Geminiを用いてGitリポジトリの内容を要約し、開発者向けドキュメントを自動生成します。

特徴

  • 環境変数の設定方法、APIエンドポイント、設定ファイル、コマンド実行例など、開発に必要な情報を自動的に抽出します。
  • 初めてプロジェクトに触れる開発者でも理解しやすいように、具体例を交えて説明します。
  • ファイルツリーを用いてリポジトリの構造を視覚化し、全体像を把握しやすくします。
  • Markdown形式で出力するため、READMEファイルなどに簡単に組み込むことができます。

インストール

前提条件

  • Node.js
  • npm
  • Google Cloud Platformアカウント
  • Google Gemini API キー

手順

  1. リポジトリをクローンします。
git clone https://github.com/takoyaki-3/git-repo-summarizer.git
  1. 依存関係をインストールします。
cd git-repo-summarizer
npm install
  1. Google Gemini API キーを環境変数に設定します。

Windows (PowerShell)

$env:GOOGLE_API_KEY = "YOUR_API_KEY"

Unix系端末 (bash, zshなど)

export GOOGLE_API_KEY="YOUR_API_KEY"

利用方法

グローバルインストール

このツールは、グローバルにインストールすることで、どのディレクトリからでもコマンドを使用できるようになります。

npm install -g git-repo-summarizer

コマンド

git-repo-summarizer summarize

Gitリポジトリの情報をMarkdown形式で出力します。

git-repo-summarizer summarize -- -t /path/to/your/repo -o output.md

オプション

  • -t, --target: 対象のリポジトリのパスを指定します。デフォルトはカレントディレクトリです。
  • -o, --output: 出力ファイル名を指定します。デフォルトは git-repo-summary-YYYYMMDD-HHMMSS.md のようなタイムスタンプ付きのファイル名になります。

git-repo-summarizer mkdoc

Gemini API を用いてドキュメントを生成します。

git-repo-summarizer mkdoc -- -t /path/to/your/repo -o document.md

オプション

  • -t, --target: 対象のリポジトリのパスを指定します。デフォルトはカレントディレクトリです。
  • -o, --output: 出力ファイル名を指定します。デフォルトは gemini-output-YYYYMMDD-HHMMSS.md のようなタイムスタンプ付きのファイル名になります。
  • -m, --model_id: 利用する Gemini のモデル ID を指定します。デフォルトは gemini-1.5-pro です。
  • -k, --api_key: Google Gemini API の API キーを指定します。環境変数 GOOGLE_API_KEY より優先されます。

git-repo-summarizer readme

README の自動更新を行います。

git-repo-summarizer readme -- -i /path/to/your/readme -o updated-readme.md

オプション

  • -i, --input: 更新対象のREADMEファイルのパスを指定します。
  • -o, --output: 出力ファイル名を指定します。デフォルトは updated-readme-YYYYMMDD-HHMMSS.md のようなタイムスタンプ付きのファイル名になります。
  • -t, --target: 対象のGitリポジトリのパスを指定します。デフォルトはカレントディレクトリです。
  • -m, --model_id: 利用する Gemini のモデル ID を指定します。デフォルトは gemini-1.5-pro です。
  • -k, --api_key: Google Gemini API の API キーを指定します。環境変数 GOOGLE_API_KEY より優先されます。

git-repo-summarizer gemini

Gemini APIを用いて指定したテキストに対する応答を取得し、保存する

git-repo-summarizer gemini -- -i /path/to/your/inputfile -t "要約してください" -o output.md

オプション

  • -t, --text: Gemini APIに送信するテキスト
  • -i, --input: 追加するテキストが含まれるファイルのパス
  • -o, --output: 出力ファイルの名前
  • -m, --model_id: 利用するGeminiモデルのID
  • -k, --api_key: Google Gemini APIのAPIキー

git-repo-summarizer patch

diff形式の変更ファイルを入力として与え、変更を適用する 注意:このコマンドは現在試用期間中であり今後仕様の変更や削除が行われる場合があります

git-repo-summarizer patch -- -d /path/to/your/diff -t /path/to/your/repo

オプション

  • -d, --diff: diff形式の変更ファイルのパス
  • -t, --target: 変更を適用する対象のディレクトリ

git-repo-summarizer update-diff

指定されたテキストに基づいてdiff.patchを生成する 注意:このコマンドは現在試用期間中であり今後仕様の変更や削除が行われる場合があります

git-repo-summarizer update-diff -- -c "変更内容" -t /path/to/your/repo -o diff.patch

オプション

  • -c, --change: 変更点を箇条書きで指定するテキスト
  • -t, --target: 対象のリポジトリのパス
  • -o, --output: 出力ファイル名
  • -m, --model_id: 利用するGeminiモデルのID
  • -k, --api_key: Google Gemini APIのAPIキー

ファイル構成

├── commands
│   ├── gemini.mjs
│   ├── mkdoc.mjs
│   ├── patch.mjs
│   ├── readme.mjs
│   ├── summarize.mjs
│   └── update.mjs
├── index.mjs
├── package.json
├── prompts
│   ├── generage-document-prompt.md
│   ├── generate-update-diff.md
│   └── update-readme-prompt.md
└── utils
    ├── apiUtils.mjs
    ├── apiUtils.test.js
    ├── fileUtils.mjs
    ├── generateFileName.mjs
    ├── generateFileName.test.js
    ├── gitUtils.mjs
    └── summarize.mjs

ファイル説明

  • .babelrc: Babelの設定ファイルです。
  • commands: コマンドラインツールのコマンドを定義したファイル群です。
    • gemini.mjs: npm run gemini コマンドの実装です。Gemini API を用いてテキストに対する応答を取得し、保存します。
    • mkdoc.mjs: npm run mkdoc コマンドの実装です。Gemini API を用いてドキュメントを生成します。
    • patch.mjs: npm run patch コマンドの実装です。diff 形式の変更を適用します。
    • readme.mjs: npm run readme コマンドの実装です。README の自動更新を行います。
    • summarize.mjs: npm run summarize コマンドの実装です。Git リポジトリの情報を Markdown 形式で出力します。
    • update.mjs: npm run update-diff コマンドの実装です。指定されたテキストに基づいて diff.patch を生成します。
  • index.mjs: ツールのエントリーポイントです。コマンドライン引数を解析し、適切な処理を実行します。
  • package.json: プロジェクトの依存関係とスクリプトを定義します。
  • prompts: Gemini に渡すプロンプトを定義したファイル群です。
    • generage-document-prompt.md: ドキュメント生成の指示を記述した Markdown ファイルです。
    • generate-update-diff.md: diff.patch 生成の指示を記述した Markdown ファイルです。
    • update-readme-prompt.md: README の自動更新の指示を記述した Markdown ファイルです。
  • utils: ユーティリティ関数を定義したファイル群です。
    • apiUtils.mjs: Google Gemini API へのリクエスト処理を行います。
    • apiUtils.test.js: apiUtils.mjs のユニットテストです。
    • fileUtils.mjs: ファイルの読み書きなどを行います。
    • generateFileName.mjs: タイムスタンプ付きのファイル名を生成します。
    • generateFileName.test.js: generateFileName.mjs のユニットテストです。
    • gitUtils.mjs: Git リポジトリの情報取得を行います。
    • summarize.mjs: Git リポジトリの情報を Markdown 形式にまとめます。

補足

  • Google Gemini API の利用料金については、Google Cloud Platform の料金ページをご確認ください。

ライセンス

このプロジェクトは MIT ライセンスで公開されています。