430 lines
13 KiB
Makefile
430 lines
13 KiB
Makefile
######################################################################
|
|
# Testing variables
|
|
######################################################################
|
|
|
|
ALL_TEST_INPUTS = $(wildcard $(S)src/test/*/*.rs \
|
|
$(S)src/test/*/*/*.rs \
|
|
$(S)src/test/*/*.rc)
|
|
|
|
RPASS_RC := $(wildcard $(S)src/test/run-pass/*.rc)
|
|
RPASS_RS := $(wildcard $(S)src/test/run-pass/*.rs)
|
|
RFAIL_RC := $(wildcard $(S)src/test/run-fail/*.rc)
|
|
RFAIL_RS := $(wildcard $(S)src/test/run-fail/*.rs)
|
|
CFAIL_RC := $(wildcard $(S)src/test/compile-fail/*.rc)
|
|
CFAIL_RS := $(wildcard $(S)src/test/compile-fail/*.rs)
|
|
BENCH_RS := $(wildcard $(S)src/test/bench/*.rs)
|
|
PRETTY_RS := $(wildcard $(S)src/test/pretty/*.rs)
|
|
|
|
# perf tests are the same as bench tests only they run under
|
|
# a performance monitor.
|
|
PERF_RS := $(wildcard $(S)src/test/bench/*.rs)
|
|
|
|
RPASS_TESTS := $(RPASS_RC) $(RPASS_RS)
|
|
RFAIL_TESTS := $(RFAIL_RC) $(RFAIL_RS)
|
|
CFAIL_TESTS := $(CFAIL_RC) $(CFAIL_RS)
|
|
BENCH_TESTS := $(BENCH_RS)
|
|
PERF_TESTS := $(PERF_RS)
|
|
PRETTY_TESTS := $(PRETTY_RS)
|
|
|
|
FT := run_pass_stage2
|
|
FT_LIB := $(call CFG_LIB_NAME,$(FT))
|
|
FT_DRIVER := $(FT)_driver
|
|
|
|
# The arguments to all test runners
|
|
ifdef TESTNAME
|
|
TESTARGS += $(TESTNAME)
|
|
endif
|
|
|
|
ifdef CHECK_XFAILS
|
|
TESTARGS += --ignored
|
|
endif
|
|
|
|
# Arguments to the cfail/rfail/rpass/bench tests
|
|
ifdef CFG_VALGRIND
|
|
CTEST_RUNTOOL = --runtool "$(CFG_VALGRIND)"
|
|
endif
|
|
|
|
# Arguments to the perf tests
|
|
ifdef CFG_PERF_TOOL
|
|
CTEST_PERF_RUNTOOL = --runtool "$(CFG_PERF_TOOL)"
|
|
endif
|
|
|
|
CTEST_TESTARGS := $(TESTARGS)
|
|
|
|
ifdef VERBOSE
|
|
CTEST_TESTARGS += --verbose
|
|
endif
|
|
|
|
# The standard library test crate
|
|
STDTEST_CRATE := $(S)src/test/stdtest/stdtest.rc
|
|
STDTEST_INPUTS := $(wildcard $(S)src/test/stdtest/*rs)
|
|
|
|
# Run the compiletest runner itself under valgrind
|
|
ifdef CTEST_VALGRIND
|
|
CFG_RUN_CTEST=$(call CFG_RUN_TEST,$(2),$(3))
|
|
else
|
|
CFG_RUN_CTEST=$(call CFG_RUN,$(TLIB$(1)_T_$(3)_H_$(3)),$(2))
|
|
endif
|
|
|
|
######################################################################
|
|
# Main test targets
|
|
######################################################################
|
|
|
|
check: tidy check-stage2 \
|
|
|
|
check-full: tidy check-stage1 check-stage2 check-stage3 \
|
|
|
|
# Run the tidy script in multiple parts to avoid huge 'echo' commands
|
|
ifdef CFG_NOTIDY
|
|
tidy:
|
|
else
|
|
tidy:
|
|
@$(call E, check: formatting)
|
|
$(Q)echo \
|
|
$(addprefix $(S)src/, $(RUSTLLVM_LIB_CS) $(RUSTLLVM_OBJS_CS) \
|
|
$(RUSTLLVM_HDR) \
|
|
$(RUNTIME_CS) $(RUNTIME_HDR) $(RUNTIME_S)) \
|
|
$(wildcard $(S)src/etc/*.py) \
|
|
$(COMPILER_CRATE) \
|
|
$(COMPILER_INPUTS) \
|
|
$(STDLIB_CRATE) \
|
|
$(STDLIB_INPUTS) \
|
|
$(COMPILETEST_CRATE) \
|
|
$(COMPILETEST_INPUTS) \
|
|
| xargs -n 10 python $(S)src/etc/tidy.py
|
|
$(Q)echo \
|
|
$(ALL_TEST_INPUTS) \
|
|
| xargs -n 10 python $(S)src/etc/tidy.py
|
|
endif
|
|
|
|
######################################################################
|
|
# Rules for the test runners
|
|
######################################################################
|
|
|
|
define TEST_STAGEN
|
|
|
|
# All the per-stage build rules you might want to call from the
|
|
# command line.
|
|
#
|
|
# $(1) is the stage number
|
|
# $(2) is the target triple to test
|
|
# $(3) is the host triple to test
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3): tidy \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rustc \
|
|
check-stage$(1)-T-$(2)-H-$(3)-std \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rpass \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rfail \
|
|
check-stage$(1)-T-$(2)-H-$(3)-cfail \
|
|
check-stage$(1)-T-$(2)-H-$(3)-bench \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-std: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-std-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rustc: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rustc-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-cfail: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-cfail-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rfail: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rfail-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rpass: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-rpass-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-bench: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-bench-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-perf: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-perf-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rfail \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-bench \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-pretty
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rfail: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rfail-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-bench: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-bench-dummy
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-pretty: \
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-pretty-dummy
|
|
|
|
# Rules for the standard library test runner
|
|
|
|
$(3)/test/stdtest.stage$(1)-$(2)$$(X): \
|
|
$$(STDTEST_CRATE) $$(STDTEST_INPUTS) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3))
|
|
@$$(call E, compile_and_link: $$@)
|
|
$$(STAGE$(1)_T_$(2)_H_$(3)) -o $$@ $$< --test
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-std-dummy: \
|
|
$(3)/test/stdtest.stage$(1)-$(2)$$(X)
|
|
@$$(call E, run: $$<)
|
|
$$(Q)$$(call CFG_RUN_TEST,$$<,$(2),$(3)) $$(TESTARGS)
|
|
|
|
# Rules for the rustc test runner
|
|
|
|
$(3)/test/rustctest.stage$(1)-$(2)$$(X): \
|
|
$$(COMPILER_CRATE) \
|
|
$$(COMPILER_INPUTS) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(TLIB$(1)_T_$(2)_H_$(3))/$$(CFG_RUSTLLVM)
|
|
@$$(call E, compile_and_link: $$@)
|
|
$$(STAGE$(1)_T_$(2)_H_$(3)) -o $$@ $$< --test
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rustc-dummy: \
|
|
$(3)/test/rustctest.stage$(1)-$(2)$$(X)
|
|
@$$(call E, run: $$<)
|
|
$$(Q)$$(call CFG_RUN_TEST,$$<,$(2),$(3)) $$(TESTARGS)
|
|
|
|
# Rules for the cfail/rfail/rpass/bench/perf test runner
|
|
|
|
CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
--compile-lib-path $$(HLIB$(1)_H_$(3)) \
|
|
--run-lib-path $$(TLIB$(1)_T_$(2)_H_$(3)) \
|
|
--rustc-path $$(HBIN$(1)_H_$(3))/rustc$$(X) \
|
|
--stage-id stage$(1)-$(2) \
|
|
--rustcflags "$$(CFG_RUSTC_FLAGS) --target=$(2)" \
|
|
$$(CTEST_TESTARGS)
|
|
|
|
CFAIL_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/compile-fail/ \
|
|
--build-base $(3)/test/compile-fail/ \
|
|
--mode compile-fail
|
|
|
|
RFAIL_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/run-fail/ \
|
|
--build-base $(3)/test/run-fail/ \
|
|
--mode run-fail \
|
|
$$(CTEST_RUNTOOL)
|
|
|
|
RPASS_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/run-pass/ \
|
|
--build-base $(3)/test/run-pass/ \
|
|
--mode run-pass \
|
|
$$(CTEST_RUNTOOL)
|
|
|
|
BENCH_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/bench/ \
|
|
--build-base $(3)/test/bench/ \
|
|
--mode run-pass \
|
|
$$(CTEST_RUNTOOL)
|
|
|
|
PERF_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/bench/ \
|
|
--build-base $(3)/test/perf/ \
|
|
--mode run-pass \
|
|
$$(CTEST_PERF_RUNTOOL)
|
|
|
|
PRETTY_RPASS_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/run-pass/ \
|
|
--build-base $(3)/test/run-pass/ \
|
|
--mode pretty
|
|
|
|
PRETTY_RFAIL_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/run-fail/ \
|
|
--build-base $(3)/test/run-fail/ \
|
|
--mode pretty
|
|
|
|
PRETTY_BENCH_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/bench/ \
|
|
--build-base $(3)/test/bench/ \
|
|
--mode pretty
|
|
|
|
PRETTY_PRETTY_ARGS$(1)-T-$(2)-H-$(3) := \
|
|
$$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
|
|
--src-base $$(S)src/test/pretty/ \
|
|
--build-base $(3)/test/pretty/ \
|
|
--mode pretty
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-cfail-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(CFAIL_TESTS)
|
|
@$$(call E, run cfail: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(CFAIL_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rfail-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(RFAIL_TESTS)
|
|
@$$(call E, run rfail: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(RFAIL_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-rpass-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(RPASS_TESTS)
|
|
@$$(call E, run rpass: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(RPASS_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-bench-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(BENCH_TESTS)
|
|
@$$(call E, run bench: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(BENCH_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-perf-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(BENCH_TESTS)
|
|
@$$(call E, perf: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(PERF_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(RPASS_TESTS)
|
|
@$$(call E, run pretty-rpass: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(PRETTY_RPASS_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-rfail-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(RFAIL_TESTS)
|
|
@$$(call E, run pretty-rfail: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(PRETTY_RFAIL_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-bench-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(BENCH_TESTS)
|
|
@$$(call E, run pretty-bench: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(PRETTY_BENCH_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
check-stage$(1)-T-$(2)-H-$(3)-pretty-pretty-dummy: \
|
|
$$(HBIN$(1)_H_$(3))/compiletest$$(X) \
|
|
$$(SREQ$(1)_T_$(2)_H_$(3)) \
|
|
$$(PRETTY_TESTS)
|
|
@$$(call E, run pretty-pretty: $$<)
|
|
$$(Q)$$(call CFG_RUN_CTEST,$(1),$$<,$(3)) \
|
|
$$(PRETTY_PRETTY_ARGS$(1)-T-$(2)-H-$(3))
|
|
|
|
endef
|
|
|
|
# Instantiate the template for stage 0, 1, 2, 3
|
|
|
|
$(foreach host,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(foreach target,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(foreach stage,$(STAGES), \
|
|
$(eval $(call TEST_STAGEN,$(stage),$(target),$(host))))))))
|
|
|
|
######################################################################
|
|
# Fast-test rules
|
|
######################################################################
|
|
|
|
GENERATED += tmp/$$(FT).rc tmp/$$(FT_DRIVER).rs
|
|
|
|
tmp/$(FT).rc tmp/$(FT_DRIVER).rs: \
|
|
$(TEST_RPASS_SOURCES_STAGE2) \
|
|
$(S)src/etc/combine-tests.py
|
|
@$(call E, check: building combined stage2 test runner)
|
|
$(Q)$(S)src/etc/combine-tests.py
|
|
|
|
define DEF_CHECK_FAST_FOR_T_H
|
|
# $(1) unused
|
|
# $(2) target triple
|
|
# $(3) host triple
|
|
|
|
$$(TLIB2_T_$(2)_H_$(3))/$$(FT_LIB): \
|
|
tmp/$$(FT).rc \
|
|
$$(SREQ2_T_$(2)_H_$(3))
|
|
@$$(call E, compile_and_link: $$@)
|
|
$$(STAGE2_T_$(2)_H_$(3)) --lib -o $$@ $$<
|
|
|
|
$(3)/test/$$(FT_DRIVER)-$(2)$$(X): \
|
|
tmp/$$(FT_DRIVER).rs \
|
|
$$(TLIB2_T_$(2)_H_$(3))/$$(FT_LIB) \
|
|
$$(SREQ2_T_$(2)_H_$(3))
|
|
@$$(call E, compile_and_link: $$@ $$<)
|
|
$$(STAGE2_T_$(2)_H_$(3)) -L $$(TLIB2_T_$(2)_H_$(3)) -o $$@ $$<
|
|
|
|
$(3)/test/$$(FT_DRIVER)-$(2).out: \
|
|
$(3)/test/$$(FT_DRIVER)-$(2)$$(X) \
|
|
$$(SREQ2_T_$(2)_H_$(3))
|
|
$$(Q)$$(call CFG_RUN_TEST,$$<,$(2),$(3))
|
|
|
|
check-fast-T-$(2)-H-$(3): tidy \
|
|
check-stage2-T-$(2)-H-$(3)-rustc \
|
|
check-stage2-T-$(2)-H-$(3)-std \
|
|
$(3)/test/$$(FT_DRIVER)-$(2).out
|
|
|
|
endef
|
|
|
|
$(foreach host,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(foreach target,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(call DEF_CHECK_FAST_FOR_T_H,,$(target),$(host))))))
|
|
|
|
######################################################################
|
|
# Shortcut rules
|
|
######################################################################
|
|
|
|
define DEF_CHECK_FOR_STAGE_H
|
|
|
|
check-stage$(1)-H-$(2): check-stage$(1)-T-$(2)-H-$(2)
|
|
check-stage$(1)-H-$(2)-perf: check-stage$(1)-T-$(2)-H-$(2)-perf
|
|
check-stage$(1)-H-$(2)-rustc: check-stage$(1)-T-$(2)-H-$(2)-rustc
|
|
check-stage$(1)-H-$(2)-std: check-stage$(1)-T-$(2)-H-$(2)-std
|
|
check-stage$(1)-H-$(2)-rpass: check-stage$(1)-T-$(2)-H-$(2)-rpass
|
|
check-stage$(1)-H-$(2)-rfail: check-stage$(1)-T-$(2)-H-$(2)-rfail
|
|
check-stage$(1)-H-$(2)-cfail: check-stage$(1)-T-$(2)-H-$(2)-cfail
|
|
check-stage$(1)-H-$(2)-bench: check-stage$(1)-T-$(2)-H-$(2)-bench
|
|
|
|
endef
|
|
|
|
$(foreach stage,$(STAGES), \
|
|
$(eval $(foreach target,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(call DEF_CHECK_FOR_STAGE_H,$(stage),$(target))))))
|
|
|
|
define DEF_CHECK_FAST_FOR_H
|
|
|
|
check-fast-H-$(1): check-fast-T-$(1)-H-$(1)
|
|
|
|
endef
|
|
|
|
$(foreach target,$(CFG_TARGET_TRIPLES), \
|
|
$(eval $(call DEF_CHECK_FAST_FOR_H,$(target))))
|
|
|
|
define DEF_CHECK_FOR_STAGE
|
|
|
|
check-stage$(1): check-stage$(1)-H-$(CFG_HOST_TRIPLE)
|
|
check-stage$(1)-perf: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-perf
|
|
check-stage$(1)-rustc: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-rustc
|
|
check-stage$(1)-std: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-std
|
|
check-stage$(1)-rpass: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-rpass
|
|
check-stage$(1)-rfail: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-rfail
|
|
check-stage$(1)-cfail: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-cfail
|
|
check-stage$(1)-bench: check-stage$(1)-H-$(CFG_HOST_TRIPLE)-bench
|
|
|
|
endef
|
|
|
|
$(foreach stage,$(STAGES), \
|
|
$(eval $(call DEF_CHECK_FOR_STAGE,$(stage))))
|
|
|
|
check-fast: check-fast-H-$(CFG_HOST_TRIPLE) |