-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Installer options such as require PPAs #11
Comments
I like having the installer_options for the top of the file. I'm not sure if supporting rule specific ppa requirements is good for overall complexity of maintenance of the rules files. if each PPA requirement is at the top you can capture two PPAs in with half the lines by using two files instead of interleaving the required ppa for each entry. The other question I have is about how to express the PPAs. You're currently implying that the PPA is some sort of reference into a config file, I'd much rather see the PPA parameterization captured in the rules file header. For example you may want to add the GPG keys for a custom repo in addition to the url. |
I agree that in general rules files are best split up to have at most one ppa per file and put that at the top, which should be the documented best practice. However, do we need to prevent people from the possibility of using per-key PPA requirements? I'm not saying this is needed for the rules files, but I like the idea of having these requirements at the key-level in the expande rules file, such that only the requirements for keys actually to be installed are checked. Expanding the rules files such that these keys are attached to each key is the simplest way to achieve that IMO. Any alternative would require to track during resolution where each rule was coming from. I was actually not implying a reference to a config file and I agree that the info in the rules file should be self contained. I was only considering ubuntu launchpad PPAs which can be added with
We keep talking of PPAs, but I guess strictly speakin that is referring to Ubuntu launchpad PPAs only? Maybe better term this "apt repository". It probably makes sense to have the rule-file-wide repositry definition depend on os and verison. Maybe like this:
|
I agree using the repositories keyword is better and reusing the apt-add-repository keywords is a good idea. For the availability of per rule repository definitions makes everything more complicated. Unless there's a use case that is not met, I believe that adding the complexity to the file, and the parsing, and for the maintainer will simply create more work at every level. And I think that since we can have as many source files as required the rules can be maintained in separate files anyway. |
Ok, I can understand your point. I agree that there is no use case as of now that can not be served well with per-rules-file-only apt-repository information. My main argument for anchoring that information at the rule level is that it makes sense from the implementation perspective, i.e. I suggest to transfer this information to every key upon rule file expansion such that during lookup the repositories are checked/installed if and only if one of the xylem keys from that file is being installed and has resolved to an apt-rule. Independent from the implementation, what do you suggest how xylem should use the repository information. At what point should xylem check/install a repository defined in a rules file? |
I think that xylem should check at load time not recheck on every evaluation. There's some level of caching possible for the code path. I would suggest that xylem be able to automatically add sources only when explicitly asked for by an option like --auto-add-sources Case 1: Repository declared and missing and --auto-add set Case 2: Repository declared and missing Case 3: Repository declared and missing --ignore-missing-repositories set Case 4: Repository declared and present Case 5: Repository not declared |
What do you mean when you say Just to make sure we are on the same page. The workflow in xylem is the following for rules files and the database:
I assume you mean the repositories should be checked when the database is loaded (not on To me, that doesn't make much sense.
Is there a specific reason you do not want to perform this check just before an install command would be issued? I think this is not only closer to what I as a user would want, but also much simpler to implement. With my suggestion, only the installer plugin needs to worry at all about this information. It does not receive any kind of special treatment during rules file expansion, loading of the database, rule lookup / resolution, ... None of that code needs to know anything about apt-repositories. No heuristics at "rules file evaluation" about whether or not certain repositories should be checked given the detected/overwritten OS. I don't even need to load any installer plugins at all just to load the rule database into memory and lookup rools (although I do need the installer plugins for Note that with my proposal the check happens at most once for every
|
As long as the check is only done once per invocation and not once per package that will work. That's the main think I want to avoid. |
Ok great, I fully agree about only one invocation per |
Is it possible to stretch this a little bit to include enabling Ubuntu's universe and multiverse repositories? I continue to see users on ROS answers that have dependency problems because they missed that step in the installation guide. If you think this is better addressed elsewhere, that is fine as well. |
@trainman419: Is there anything special in the way these "source lines" should be added to |
I would suggest that once this is fully supported that we just add these as sources in our standard rosdep rules. If they've already uncommented it, that should not be a problem. And if they haven't appending shouldn't be a problem. Note for the implementation we should probably be working in our own file in the sources.list.d/ directory. |
Sounds goog. So no special case required. |
Here is a proposal for how to realize this:
http://xylem.readthedocs.org/en/latest/design.html#installer-options
Feel free to comment / discuss in this issue.
The text was updated successfully, but these errors were encountered: