<div dir="ltr"><div>Thanks everyone for your thoughts. I have opened an issue here:</div><a href="https://gitlab.haskell.org/ghc/ghc/-/issues/20569">https://gitlab.haskell.org/ghc/ghc/-/issues/20569</a><br><div><br></div><div>Best,</div><div>Facundo</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sat, Oct 23, 2021 at 11:18 PM Evan Laforge <<a href="mailto:qdunkan@gmail.com">qdunkan@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">The issue uses consistency with -odir and -hieDir as a<br>
rationalization.  I think it's not quite right because inputs can have<br>
a search path while outputs don't, but if it is true that -odir<br>
simultaneously sets the output and input dir for `*.o`, that seems<br>
confusing too.  Shouldn't -odir set *only* output, and all inputs<br>
should either be lumped under the `-i` search path, or even split up<br>
into separate flags as outputs are?  If you are building in --make<br>
mode then you will naturally want to read .o files from the last place<br>
you wrote them, but in that case you can explicitly say so.  I'm not<br>
actually advocating for this since I don't have a use for it at the<br>
moment, and I don't want to potentially break every single user of ghc<br>
--make, but it seemed to me that the argument for consistency could<br>
run the other direction.<br>
<br>
I think this issue is coming up due to a mismatch between the<br>
traditional Make style builds which assume a single mutable input and<br>
output directory, and the newer functional / hermetic style builds<br>
which require immutable inputs and a mutable output.  It's a familiar<br>
concept, just transposed to the file system!<br>
_______________________________________________<br>
ghc-devs mailing list<br>
<a href="mailto:ghc-devs@haskell.org" target="_blank">ghc-devs@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs</a><br>
</blockquote></div>