Coder Social home page Coder Social logo

Comments (9)

paulhfischer avatar paulhfischer commented on August 22, 2024

have a look at this commit, i used the all-repos.json file and parsed all attributes of the hooks (fallback are the default values listed on pre-commit.com).

let me know if this is what you've imagined and if you have comments on it.

from pre-commit.com.

asottile avatar asottile commented on August 22, 2024

looks like a good start! I imagine the version information would be useful as well -- is there a second mechanism for parsing .pre-commit-config.yaml from consuming repositories? to be honest I can't remember why this was useful (I think it was so a third party could integrate with showing packaging mappings / use)

from pre-commit.com.

paulhfischer avatar paulhfischer commented on August 22, 2024

the reason why i commented out the self.version method is because libraries.io then automatic gets the latest tag (either you define your one version or it uses git tags. this can also be seen in the compatibility matrix). this is similar to the emacs-packages.

not sure if i understood you correct regarding consuming repositories: do you mean parsing the additional_dependencies-field? i can add this for all languages that are listed in libraries.io (node, python via pypi, go). Here's an example of what i mean:

{
    "https://github.com/pre-commit/mirrors-coffeelint": [
        {
            "id": "coffeelint",
            "name": "coffeelint",
            "entry": "coffeelint",
            "language": "node",
            "files": "\\.(js|coffee)$",
            "args": [],
            "additional_dependencies": ["[email protected]"],
            "minimum_pre_commit_version": "0.7.0"
        }
    ]
}

would return the following in self.dependencies:

[
    {
        project_name: 'coffeelint',
        requirements: 2.1.0,
        kind: 'runtime',
        platform: 'npm'
    }
]

from pre-commit.com.

asottile avatar asottile commented on August 22, 2024

ah no not additional_dependencies (though maybe that's worth doing too? idk?) -- I was thinking more like if you looked at https://github.com/asottile/t for example it would have dependencies on github.com/pre-commit/pre-commit-hooks, ... based on its consuming .pre-commit-config.yaml

I don't know how that gets represented in libraries.io though πŸ€”

from pre-commit.com.

paulhfischer avatar paulhfischer commented on August 22, 2024

oh ok, if i understood the documentation correct, this is done by bibliothecary (if you log in to libraries.io, this will check your repositories for dependencies). i added pre-commit to bibliothecary here.

from pre-commit.com.

asottile avatar asottile commented on August 22, 2024

neat, that looks good -- though you'll want to skip repo: meta and repo: local

from pre-commit.com.

paulhfischer avatar paulhfischer commented on August 22, 2024

neat, that looks good -- though you'll want to skip repo: meta and repo: local

yeah thanks, i'm going to to change this.

from pre-commit.com.

paulhfischer avatar paulhfischer commented on August 22, 2024

i just tried adding the parsing of additional_dependencies, but encountered two problems:

  1. most languages have multiple package managers in libraries.io, but we are required to specify which one the dependency uses. it would be possible to search for the corresponding package manager in libraries.io, but this would be quite expensive and might cause errors if the same name is specified in multiple package managers
  2. the dependencies wouldn't be consistent, as not all additional_dependencies can be found on libraries.io, which kind of ruins the purpose imo

let me know what you think about adding this or if you have any suggestions

from pre-commit.com.

asottile avatar asottile commented on August 22, 2024

feel free to skip additional_dependencies πŸ‘

from pre-commit.com.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.