Package manager - interacting with the compiler
jdrewsen
jdrewsen at nospam.com
Sat Dec 10 13:17:44 PST 2011
On Saturday, 10 December 2011 at 08:55:57 UTC, Jacob Carlborg
wrote:
> I think I've come so far in my development of a package manager
> that it's time to think how it should interact with the
> compiler.
>
> Currently I see two use cases:
>
> 1. When the package manager installs (and builds) a package
>
> 2. When a user (developer) builds a project and want's to use
> installed packages
>
> In the best of worlds the user wouldn't have to do anything and
> it just works. The package manger needs to somehow pass import
> paths to the compiler and libraries to link with.
>
> I'm not entirely sure what the best method to do this would be.
> But I'm thinking that if the compiler could accept compiler
> flags passed via environment variables use case 1 would be easy
> to implement.
>
> For use case 2 it would be a bit more problematic. In this use
> case the user would need to somehow tell the package manager
> that I want to use these packages, something like:
>
> // project.obspec
> orb "foo"
> orb "bar"
>
> $ orb use project.obspec
>
> or for single packages
>
> $ orb use foobar
> $ dmd project.d
>
> If environment variables are used in this case, then the
> package manager would need a shell script wrapper, the same way
> as DVM does it, to be able to set environment variables for the
> parent (the shell). The reason for this is that a child process
> (the package manager) can't set environment variables for the
> parent process (the shell). This complicates the implementation
> and installation of the package manager and requires different
> implementations for Posix and Windows.
>
> Another idea would be to manipulate the dmd.conf/sc.ini file
> but that seems to be quite complicated and messy. On the other
> hand, this wouldn't require any changes to the compiler.
>
> Any other ideas?
>
> https://github.com/jacob-carlborg/orbit/wiki/Orbit-Package-Manager-for-D
> https://github.com/jacob-carlborg/orbit
For use case 1 the package manager could just as well call dmd
directly with the correct flags ie. no need for using environment
variables. Use case 2 does not belong to a package manager in my
opinion. It is the job of a build tool to configure packages for
a project. What would be nice to have support for using packages
without a build tool. Maybe something like what pkg-config
provides:
dmd -ofhello `orb -lib foo` hello.d where "org -lib foo"
returns the flags to use the foo package.
/Jonas
More information about the Digitalmars-d
mailing list