atomic-waitgroup 0.1.4

A waitgroup implementation supports async with advanced features
Documentation
RUNTESTCASE = _run_test_case() {                                                  \
    case="$(filter-out $@,$(MAKECMDGOALS))";                                      \
    if [ -n "$${WORKFLOW}" ]; then \
        export TEST_FLAG=" -- -q --test-threads=1"; \
    else  \
        export TEST_FLAG=" -- --nocapture --test-threads=1"; \
        export LOG_FILE="/tmp/test_wg.log"; \
    fi; \
    if [ -n "$${case}" ]; then                                                    \
        RUST_BACKTRACE=full cargo test $${case} $${FEATURE_FLAG} $${TEST_FLAG};    \
    else  \
        RUST_BACKTRACE=full cargo test $${FEATURE_FLAG} $${TEST_FLAG};           \
    fi;  \
}

RUNRELEASECASE = _run_test_release_case() {                                                  \
    case="$(filter-out $@,$(MAKECMDGOALS))";                                      \
    if [ -n "$${WORKFLOW}" ]; then \
        export TEST_FLAG=" --release -- -q --test-threads=1"; \
    else  \
        export LOG_FILE="/tmp/test_wg.log"; \
        export TEST_FLAG=" --release -- --nocapture --test-threads=1"; \
    fi; \
    if [ -n "$${case}" ]; then                                                    \
        RUST_BACKTRACE=full cargo test $${case} $${FEATURE_FLAG} $${TEST_FLAG};  \
    else                                                                          \
        RUST_BACKTRACE=full cargo test $${FEATURE_FLAG} $${TEST_FLAG};                                            \
    fi  \
}


INSTALL_GITHOOKS = _install_githooks() {                \
    git config core.hooksPath ./git-hooks;              \
}

.PHONY: git-hooks
git-hooks:
	@$(INSTALL_GITHOOKS); _install_githooks

.PHONY: init
init: git-hooks

.PHONY: fmt
fmt: init
	cargo fmt

.PHONY: doc
doc:
	RUSTDOCFLAGS="--cfg docsrs" cargo +nightly doc --all-features

.PHONY: test
test: init
	@echo "Run test"
	@${RUNTESTCASE}; _run_test_case
	@echo "Done"

.PHONY: test
test_log: init
	@echo "Run test"
	@${RUNTESTCASE}; FEATURE_FLAG="-F trace_log"; _run_test_case
	@echo "Done"

.PHONY: test_release
test_release:
	@${RUNRELEASECASE}; _run_test_release_case

.PHONY: test_log_release
test_log_release:
	@${RUNRELEASECASE}; FEATURE_FLAG="-F trace_log"; _run_test_release_case

.PHONY: test_smol
test_smol:
	@${RUNTESTCASE}; FEATURE_FLAG="-F smol"; _run_test_case

.PHONY: test_log_smol
test_log_smol:
	@${RUNTESTCASE}; FEATURE_FLAG="-F smol,trace_log"; _run_test_case

.PHONY: test_smol_release
test_smol_release:
	@${RUNRELEASECASE}; FEATURE_FLAG="-F smol"; _run_test_release_case

.PHONY: test_log_smol_release
test_log_smol_release:
	@${RUNRELEASECASE}; FEATURE_FLAG="-F smol,trace_log"; _run_test_release_case

.PHONY: build
build: init
	cargo build

.DEFAULT_GOAL = build

# Target name % means that it is a rule that matches anything, @: is a recipe;
# the : means do nothing
%:
	@: