this post was submitted on 28 Jan 2024
32 points (94.4% liked)

Programming

17325 readers
119 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 1 year ago
MODERATORS
 

Background

I am designing a CLI for a container build tool I am making. It uses Gentoo's Portage behind the scenes

Question

I want to give the user the ability to specify a custom package repository. The repository must have a name, URI and sync type.

custom_repo: {
    uri: 'https://...',
    name: 'custom',
    sync_type: 'git',
}

How do I have the user represent this in the CLI? keep in mind, this is not the main input and is optional.

One way is to make this only provide-able via a config file using JSON or another structured data representation. But I want to see if theres a good way to do it in the CLI

What I am thinking of: command --custom-repo uri='https://...',name=custom,sync_type=git --custom-repo ... [main input]

Is this the best way of doing this?

you are viewing a single comment's thread
view the rest of the comments
[–] SpaceNoodle@lemmy.world 9 points 9 months ago (2 children)

Can't this all be deduced from the URI?

https://github.com/org/project.git

The .git suffix indicates git, the project name is the stem (project).

[–] Corngood@lemmy.ml 8 points 9 months ago* (last edited 9 months ago)

Nix does something like this with the protocol specifier: e.g. git+https://...

I'm not sure what name means here exactly, but it might make sense to treat that separately, like git remotes:

tool add [name] git+https://foo

[–] oscar@programming.dev 2 points 9 months ago (1 children)

That is assuming it's hosted on github.

[–] SpaceNoodle@lemmy.world 0 points 9 months ago (1 children)
[–] oscar@programming.dev 3 points 9 months ago* (last edited 9 months ago) (1 children)

Ok, then I don't understand at all. What happens if I host my git project on https://myawesomeproject.dev/? How can the application infer anything by this URL?

[–] SpaceNoodle@lemmy.world 0 points 9 months ago (2 children)

Then replace "github.com" with "myawesomeproject.dev". There's more to the URI than just the hostname.

[–] oscar@programming.dev 3 points 9 months ago (1 children)

But you can't assume that it follows the github format of https://<domain>/<user>/<project>.git. In my example, I meant that you would just use that url to clone it:

git clone https://myawesomeproject.dev

One real-world example of this is ziglings.org (though it's technically just a redirect).

[–] SpaceNoodle@lemmy.world -1 points 9 months ago (1 children)

That's not a GitHub format; it's a git format.

[–] oscar@programming.dev 3 points 9 months ago

No, it isn't. Git doesn't care what the url is, as long as it uses a supported transport protocol.