conf-finder


Nameconf-finder JSON
Version 0.3.1 PyPI version JSON
download
home_pageNone
SummaryConfiguration file finder.
upload_time2025-01-08 05:24:23
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseNone
keywords config git xgb xgb_config_home
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # conf-finder

[![test](https://github.com/rcmdnk/conf-finder/actions/workflows/test.yml/badge.svg)](https://github.com/rcmdnk/conf-finder/actions/workflows/test.yml)
[![test coverage](https://img.shields.io/badge/coverage-check%20here-blue.svg)](https://github.com/rcmdnk/conf-finder/tree/coverage)

Configuration file finder.

The configuration file/directory is searched for in the following locations by default:

- The current directory
- Git root repository (if the current directory is within a repository)
- XDG config home (`$XDG_CONFIG_HOME`; if not set, **~/.config** is used)
- Home directory

To locate the configuration directory, the tool searches for a dot-prefixed
name (e.g., .**mytool**) in all locations except for the XDG config home.
Within the XDG config home, a name without the dot prefix (e.g., **mytool**)
is searched for.

If no directory is found, the path under the XDG config home is returned.

To locate the configuration file, the tool first searches for a dot-prefixed
file (e.g., **.myconf.txt**) in all locations except for the XDG config home.
Within the XDG config home, a file name without the dot prefix
(e.g., **myconf.txt**) is searched for. Following this, an attempt is made
to find the file within the located configuration directories.

If no file is found, the path under the configuration directory within
the XDG config home is returned.

## Requirement

- Python 3.9, 3.10, 3.11

## Installation

```bash
$ pip install conf-finder
```

## Usage

```python
from conf_finder import ConfFinder


cf = ConfFinder('mytool')
print(cf.directory())
```

This script searches for:

- **./.mytool**
- **<Git root directory>/.mytool** if here is under the git repository.
- **$XDG_CONFIG_HOME/mytool** (If `XDG_CONFIG_HOME` is not set, use `~/.config`.)
- **~/.mytool**

If no directory is found, return `$XDG_CONFIG_HOME/mytool` (or `~/.config/mytool`).

```python
from conf_finder import ConfFinder


cf = ConfFinder('mytool')
print(cf.conf(exe='toml'))
```

This script searches for:

- **./.mytool.toml**
- **<Git root directory>/.mytool.toml** if here is under the git repository.
- **$XDG_CONFIG_HOME/mytool.toml** (If `XDG_CONFIG_HOME` is not set, use `~/.config`.)
- **~/.mytool.toml**
- **./.mytool/conf.toml**
- **<Git root directory>/.mytool/conf.toml**
- **$XDG_CONFIG_HOME/mytool/conf.toml**
- **~/.mytool/conf.toml**

```python
from conf_finder import ConfFinder


cf = ConfFinder('mytool')
print(cf.conf('mytool', 'toml', 'myconf'))
```

This script searches for:

- **./.myconf.toml**
- **<Git root directory>/.myconf.toml**
- **$XDG_CONFIG_HOME/myconf.toml**
- **~/.myconf.toml**
- **./.mytool/myconf.toml**
- **<Git root directory>/.mytool/myconf.toml**
- **$XDG_CONFIG_HOME/mytool/myconf.toml**
- **~/.mytool/myconf.toml**

If you wish to search for only files directly placed under the search directories,
`conf_type` to `'file'`:

```python
from conf_finder import ConfFinder


cf = ConfFinder('mytool', conf_type='file')
print(cf.conf('mytool', 'toml', 'myconf'))
```

This script searches for:

- **./.myconf.toml**
- **<Git root directory>/.myconf.toml**
- **$XDG_CONFIG_HOME/myconf.toml**
- **~/.myconf.toml**

If no file is found, **$XDG_CONFIG_HOME/myconf.toml** is returned.

To search for only directories, `conf_type` to `'dir'` instead.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "conf-finder",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "CONFIG, Git, XGB, XGB_CONFIG_HOME",
    "author": null,
    "author_email": "rcmdnk <rcmdnk@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/25/7e/233812e2ab32874a11da2113bce4981df6d6d43da94221204aa6afc986b2/conf_finder-0.3.1.tar.gz",
    "platform": null,
    "description": "# conf-finder\n\n[![test](https://github.com/rcmdnk/conf-finder/actions/workflows/test.yml/badge.svg)](https://github.com/rcmdnk/conf-finder/actions/workflows/test.yml)\n[![test coverage](https://img.shields.io/badge/coverage-check%20here-blue.svg)](https://github.com/rcmdnk/conf-finder/tree/coverage)\n\nConfiguration file finder.\n\nThe configuration file/directory is searched for in the following locations by default:\n\n- The current directory\n- Git root repository (if the current directory is within a repository)\n- XDG config home (`$XDG_CONFIG_HOME`; if not set, **~/.config** is used)\n- Home directory\n\nTo locate the configuration directory, the tool searches for a dot-prefixed\nname (e.g., .**mytool**) in all locations except for the XDG config home.\nWithin the XDG config home, a name without the dot prefix (e.g., **mytool**)\nis searched for.\n\nIf no directory is found, the path under the XDG config home is returned.\n\nTo locate the configuration file, the tool first searches for a dot-prefixed\nfile (e.g., **.myconf.txt**) in all locations except for the XDG config home.\nWithin the XDG config home, a file name without the dot prefix\n(e.g., **myconf.txt**) is searched for. Following this, an attempt is made\nto find the file within the located configuration directories.\n\nIf no file is found, the path under the configuration directory within\nthe XDG config home is returned.\n\n## Requirement\n\n- Python 3.9, 3.10, 3.11\n\n## Installation\n\n```bash\n$ pip install conf-finder\n```\n\n## Usage\n\n```python\nfrom conf_finder import ConfFinder\n\n\ncf = ConfFinder('mytool')\nprint(cf.directory())\n```\n\nThis script searches for:\n\n- **./.mytool**\n- **<Git root directory>/.mytool** if here is under the git repository.\n- **$XDG_CONFIG_HOME/mytool** (If `XDG_CONFIG_HOME` is not set, use `~/.config`.)\n- **~/.mytool**\n\nIf no directory is found, return `$XDG_CONFIG_HOME/mytool` (or `~/.config/mytool`).\n\n```python\nfrom conf_finder import ConfFinder\n\n\ncf = ConfFinder('mytool')\nprint(cf.conf(exe='toml'))\n```\n\nThis script searches for:\n\n- **./.mytool.toml**\n- **<Git root directory>/.mytool.toml** if here is under the git repository.\n- **$XDG_CONFIG_HOME/mytool.toml** (If `XDG_CONFIG_HOME` is not set, use `~/.config`.)\n- **~/.mytool.toml**\n- **./.mytool/conf.toml**\n- **<Git root directory>/.mytool/conf.toml**\n- **$XDG_CONFIG_HOME/mytool/conf.toml**\n- **~/.mytool/conf.toml**\n\n```python\nfrom conf_finder import ConfFinder\n\n\ncf = ConfFinder('mytool')\nprint(cf.conf('mytool', 'toml', 'myconf'))\n```\n\nThis script searches for:\n\n- **./.myconf.toml**\n- **<Git root directory>/.myconf.toml**\n- **$XDG_CONFIG_HOME/myconf.toml**\n- **~/.myconf.toml**\n- **./.mytool/myconf.toml**\n- **<Git root directory>/.mytool/myconf.toml**\n- **$XDG_CONFIG_HOME/mytool/myconf.toml**\n- **~/.mytool/myconf.toml**\n\nIf you wish to search for only files directly placed under the search directories,\n`conf_type` to `'file'`:\n\n```python\nfrom conf_finder import ConfFinder\n\n\ncf = ConfFinder('mytool', conf_type='file')\nprint(cf.conf('mytool', 'toml', 'myconf'))\n```\n\nThis script searches for:\n\n- **./.myconf.toml**\n- **<Git root directory>/.myconf.toml**\n- **$XDG_CONFIG_HOME/myconf.toml**\n- **~/.myconf.toml**\n\nIf no file is found, **$XDG_CONFIG_HOME/myconf.toml** is returned.\n\nTo search for only directories, `conf_type` to `'dir'` instead.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Configuration file finder.",
    "version": "0.3.1",
    "project_urls": {
        "Homepage": "https://github.com/rcmdnk/conf-finder",
        "Repository": "https://github.com/rcmdnk/conf-finder"
    },
    "split_keywords": [
        "config",
        " git",
        " xgb",
        " xgb_config_home"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "9653c5d92b192f8e6d0ab7e08c629db999750a2d07c2771ba76195e365017b7e",
                "md5": "d134a69b12909201e925f261254f2e20",
                "sha256": "f4e7d4a87839f54433bd3d7ed3be09fc1e1ca8f251f7df3d2ff87dbfbcd1bd69"
            },
            "downloads": -1,
            "filename": "conf_finder-0.3.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "d134a69b12909201e925f261254f2e20",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 9391,
            "upload_time": "2025-01-08T05:24:21",
            "upload_time_iso_8601": "2025-01-08T05:24:21.810692Z",
            "url": "https://files.pythonhosted.org/packages/96/53/c5d92b192f8e6d0ab7e08c629db999750a2d07c2771ba76195e365017b7e/conf_finder-0.3.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "257e233812e2ab32874a11da2113bce4981df6d6d43da94221204aa6afc986b2",
                "md5": "c7f3c2ff4b301ac57b2c06cd62c06347",
                "sha256": "3df3a3eaf2a1af8920c3b91b6b2068a4620c5b4e6fac8711e6da4582e0ed591f"
            },
            "downloads": -1,
            "filename": "conf_finder-0.3.1.tar.gz",
            "has_sig": false,
            "md5_digest": "c7f3c2ff4b301ac57b2c06cd62c06347",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 74811,
            "upload_time": "2025-01-08T05:24:23",
            "upload_time_iso_8601": "2025-01-08T05:24:23.342658Z",
            "url": "https://files.pythonhosted.org/packages/25/7e/233812e2ab32874a11da2113bce4981df6d6d43da94221204aa6afc986b2/conf_finder-0.3.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-08 05:24:23",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "rcmdnk",
    "github_project": "conf-finder",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "conf-finder"
}
        
Elapsed time: 1.06437s