mk: Improve build system help commands
This commit is contained in:
parent
ab17f445fe
commit
334af011f0
112
Makefile.in
112
Makefile.in
@ -8,55 +8,100 @@
|
|||||||
# option. This file may not be copied, modified, or distributed
|
# option. This file may not be copied, modified, or distributed
|
||||||
# except according to those terms.
|
# except according to those terms.
|
||||||
|
|
||||||
# <help>
|
# <help> \(^o^)/
|
||||||
#
|
#
|
||||||
# # The Rust Build System
|
# Greetings, adventurer! The Rust Build System is at your service.
|
||||||
#
|
#
|
||||||
# Start with these these build targets:
|
# Whether you want a genuine copy of `rustc`, access to the latest and
|
||||||
|
# most authoritative Rust documentation, or even to investigate the
|
||||||
|
# most intimate workings of the compiler itself, you've come to the
|
||||||
|
# right place. Let's see what's on the menu.
|
||||||
#
|
#
|
||||||
# * all - The default rule. Builds a complete stage2 compiler, std,
|
# First, start with one of these build targets:
|
||||||
# and extra for all hosts and targets
|
#
|
||||||
# * docs - Generate HTML documentation for the std and extra libraries
|
# * all - The default. Builds a complete, bootstrapped compiler.
|
||||||
# from source code comments
|
# `rustc` will be in `${target-triple}/stage2/bin/`. Run it
|
||||||
# * rustc - The stage 2 compiler for the build platform with standard
|
# directly from the build directory if you like. This also
|
||||||
# and extra libraries
|
# comes with docs in `doc/`.
|
||||||
# * install
|
#
|
||||||
# * uninstall
|
# * check - Run the complete test suite
|
||||||
# * check - Run tests
|
#
|
||||||
# * check-stage1-$(crate) - Run tests for a crate, e.g. `check-stage1-std`
|
# * install - Install Rust. Note that installation is not necessary
|
||||||
# * check-stage1-rpass - Run the language tests
|
# to use the compiler.
|
||||||
# * check-docs - Run the doc tests
|
#
|
||||||
|
# * uninstall - Uninstall the binaries
|
||||||
|
#
|
||||||
|
# For hot tips on working with The Rust Build System, just:
|
||||||
|
#
|
||||||
|
# type `make hot-tips`
|
||||||
|
#
|
||||||
|
# Otherwise
|
||||||
|
#
|
||||||
|
# type `make`
|
||||||
|
#
|
||||||
|
# </help>
|
||||||
|
#
|
||||||
|
# <hottips>
|
||||||
|
#
|
||||||
|
# # The Rust Build System Tip Line
|
||||||
|
#
|
||||||
|
# There are a bazillion different targets you might want to build. Here
|
||||||
|
# are a few ideas.
|
||||||
|
#
|
||||||
|
# * docs - Build gobs of HTML documentation and put it into `doc/`
|
||||||
|
# * check-$(crate) - Test a crate, e.g. `check-std`
|
||||||
|
# * check-ref - Run the language reference tests
|
||||||
|
# * check-docs - Test the documentation examples
|
||||||
|
#
|
||||||
|
# TODO: Lots more
|
||||||
#
|
#
|
||||||
# Then mix in some of these environment variables to harness the
|
# Then mix in some of these environment variables to harness the
|
||||||
# ultimate power of Rust Build System.
|
# ultimate power of The Rust Build System.
|
||||||
#
|
#
|
||||||
# * `VERBOSE=1` - Print all commands. Use this to see what's going on.
|
# * `VERBOSE=1` - Print all commands. Use this to see what's going on.
|
||||||
# * `RUSTFLAGS=...` - Add compiler flags to all `rustc` invocations
|
# * `RUSTFLAGS=...` - Add compiler flags to all `rustc` invocations
|
||||||
# * `CFG_ENABLE_VALGRIND=1` - Run tests under valgrind
|
#
|
||||||
# * `VALGRIND_COMPILE=1` - Run the compiler itself under valgrind
|
# * `TESTNAME=...` - Specify the name of tests to run
|
||||||
# (may require `CFG_ENABLE_VALGRIND`)
|
# * `CHECK_IGNORED=1` - Run normally-ignored tests
|
||||||
# * `NO_REBUILD=1` - Don't rebootstrap when testing std
|
# * `NO_BENCH=1` - Don't run crate benchmarks (disable `--bench` flag)
|
||||||
# (and possibly other crates)
|
#
|
||||||
# * `NO_MKFILE_DEPS=1` - Don rebuild for modified .mk files
|
# * `CFG_ENABLE_VALGRIND=1` - Run tests under valgrind
|
||||||
# * `SAVE_TEMPS=1` - Use `--save-temps` flag on all `rustc` invocations
|
# * `VALGRIND_COMPILE=1` - Run the compiler itself under valgrind
|
||||||
# * `ASM_COMMENTS=1` - Use `-Z asm-comments`
|
# (may require `CFG_ENABLE_VALGRIND`)
|
||||||
# * `TIME_PASSES=1` - Use `-Z time-passes`
|
#
|
||||||
# * `TIME_LLVM_PASSES=1` - Use `-Z time-llvm-passes`
|
# * `NO_REBUILD=1` - Don't rebootstrap when testing std
|
||||||
# * `TRACE=1` - Use `-Z trace`
|
# (and possibly other crates)
|
||||||
|
# * `NO_MKFILE_DEPS=1` - Don rebuild for modified .mk files
|
||||||
|
#
|
||||||
|
# * `SAVE_TEMPS=1` - Use `--save-temps` flag on all `rustc` invocations
|
||||||
|
# * `ASM_COMMENTS=1` - Use `-Z asm-comments`
|
||||||
|
# * `TIME_PASSES=1` - Use `-Z time-passes`
|
||||||
|
# * `TIME_LLVM_PASSES=1` - Use `-Z time-llvm-passes`
|
||||||
|
# * `TRACE=1` - Use `-Z trace`
|
||||||
#
|
#
|
||||||
# This is hardly all there is to know of The Rust Build System's
|
# This is hardly all there is to know of The Rust Build System's
|
||||||
# mysteries. Your journey continues on the wiki[1][2].
|
# mysteries. The tale continues on the wiki[1][2].
|
||||||
#
|
#
|
||||||
# [1]: https://github.com/mozilla/rust/wiki/Note-build-system
|
# [1]: https://github.com/mozilla/rust/wiki/Note-build-system
|
||||||
# [2]: https://github.com/mozilla/rust/wiki/Note-testsuite
|
# [2]: https://github.com/mozilla/rust/wiki/Note-testsuite
|
||||||
#
|
#
|
||||||
# </help>
|
# Unless you feel like getting your hands dirty, then:
|
||||||
|
#
|
||||||
|
# don't type `make nitty-gritty`
|
||||||
|
#
|
||||||
|
# </hottips>
|
||||||
|
#
|
||||||
|
# <nittygritty>
|
||||||
|
#
|
||||||
|
# # The Rust Build System
|
||||||
|
#
|
||||||
|
# Gosh I wish there was something useful here (TODO).
|
||||||
#
|
#
|
||||||
# # An (old) explanation of how the build is structured:
|
# # An (old) explanation of how the build is structured:
|
||||||
#
|
#
|
||||||
# *Note: Hey, like, this is probably inaccurate, and is definitely
|
# *Note: Hey, like, this is probably inaccurate, and is definitely
|
||||||
# an outdated and insufficient explanation of the remarkable
|
# an outdated and insufficient explanation of the remarkable
|
||||||
# and discomfiting Rust Build System.*
|
# Rust Build System.*
|
||||||
#
|
#
|
||||||
# There are multiple build stages (0-3) needed to verify that the
|
# There are multiple build stages (0-3) needed to verify that the
|
||||||
# compiler is properly self-hosting. Each stage is divided between
|
# compiler is properly self-hosting. Each stage is divided between
|
||||||
@ -99,6 +144,9 @@
|
|||||||
# will just link against the libraries in the target lib directory.
|
# will just link against the libraries in the target lib directory.
|
||||||
#
|
#
|
||||||
# Admittedly this is a little convoluted.
|
# Admittedly this is a little convoluted.
|
||||||
|
#
|
||||||
|
# </nittygritty>
|
||||||
|
#
|
||||||
|
|
||||||
######################################################################
|
######################################################################
|
||||||
# Primary rules
|
# Primary rules
|
||||||
|
2
configure
vendored
2
configure
vendored
@ -1103,3 +1103,5 @@ rm -f config.tmp
|
|||||||
touch config.stamp
|
touch config.stamp
|
||||||
|
|
||||||
step_msg "complete"
|
step_msg "complete"
|
||||||
|
msg "type \`make help\`"
|
||||||
|
msg
|
||||||
|
18
mk/main.mk
18
mk/main.mk
@ -428,8 +428,20 @@ ALL_TARGET_RULES = $(foreach target,$(CFG_TARGET), \
|
|||||||
|
|
||||||
all: $(ALL_TARGET_RULES) $(GENERATED) docs
|
all: $(ALL_TARGET_RULES) $(GENERATED) docs
|
||||||
|
|
||||||
help:
|
######################################################################
|
||||||
# Show the comments from Makefile.in as "help"
|
# Build system documentation
|
||||||
|
######################################################################
|
||||||
|
|
||||||
|
# $(1) is the name of the doc <section> in Makefile.in
|
||||||
# pick everything between tags | remove first line | remove last line
|
# pick everything between tags | remove first line | remove last line
|
||||||
# | remove extra (?) line | strip leading `#` from lines
|
# | remove extra (?) line | strip leading `#` from lines
|
||||||
$(Q)awk '/<help>/,/<\/help>/' $(S)/Makefile.in | sed '1d' | sed '$$d' | sed 's/^# \?//'
|
SHOW_DOCS = $(Q)awk '/$(1)/,/<\/$(1)>/' $(S)/Makefile.in | sed '1d' | sed '$$d' | sed 's/^\# \?//'
|
||||||
|
|
||||||
|
help:
|
||||||
|
$(call SHOW_DOCS,help)
|
||||||
|
|
||||||
|
hot-tips:
|
||||||
|
$(call SHOW_DOCS,hottips)
|
||||||
|
|
||||||
|
nitty-gritty:
|
||||||
|
$(call SHOW_DOCS,nittygritty)
|
||||||
|
@ -190,6 +190,10 @@ check-lite: cleantestlibs cleantmptestlogs \
|
|||||||
check-stage2-rfail check-stage2-cfail check-stage2-rmake
|
check-stage2-rfail check-stage2-cfail check-stage2-rmake
|
||||||
$(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
|
$(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
|
||||||
|
|
||||||
|
check-ref: cleantestlibs cleantmptestlogs check-stage2-rpass \
|
||||||
|
check-stage2-rfail check-stage2-cfail check-stage2-rmake
|
||||||
|
$(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
|
||||||
|
|
||||||
.PHONY: cleantmptestlogs cleantestlibs
|
.PHONY: cleantmptestlogs cleantestlibs
|
||||||
|
|
||||||
cleantmptestlogs:
|
cleantmptestlogs:
|
||||||
|
Loading…
Reference in New Issue
Block a user