mirror of
https://github.com/flutter/flutter
synced 2024-11-05 18:37:51 +00:00
e31ac61813
Bumping DartDoc to 8.0.2. https://pub.dev/packages/dartdoc/changelog#802 Made a fix for https://github.com/flutter/flutter/issues/139755, so this release rolls that fix in. The fix was made here https://github.com/dart-lang/dartdoc/pull/3595. Not sure who's most relevant to tag so ccing some folks. cc. @srawlins @jason-simmons @gspencergoog ## Pre-launch Checklist - [X] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [X] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [X] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [X] I signed the [CLA]. - [X] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [ ] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/wiki/Tree-hygiene#overview [Tree Hygiene]: https://github.com/flutter/flutter/wiki/Tree-hygiene [test-exempt]: https://github.com/flutter/flutter/wiki/Tree-hygiene#tests [Flutter Style Guide]: https://github.com/flutter/flutter/wiki/Style-guide-for-Flutter-repo [Features we expect every widget to implement]: https://github.com/flutter/flutter/wiki/Style-guide-for-Flutter-repo#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/wiki/Tree-hygiene#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/wiki/Chat
154 lines
5.2 KiB
Bash
Executable file
154 lines
5.2 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
# Copyright 2014 The Flutter Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
set -e
|
|
|
|
function script_location() {
|
|
local script_location="${BASH_SOURCE[0]}"
|
|
# Resolve symlinks
|
|
while [[ -h "$script_location" ]]; do
|
|
DIR="$(cd -P "$( dirname "$script_location")" >/dev/null && pwd)"
|
|
script_location="$(readlink "$script_location")"
|
|
[[ "$script_location" != /* ]] && script_location="$DIR/$script_location"
|
|
done
|
|
cd -P "$(dirname "$script_location")" >/dev/null && pwd
|
|
}
|
|
|
|
# So that users can run this script from anywhere and it will work as expected.
|
|
SCRIPT_LOCATION="$(script_location)"
|
|
# Sets the Flutter root to be "$(script_location)/../..": This script assumes
|
|
# that it resides two directory levels down from the root, so if that changes,
|
|
# then this line will need to as well.
|
|
FLUTTER_ROOT="$(dirname "$(dirname "$SCRIPT_LOCATION")")"
|
|
export FLUTTER_ROOT
|
|
|
|
echo "$(date): Running docs.sh"
|
|
|
|
if [[ ! -d "$FLUTTER_ROOT" || ! -f "$FLUTTER_ROOT/bin/flutter" ]]; then
|
|
>&2 echo "Unable to locate the Flutter installation (using FLUTTER_ROOT: $FLUTTER_ROOT)"
|
|
exit 1
|
|
fi
|
|
|
|
FLUTTER_BIN="$FLUTTER_ROOT/bin"
|
|
DART_BIN="$FLUTTER_ROOT/bin/cache/dart-sdk/bin"
|
|
FLUTTER="$FLUTTER_BIN/flutter"
|
|
DART="$DART_BIN/dart"
|
|
PATH="$FLUTTER_BIN:$DART_BIN:$PATH"
|
|
|
|
# Make sure dart is installed by invoking Flutter to download it if it is missing.
|
|
# Also make sure the flutter command is ready to run before capturing output from
|
|
# it: if it has to rebuild itself or something, it'll spoil our JSON output.
|
|
"$FLUTTER" > /dev/null 2>&1
|
|
FLUTTER_VERSION="$("$FLUTTER" --version --machine)"
|
|
export FLUTTER_VERSION
|
|
|
|
# If the pub cache directory exists in the root, then use that.
|
|
FLUTTER_PUB_CACHE="$FLUTTER_ROOT/.pub-cache"
|
|
if [[ -d "$FLUTTER_PUB_CACHE" ]]; then
|
|
# This has to be exported, because pub interprets setting it to the empty
|
|
# string in the same way as setting it to ".".
|
|
PUB_CACHE="${PUB_CACHE:-"$FLUTTER_PUB_CACHE"}"
|
|
export PUB_CACHE
|
|
fi
|
|
|
|
function usage() {
|
|
echo "Usage: $(basename "${BASH_SOURCE[0]}") [--keep-temp] [--output <output.zip>]"
|
|
echo ""
|
|
echo " --keep-staging Do not delete the staging directory created while generating"
|
|
echo " docs. Normally the script deletes the staging directory after"
|
|
echo " generating the output ZIP file."
|
|
echo " --output <output.zip> specifies where the output ZIP file containing the documentation"
|
|
echo " data will be written."
|
|
echo " --staging-dir <directory> specifies where the temporary output files will be written while"
|
|
echo " generating docs. This directory will be deleted after generation"
|
|
echo " unless --keep-staging is also specified."
|
|
echo ""
|
|
}
|
|
|
|
function parse_args() {
|
|
local arg
|
|
local args=()
|
|
STAGING_DIR=
|
|
KEEP_STAGING=0
|
|
DESTINATION="$FLUTTER_ROOT/dev/docs/api_docs.zip"
|
|
while (( "$#" )); do
|
|
case "$1" in
|
|
--help)
|
|
usage
|
|
exit 0
|
|
;;
|
|
--staging-dir)
|
|
STAGING_DIR="$2"
|
|
shift
|
|
;;
|
|
--keep-staging)
|
|
KEEP_STAGING=1
|
|
;;
|
|
--output)
|
|
DESTINATION="$2"
|
|
shift
|
|
;;
|
|
*)
|
|
args=("${args[@]}" "$1")
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
if [[ -z $STAGING_DIR ]]; then
|
|
STAGING_DIR=$(mktemp -d /tmp/dartdoc.XXXXX)
|
|
fi
|
|
DOC_DIR="$STAGING_DIR/doc"
|
|
if [[ ${#args[@]} != 0 ]]; then
|
|
>&2 echo "ERROR: Unknown arguments: ${args[@]}"
|
|
usage
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function generate_docs() {
|
|
# Install and activate dartdoc.
|
|
# When updating to a new dartdoc version, please also update
|
|
# `dartdoc_options.yaml` to include newly introduced error and warning types.
|
|
"$DART" pub global activate dartdoc 8.0.2
|
|
|
|
# Install and activate the snippets tool, which resides in the
|
|
# assets-for-api-docs repo:
|
|
# https://github.com/flutter/assets-for-api-docs/tree/master/packages/snippets
|
|
"$DART" pub global activate snippets 0.4.0
|
|
|
|
# This script generates a unified doc set, and creates
|
|
# a custom index.html, placing everything into DOC_DIR.
|
|
|
|
# Make sure that create_api_docs.dart has all the dependencies it needs.
|
|
(cd "$FLUTTER_ROOT/dev/tools" && "$FLUTTER" pub get)
|
|
(cd "$FLUTTER_ROOT" && "$DART" --disable-dart-dev --enable-asserts "$FLUTTER_ROOT/dev/tools/create_api_docs.dart" --output-dir="$DOC_DIR")
|
|
}
|
|
|
|
function main() {
|
|
echo "Writing docs build temporary output to $DOC_DIR"
|
|
mkdir -p "$DOC_DIR"
|
|
generate_docs
|
|
# If the destination isn't an absolute path, make it into one.
|
|
if ! [[ "$DESTINATION" =~ ^/ ]]; then
|
|
DESTINATION="$PWD/$DESTINATION"
|
|
fi
|
|
|
|
# Make sure the destination has .zip as an extension, because zip will add it
|
|
# anyhow, and we want to print the correct output location.
|
|
DESTINATION=${DESTINATION%.zip}.zip
|
|
|
|
# Zip up doc directory and write the output to the destination.
|
|
(cd "$STAGING_DIR"; zip -r -9 -q "$DESTINATION" ./doc)
|
|
if [[ $KEEP_STAGING -eq 1 ]]; then
|
|
echo "Staging documentation output left in $STAGING_DIR"
|
|
else
|
|
echo "Removing staging documentation output from $STAGING_DIR"
|
|
rm -rf "$STAGING_DIR"
|
|
fi
|
|
echo "Wrote docs ZIP file to $DESTINATION"
|
|
}
|
|
|
|
parse_args "$@"
|
|
main
|