Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/igorskyflyer/npm-is-git-repo

🐸 Checks if a directory is a local Git repository. πŸ•ΆοΈ
https://github.com/igorskyflyer/npm-is-git-repo

back-end directory folder git github gitlab igorskyflyer javascript js node repo repository ts typescript

Last synced: 3 months ago
JSON representation

🐸 Checks if a directory is a local Git repository. πŸ•ΆοΈ

Awesome Lists containing this project

README

        

Is Git repo?



🐸 Checks if a directory is a local Git repository. πŸ•ΆοΈ








πŸ’– Support further development


I work hard for every project, including this one


and your support means a lot to me!




Consider buying me a coffee. β˜•


Thank you for supporting my efforts! πŸ™πŸ˜Š





Donate to igorskyflyer




@igorskyflyer










## πŸ“ƒ Table of contents

- [Features](#-features)
- [Usage](#-usage)
- [API](#-api)
- [isGitRepo()](#isgitrepooptions-promiseboolean)
- [isGitRepoSync()](#isgitreposyncoptions-boolean)
- [Examples](#-examples)
- [Changelog](#-changelog)
- [License](#-license)
- [Related](#-related)
- [Author](#-author)




## πŸ€– Features

- πŸ” checks if a directory is a Git repo
- ⌚ both async and sync methods supported
- πŸ‘½ cross-platform
- βš–οΈ lightweight

---

## πŸ•΅πŸΌ Usage

> [!WARNING]
> This module requires that the [`git`](https://git-scm.com) executable is installed and available in the system path.
>
> If not, it needs to be installed first.
>


Install the module by executing:

```shell
npm i '@igor.dvlpr/is-git-repo'
```

---

## 🀹🏼 API

### `isGitRepo(options?): Promise`

*Asynchronously checks if a local directory is a Git repository.*

`options` - Optional object with options:
- `directory` - Sets the current working directory, otherwise the current directory will be used instead.


Will throw an error if the passed directory is not valid or does not exist.

Returns a Boolean indicating whether provided local directory is a Git repository.

---

### `isGitRepoSync(options?): boolean`

*Synchronously checks if a local directory is a Git repository.*

`options` - Optional object with options:
- `directory` - Sets the current working directory, otherwise the current directory will be used instead.


Will throw an error if the passed directory is not valid or does not exist.

Returns a Boolean indicating whether provided local directory is a Git repository.

---

## ✨ Examples

`example.mts`
```ts
import { isGitRepoSync } from '@igor.dvlpr/is-git-repo'

console.log(isGitRepoSync({ directory: '../my-git-project' })) // true
```

---

## πŸ“ Changelog

πŸ“‘ The changelog is available here: [CHANGELOG.md](https://github.com/igorskyflyer/npm-is-git-repo/blob/main/CHANGELOG.md).

---

## πŸͺͺ License

Licensed under the MIT license which is available here, [MIT license](https://github.com/igorskyflyer/npm-is-git-repo/blob/main/LICENSE).

---

## 🧬 Related

[@igor.dvlpr/vscode-folderpicker](https://www.npmjs.com/package/@igor.dvlpr/vscode-folderpicker)

> _✨ Provides a custom Folder Picker API + UI for Visual Studio Code. 🎨_


[@igor.dvlpr/git-repo-url](https://www.npmjs.com/package/@igor.dvlpr/git-repo-url)

> _🌐 Gets the origin URL a local Git repository. πŸ—ΊοΈ_


[@igor.dvlpr/is-rootdir](https://www.npmjs.com/package/@igor.dvlpr/is-rootdir)

> _πŸ”Ό Provides a way to check if the given path is the root drive/directory. β›”_


[@igor.dvlpr/str-is-in](https://www.npmjs.com/package/@igor.dvlpr/str-is-in)

> _🧡 Provides ways of checking whether a String is present in an Array of Strings using custom Comparators. πŸ”_


[@igor.dvlpr/chars-in-string](https://www.npmjs.com/package/@igor.dvlpr/chars-in-string)

> _πŸͺ Provides ways of testing whether an array of chars is present inside a given String. β˜„_

---

## πŸ‘¨πŸ»β€πŸ’» Author
Created by **Igor Dimitrijević** ([*@igorskyflyer*](https://github.com/igorskyflyer/)).