Skip to content

The repojoin fetches a GitHub repository ZIP file, extracts files with specified extensions, and concatenates their contents into a single string.

Notifications You must be signed in to change notification settings

yusenjeng/repojoin

Repository files navigation

repojoin

repojoin is a utility function that allows you to fetch a GitHub repository's ZIP file, extract files with specific extensions, and concatenate their contents into a single string.

Installation

npm install repojoin

Parameters

  • repoUrl (string): The URL of the GitHub repository.
  • targetExtensions (string[]): An array of file extensions to include in the concatenated output (e.g., ['.js', '.ts', '.tsx']).
  • branch (string, optional): The branch of the repository to fetch. Defaults to 'main'.

Usage

Join _.js and _.ts files from a specified repository.

import { repojoin } from 'repojoin'

async function test1() {
  const ret = await repojoin('https://github.com/yusenjeng/repojoin-test', [
    '.js',
    '.ts',
  ])
  console.log(ret)
}

test1()

Join _.js, _.ts, _.c and _.cc files from a specified repository and branch testing.

import { repojoin } from 'repojoin'

async function test2() {
  const ret = await repojoin(
    'https://github.com/yusenjeng/repojoin-test',
    ['.js', '.ts', '.c', '.cc'],
    'testing'
  )
  console.log(ret)
}

test2()

Join target files from a local folder

import { folderjoin } from 'repojoin'

async function test3() {
  const ret = folderjoin('test/data/', ['.ts', '.js', '.c'])
  console.log(ret)
}

test3()

About

The repojoin fetches a GitHub repository ZIP file, extracts files with specified extensions, and concatenates their contents into a single string.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published