Skip to content
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

New kind of dependencies #2

Open
bobot opened this issue Jun 18, 2013 · 1 comment
Open

New kind of dependencies #2

bobot opened this issue Jun 18, 2013 · 1 comment

Comments

@bobot
Copy link

bobot commented Jun 18, 2013

Feature wish: Currently the content of a file can only depend on the content of other files. However you can need to state that the content of a file depend on the presence or absence of a file. One example is the construction in ocaml of a .cmo that depend on the presence of a .mli.

One question is what if a dependency doesn't exists but it can be built. Do we try to build it when a rule states that it depends on the presence of the file. What if finally there is an error during the construction of the dependency?

@silene
Copy link
Owner

silene commented Jun 18, 2013

I think your example is a bit off. A .cmo file does not depend on the presence of a .mli file, it depends on its absence. Currently, if a .cmo file is originally built in the absence of a .mli file and if one is later added, the .cmo file will not be rebuilt, yet it now depends on the .cmi file built from the .mli file. Thus, the rule for a .cmo file should ideally look like the following, with --missing indicating to remake that the target becomes obsolete if the argument ever appears.

%.cmo: %.ml
    test -f $<i || remake --missing $<i
    ocamldep $< | remake -r $@
    ocamlc -c $<

At least for this example, I don't think the prerequisite can be built. But you are right that, in general, there is an issue if a rule depends on the absence of a prerequisite, since this prerequisite might well be built independently. The only solution I can come with is that remake --missing should error out if there exists a rule for building the prerequisite.

Note: --missing is not meant to be a well-thought way of indicating absence of prerequisite.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants