2013-10-11 20:21:46 +02:00
|
|
|
# Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
|
2012-12-10 17:32:48 -08:00
|
|
|
# file at the top-level directory of this distribution and at
|
|
|
|
# http://rust-lang.org/COPYRIGHT.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
# <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
# option. This file may not be copied, modified, or distributed
|
|
|
|
# except according to those terms.
|
|
|
|
|
2011-05-01 20:18:52 +00:00
|
|
|
######################################################################
|
2014-12-02 09:20:48 -05:00
|
|
|
# The various pieces of standalone documentation.
|
2014-03-09 01:41:31 +11:00
|
|
|
#
|
|
|
|
# The DOCS variable is their names (with no file extension).
|
|
|
|
#
|
|
|
|
# RUSTDOC_FLAGS_xyz variables are extra arguments to pass to the
|
|
|
|
# rustdoc invocation for xyz.
|
|
|
|
#
|
|
|
|
# RUSTDOC_DEPS_xyz are extra dependencies for the rustdoc invocation
|
|
|
|
# on xyz.
|
|
|
|
#
|
|
|
|
# L10N_LANGS are the languages for which the docs have been
|
|
|
|
# translated.
|
2011-05-01 20:18:52 +00:00
|
|
|
######################################################################
|
2015-11-03 12:46:06 -08:00
|
|
|
DOCS := index \
|
2014-12-02 09:20:48 -05:00
|
|
|
complement-lang-faq complement-design-faq complement-project-faq \
|
2015-02-13 18:00:00 -05:00
|
|
|
rustdoc reference grammar
|
2014-03-09 01:41:31 +11:00
|
|
|
|
2015-01-09 19:47:09 +11:00
|
|
|
# Legacy guides, preserved for a while to reduce the number of 404s
|
|
|
|
DOCS += guide-crates guide-error-handling guide-ffi guide-macros guide \
|
|
|
|
guide-ownership guide-plugins guide-pointers guide-strings guide-tasks \
|
2015-11-03 12:46:06 -08:00
|
|
|
guide-testing tutorial intro
|
2015-01-09 19:47:09 +11:00
|
|
|
|
|
|
|
|
2014-11-07 00:01:45 +01:00
|
|
|
RUSTDOC_DEPS_reference := doc/full-toc.inc
|
|
|
|
RUSTDOC_FLAGS_reference := --html-in-header=doc/full-toc.inc
|
2014-03-09 01:41:31 +11:00
|
|
|
|
|
|
|
L10N_LANGS := ja
|
|
|
|
|
|
|
|
# Generally no need to edit below here.
|
2011-05-01 20:18:52 +00:00
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
# The options are passed to the documentation generators.
|
2014-06-28 03:35:25 -07:00
|
|
|
RUSTDOC_HTML_OPTS_NO_CSS = --html-before-content=doc/version_info.html \
|
|
|
|
--html-in-header=doc/favicon.inc \
|
|
|
|
--html-after-content=doc/footer.inc \
|
2015-08-09 14:15:05 -07:00
|
|
|
--markdown-playground-url='https://play.rust-lang.org/'
|
2011-05-01 20:18:52 +00:00
|
|
|
|
2014-05-14 10:45:51 -07:00
|
|
|
RUSTDOC_HTML_OPTS = $(RUSTDOC_HTML_OPTS_NO_CSS) --markdown-css rust.css
|
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
# The rustdoc executable...
|
|
|
|
RUSTDOC_EXE = $(HBIN2_H_$(CFG_BUILD))/rustdoc$(X_$(CFG_BUILD))
|
|
|
|
# ...with rpath included in case --disable-rpath was provided to
|
|
|
|
# ./configure
|
|
|
|
RUSTDOC = $(RPATH_VAR2_T_$(CFG_BUILD)_H_$(CFG_BUILD)) $(RUSTDOC_EXE)
|
2012-01-12 19:10:30 -08:00
|
|
|
|
2014-12-02 09:20:48 -05:00
|
|
|
# The rustbook executable...
|
|
|
|
RUSTBOOK_EXE = $(HBIN2_H_$(CFG_BUILD))/rustbook$(X_$(CFG_BUILD))
|
|
|
|
# ...with rpath included in case --disable-rpath was provided to
|
|
|
|
# ./configure
|
|
|
|
RUSTBOOK = $(RPATH_VAR2_T_$(CFG_BUILD)_H_$(CFG_BUILD)) $(RUSTBOOK_EXE)
|
|
|
|
|
2016-02-14 22:26:37 -08:00
|
|
|
# The error_index_generator executable...
|
|
|
|
ERR_IDX_GEN_EXE = $(HBIN2_H_$(CFG_BUILD))/error_index_generator$(X_$(CFG_BUILD))
|
2015-05-03 10:57:41 +10:00
|
|
|
ERR_IDX_GEN = $(RPATH_VAR2_T_$(CFG_BUILD)_H_$(CFG_BUILD)) $(ERR_IDX_GEN_EXE)
|
2016-02-07 13:03:11 +01:00
|
|
|
ERR_IDX_GEN_MD = $(RPATH_VAR2_T_$(CFG_BUILD)_H_$(CFG_BUILD)) $(ERR_IDX_GEN_EXE) markdown
|
2015-05-03 10:57:41 +10:00
|
|
|
|
2014-01-28 14:15:29 -08:00
|
|
|
D := $(S)src/doc
|
|
|
|
|
2015-11-19 11:30:18 -05:00
|
|
|
DOC_TARGETS := book nomicon style error-index
|
2014-03-09 01:41:31 +11:00
|
|
|
COMPILER_DOC_TARGETS :=
|
|
|
|
DOC_L10N_TARGETS :=
|
|
|
|
|
|
|
|
# If NO_REBUILD is set then break the dependencies on rustdoc so we
|
|
|
|
# build the documentation without having to rebuild rustdoc.
|
2016-02-01 23:27:04 -08:00
|
|
|
ifeq ($(NO_REBUILD),)
|
2014-03-09 01:41:31 +11:00
|
|
|
HTML_DEPS := $(RUSTDOC_EXE)
|
|
|
|
else
|
|
|
|
HTML_DEPS :=
|
|
|
|
endif
|
|
|
|
|
2014-01-06 15:38:20 -06:00
|
|
|
######################################################################
|
|
|
|
# Rust version
|
|
|
|
######################################################################
|
2014-01-17 19:38:48 +01:00
|
|
|
|
2014-01-06 15:38:20 -06:00
|
|
|
HTML_DEPS += doc/version_info.html
|
2014-01-28 14:15:29 -08:00
|
|
|
doc/version_info.html: $(D)/version_info.html.template $(MKFILE_DEPS) \
|
|
|
|
$(wildcard $(D)/*.*) | doc/
|
2014-01-06 15:38:20 -06:00
|
|
|
@$(call E, version-info: $@)
|
2014-10-04 14:41:37 -04:00
|
|
|
$(Q)sed -e "s/VERSION/$(CFG_RELEASE)/; \
|
|
|
|
s/SHORT_HASH/$(CFG_SHORT_VER_HASH)/; \
|
2014-01-06 15:38:20 -06:00
|
|
|
s/STAMP/$(CFG_VER_HASH)/;" $< >$@
|
|
|
|
|
2015-08-11 20:12:11 -04:00
|
|
|
GENERATED += doc/version_info.html
|
2014-01-06 15:38:20 -06:00
|
|
|
|
2012-01-18 14:14:28 -08:00
|
|
|
######################################################################
|
2015-08-11 20:12:11 -04:00
|
|
|
# Docs from rustdoc
|
2012-01-18 14:14:28 -08:00
|
|
|
######################################################################
|
2012-03-20 17:50:32 -07:00
|
|
|
|
2014-01-28 14:15:29 -08:00
|
|
|
doc/:
|
|
|
|
@mkdir -p $@
|
|
|
|
|
2013-12-22 20:21:45 -06:00
|
|
|
HTML_DEPS += doc/rust.css
|
2014-01-28 14:15:29 -08:00
|
|
|
doc/rust.css: $(D)/rust.css | doc/
|
2012-03-26 17:59:09 -07:00
|
|
|
@$(call E, cp: $@)
|
2015-02-14 14:01:16 +01:00
|
|
|
$(Q)cp -PRp $< $@ 2> /dev/null
|
2012-03-26 17:59:09 -07:00
|
|
|
|
2014-02-07 20:46:39 +01:00
|
|
|
HTML_DEPS += doc/favicon.inc
|
|
|
|
doc/favicon.inc: $(D)/favicon.inc | doc/
|
|
|
|
@$(call E, cp: $@)
|
2015-02-14 14:01:16 +01:00
|
|
|
$(Q)cp -PRp $< $@ 2> /dev/null
|
2014-02-07 20:46:39 +01:00
|
|
|
|
2014-01-28 14:15:29 -08:00
|
|
|
doc/full-toc.inc: $(D)/full-toc.inc | doc/
|
2012-12-14 18:06:11 -08:00
|
|
|
@$(call E, cp: $@)
|
2015-02-14 14:01:16 +01:00
|
|
|
$(Q)cp -PRp $< $@ 2> /dev/null
|
2012-12-14 18:06:11 -08:00
|
|
|
|
2014-02-07 20:46:39 +01:00
|
|
|
HTML_DEPS += doc/footer.inc
|
|
|
|
doc/footer.inc: $(D)/footer.inc | doc/
|
|
|
|
@$(call E, cp: $@)
|
2015-02-14 14:01:16 +01:00
|
|
|
$(Q)cp -PRp $< $@ 2> /dev/null
|
2014-02-07 20:46:39 +01:00
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
# The (english) documentation for each doc item.
|
2014-05-14 10:45:51 -07:00
|
|
|
DOC_TARGETS += doc/not_found.html
|
|
|
|
doc/not_found.html: $(D)/not_found.md $(HTML_DEPS) | doc/
|
2014-06-01 11:09:30 -07:00
|
|
|
@$(call E, rustdoc: $@)
|
|
|
|
$(Q)$(RUSTDOC) $(RUSTDOC_HTML_OPTS_NO_CSS) \
|
2015-06-09 15:47:48 -04:00
|
|
|
--markdown-no-toc \
|
2015-08-09 14:15:05 -07:00
|
|
|
--markdown-css https://doc.rust-lang.org/rust.css $<
|
2014-05-14 10:45:51 -07:00
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
define DEF_DOC
|
|
|
|
|
|
|
|
# HTML (rustdoc)
|
|
|
|
DOC_TARGETS += doc/$(1).html
|
|
|
|
doc/$(1).html: $$(D)/$(1).md $$(HTML_DEPS) $$(RUSTDOC_DEPS_$(1)) | doc/
|
|
|
|
@$$(call E, rustdoc: $$@)
|
2014-06-01 11:09:30 -07:00
|
|
|
$$(Q)$$(RUSTDOC) $$(RUSTDOC_HTML_OPTS) $$(RUSTDOC_FLAGS_$(1)) $$<
|
2014-03-09 01:41:31 +11:00
|
|
|
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach docname,$(DOCS),$(eval $(call DEF_DOC,$(docname))))
|
2013-04-23 22:51:48 -07:00
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
|
2012-01-18 14:14:28 -08:00
|
|
|
######################################################################
|
2013-05-17 10:45:09 -07:00
|
|
|
# Rustdoc (libstd/extra)
|
2012-01-18 14:14:28 -08:00
|
|
|
######################################################################
|
2011-05-01 20:18:52 +00:00
|
|
|
|
2011-12-05 16:46:37 -08:00
|
|
|
|
2012-03-09 22:53:46 -08:00
|
|
|
# The library documenting macro
|
2014-01-24 19:27:22 -08:00
|
|
|
#
|
2013-09-21 23:25:48 -07:00
|
|
|
# $(1) - The crate name (std/extra)
|
2013-11-24 23:31:21 -05:00
|
|
|
#
|
|
|
|
# Passes --cfg stage2 to rustdoc because it uses the stage2 librustc.
|
2014-03-09 01:41:31 +11:00
|
|
|
define DEF_LIB_DOC
|
|
|
|
|
|
|
|
# If NO_REBUILD is set then break the dependencies on rustdoc so we
|
|
|
|
# build crate documentation without having to rebuild rustdoc.
|
2016-02-01 23:27:04 -08:00
|
|
|
ifeq ($(NO_REBUILD),)
|
2014-03-09 01:41:31 +11:00
|
|
|
LIB_DOC_DEP_$(1) = \
|
|
|
|
$$(CRATEFILE_$(1)) \
|
|
|
|
$$(RSINPUTS_$(1)) \
|
|
|
|
$$(RUSTDOC_EXE) \
|
2016-02-08 10:57:41 -08:00
|
|
|
$$(foreach dep,$$(RUST_DEPS_$(1)_T_$(CFG_BUILD)), \
|
2014-12-20 23:29:59 -08:00
|
|
|
$$(TLIB2_T_$(CFG_BUILD)_H_$(CFG_BUILD))/stamp.$$(dep)) \
|
2016-02-08 10:57:41 -08:00
|
|
|
$$(foreach dep,$$(filter $$(DOC_CRATES), $$(RUST_DEPS_$(1)_T_$(CFG_BUILD))), \
|
2014-06-09 13:00:18 -07:00
|
|
|
doc/$$(dep)/)
|
2014-03-09 01:41:31 +11:00
|
|
|
else
|
|
|
|
LIB_DOC_DEP_$(1) = $$(CRATEFILE_$(1)) $$(RSINPUTS_$(1))
|
|
|
|
endif
|
2014-02-06 15:43:27 -08:00
|
|
|
|
2014-06-09 13:00:18 -07:00
|
|
|
doc/$(1)/:
|
|
|
|
$$(Q)mkdir -p $$@
|
|
|
|
|
2014-04-09 02:45:53 +09:00
|
|
|
doc/$(1)/index.html: CFG_COMPILER_HOST_TRIPLE = $(CFG_TARGET)
|
2014-06-09 13:00:18 -07:00
|
|
|
doc/$(1)/index.html: $$(LIB_DOC_DEP_$(1)) doc/$(1)/
|
2014-08-01 16:48:41 -07:00
|
|
|
@$$(call E, rustdoc: $$@)
|
2014-11-25 17:28:49 -06:00
|
|
|
$$(Q)CFG_LLVM_LINKAGE_FILE=$$(LLVM_LINKAGE_PATH_$(CFG_BUILD)) \
|
2015-04-06 15:26:27 -07:00
|
|
|
$$(RUSTDOC) --cfg dox --cfg stage2 $$(RUSTFLAGS_$(1)) $$<
|
2013-12-29 00:13:19 -05:00
|
|
|
endef
|
|
|
|
|
2015-04-07 15:11:16 -07:00
|
|
|
$(foreach crate,$(CRATES),$(eval $(call DEF_LIB_DOC,$(crate))))
|
2015-03-27 23:01:19 -04:00
|
|
|
|
2015-04-07 15:11:16 -07:00
|
|
|
COMPILER_DOC_TARGETS := $(CRATES:%=doc/%/index.html)
|
2015-06-03 00:49:47 +03:00
|
|
|
ifdef CFG_ENABLE_COMPILER_DOCS
|
2015-04-07 15:11:16 -07:00
|
|
|
DOC_TARGETS += $(COMPILER_DOC_TARGETS)
|
|
|
|
else
|
|
|
|
DOC_TARGETS += $(DOC_CRATES:%=doc/%/index.html)
|
2015-03-27 23:01:19 -04:00
|
|
|
endif
|
2012-01-18 14:14:28 -08:00
|
|
|
|
|
|
|
ifdef CFG_DISABLE_DOCS
|
|
|
|
$(info cfg: disabling doc build (CFG_DISABLE_DOCS))
|
2014-03-09 01:41:31 +11:00
|
|
|
DOC_TARGETS :=
|
2014-05-27 20:17:17 -04:00
|
|
|
COMPILER_DOC_TARGETS :=
|
2012-01-18 14:14:28 -08:00
|
|
|
endif
|
|
|
|
|
2014-03-09 01:41:31 +11:00
|
|
|
docs: $(DOC_TARGETS)
|
2015-09-02 18:03:17 -04:00
|
|
|
doc: docs
|
2014-03-09 01:41:31 +11:00
|
|
|
compiler-docs: $(COMPILER_DOC_TARGETS)
|
2014-12-02 09:20:48 -05:00
|
|
|
|
2015-11-19 11:30:18 -05:00
|
|
|
book: doc/book/index.html
|
2014-12-02 09:20:48 -05:00
|
|
|
|
2015-11-19 11:30:18 -05:00
|
|
|
doc/book/index.html: $(RUSTBOOK_EXE) $(wildcard $(S)/src/doc/book/*.md) | doc/
|
2015-02-26 21:00:43 -08:00
|
|
|
@$(call E, rustbook: $@)
|
2014-12-02 09:20:48 -05:00
|
|
|
$(Q)rm -rf doc/book
|
2015-11-19 11:30:18 -05:00
|
|
|
$(Q)$(RUSTBOOK) build $(S)src/doc/book doc/book
|
2015-02-14 12:02:45 -05:00
|
|
|
|
2015-07-31 14:13:59 -07:00
|
|
|
nomicon: doc/nomicon/index.html
|
2015-07-13 23:31:52 -07:00
|
|
|
|
2015-07-31 14:13:59 -07:00
|
|
|
doc/nomicon/index.html: $(RUSTBOOK_EXE) $(wildcard $(S)/src/doc/nomicon/*.md) | doc/
|
2015-07-13 23:31:52 -07:00
|
|
|
@$(call E, rustbook: $@)
|
2015-07-31 14:13:59 -07:00
|
|
|
$(Q)rm -rf doc/nomicon
|
|
|
|
$(Q)$(RUSTBOOK) build $(S)src/doc/nomicon doc/nomicon
|
2015-07-13 23:31:52 -07:00
|
|
|
|
2015-02-14 12:02:45 -05:00
|
|
|
style: doc/style/index.html
|
|
|
|
|
|
|
|
doc/style/index.html: $(RUSTBOOK_EXE) $(wildcard $(S)/src/doc/style/*.md) | doc/
|
2015-02-26 21:00:43 -08:00
|
|
|
@$(call E, rustbook: $@)
|
2015-02-14 12:02:45 -05:00
|
|
|
$(Q)rm -rf doc/style
|
|
|
|
$(Q)$(RUSTBOOK) build $(S)src/doc/style doc/style
|
2015-05-03 10:57:41 +10:00
|
|
|
|
|
|
|
error-index: doc/error-index.html
|
|
|
|
|
2016-02-07 13:03:11 +01:00
|
|
|
# Metadata used to generate the index is created as a side effect of
|
|
|
|
# the build so this depends on every crate being up to date.
|
|
|
|
doc/error-index.html: $(ERR_IDX_GEN_EXE) $(CSREQ$(2)_T_$(CFG_BUILD)_H_$(CFG_BUILD)) | doc/
|
2016-02-14 22:26:37 -08:00
|
|
|
$(Q)$(call E, error_index_generator: $@)
|
2015-05-03 10:57:41 +10:00
|
|
|
$(Q)$(ERR_IDX_GEN)
|
2016-02-07 13:03:11 +01:00
|
|
|
|
|
|
|
doc/error-index.md: $(ERR_IDX_GEN_EXE) $(CSREQ$(2)_T_$(CFG_BUILD)_H_$(CFG_BUILD)) | doc/
|
2016-02-14 22:26:37 -08:00
|
|
|
$(Q)$(call E, error_index_generator: $@)
|
2016-02-07 13:03:11 +01:00
|
|
|
$(Q)$(ERR_IDX_GEN_MD)
|