Closed
Bug 1317778
Opened 8 years ago
Closed 8 years ago
Changing the code that generates config.status may require a clobber
Categories
(Firefox Build System :: General, defect)
Firefox Build System
General
Tracking
(firefox53 fixed)
RESOLVED
FIXED
mozilla53
Tracking | Status | |
---|---|---|
firefox53 | --- | fixed |
People
(Reporter: chmanchester, Unassigned)
References
(Blocks 1 open bug)
Details
Attachments
(1 file)
I found working on bug 1316140 that un-applying that patch can require a clobber, because |./mach build| is trusting that the config.status it finds is up to date.
Comment hidden (mozreview-request) |
Comment 2•8 years ago
|
||
mozreview-review |
Comment on attachment 8811008 [details]
Bug 1317778 - Emit a depfile with python configure dependencies so Make will know when to re-run configure.
https://reviewboard.mozilla.org/r/93266/#review94846
There's actually more than configure.py that can affect config.status (and in fact, configure.py doesn't change enough that adding it manually makes a difference).
We should probably make configure emit a proper dependency file and include it from client.mk.
Attachment #8811008 -
Flags: review?(mh+mozilla) → review-
Comment hidden (mozreview-request) |
Comment 4•8 years ago
|
||
mozreview-review |
Comment on attachment 8811008 [details]
Bug 1317778 - Emit a depfile with python configure dependencies so Make will know when to re-run configure.
https://reviewboard.mozilla.org/r/93266/#review97418
::: configure.py:36
(Diff revision 2)
> if sandbox._help:
> return 0
>
> - return config_status(config)
> + mk = Makefile()
> + rule = mk.create_rule()
> + rule.add_targets([os.path.join(config['TOPSRCDIR'], 'configure'),
It will be better for make to:
- use a literal '$(TOPSRCDIR)', because in some corner cases, config['TOPSRCDIR'] might be different, and that would make the dependencies unused.
- use mozpath instead of os.path, because forward slashes are better.
- and in fact, the right target for the dependencies is not $(TOPSRCDIR)/**/configure, but $(OBJDIR)/config.status.
This should also go into the config_status function.
Attachment #8811008 -
Flags: review?(mh+mozilla)
Comment hidden (mozreview-request) |
Comment 6•8 years ago
|
||
mozreview-review |
Comment on attachment 8811008 [details]
Bug 1317778 - Emit a depfile with python configure dependencies so Make will know when to re-run configure.
https://reviewboard.mozilla.org/r/93266/#review98002
::: client.mk:333
(Diff revision 3)
> $(TOPSRCDIR)/testing/mozbase/packages.txt \
> $(OBJDIR)/.mozconfig.json \
> $(NULL)
>
> +# Include a dep file emitted by configure to track Python files that
> +# may incluence the result of configure.
typo
::: configure.py:36
(Diff revision 3)
> if sandbox._help:
> return 0
>
> - return config_status(config)
> + return config_status(config, sandbox)
>
> -
> +def config_status(config, sandbox):
Mmmmm it would be better if we could avoid the signature change, so that we don't break comm-central. How about a set_config() at the end of moz.configure to be able to grab _all_paths from config instead of sandbox?
But I won't stop you if you don't feel like it's necessary ; after all, that only requires a one-liner in comm-central to be fixed.
Attachment #8811008 -
Flags: review?(mh+mozilla) → review+
Comment hidden (mozreview-request) |
Reporter | ||
Updated•8 years ago
|
Attachment #8811008 -
Flags: review+ → review?(mh+mozilla)
Comment 8•8 years ago
|
||
mozreview-review |
Comment on attachment 8811008 [details]
Bug 1317778 - Emit a depfile with python configure dependencies so Make will know when to re-run configure.
https://reviewboard.mozilla.org/r/93266/#review100554
Sorry for the delay.
Attachment #8811008 -
Flags: review?(mh+mozilla) → review+
Pushed by cmanchester@mozilla.com:
https://hg.mozilla.org/integration/mozilla-inbound/rev/202f46bb664d
Emit a depfile with python configure dependencies so Make will know when to re-run configure. r=glandium
Comment 10•8 years ago
|
||
bugherder |
Status: NEW → RESOLVED
Closed: 8 years ago
status-firefox53:
--- → fixed
Resolution: --- → FIXED
Target Milestone: --- → mozilla53
Updated•7 years ago
|
Product: Core → Firefox Build System
You need to log in
before you can comment on or make changes to this bug.
Description
•