docs.sh 6.21 KB
Newer Older
Ian Hickson's avatar
Ian Hickson committed
1 2 3 4 5
#!/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.

6
set -e
7

8 9 10 11 12 13 14 15
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
16
  cd -P "$(dirname "$script_location")" >/dev/null && pwd
17 18
}

19 20
function generate_docs() {
    # Install and activate dartdoc.
21 22
    # NOTE: When updating to a new dartdoc version, please also update
    # `dartdoc_options.yaml` to include newly introduced error and warning types.
23
    "$DART" pub global activate dartdoc 6.1.2
24 25 26 27

    # 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
28
    "$DART" pub global activate snippets 0.3.0
29 30 31 32

    # This script generates a unified doc set, and creates
    # a custom index.html, placing everything into dev/docs/doc.
    (cd "$FLUTTER_ROOT/dev/tools" && "$FLUTTER" pub get)
33
    (cd "$FLUTTER_ROOT/dev/tools" && "$DART" pub get)
34 35
    (cd "$FLUTTER_ROOT" && "$DART" --disable-dart-dev --enable-asserts "$FLUTTER_ROOT/dev/tools/dartdoc.dart")
    (cd "$FLUTTER_ROOT" && "$DART" --disable-dart-dev --enable-asserts "$FLUTTER_ROOT/dev/tools/java_and_objc_doc.dart")
36 37
}

38 39 40
# Zip up the docs so people can download them for offline usage.
function create_offline_zip() {
  # Must be run from "$FLUTTER_ROOT/dev/docs"
41
  echo "$(date): Zipping Flutter offline docs archive."
42 43 44 45 46 47 48 49
  rm -rf flutter.docs.zip doc/offline
  (cd ./doc; zip -r -9 -q ../flutter.docs.zip .)
}

# Generate the docset for Flutter docs for use with Dash, Zeal, and Velocity.
function create_docset() {
  # Must be run from "$FLUTTER_ROOT/dev/docs"
  # Must have dashing installed: go get -u github.com/technosophos/dashing
50 51
  # Dashing produces a LOT of log output (~30MB), so we redirect it, and just
  # show the end of it if there was a problem.
52
  echo "$(date): Building Flutter docset."
53
  rm -rf flutter.docset
54
  # If dashing gets stuck, Cirrus will time out the build after an hour, and we
55 56
  # never get to see the logs. Thus, we run it in the background and tail the logs
  # while we wait for it to complete.
57 58
  dashing_log=/tmp/dashing.log
  dashing build --source ./doc --config ./dashing.json > $dashing_log 2>&1 &
59 60
  dashing_pid=$!
  wait $dashing_pid && \
61
  cp ./doc/flutter/static-assets/favicon.png ./flutter.docset/icon.png && \
62
  "$DART" --disable-dart-dev --enable-asserts ./dashing_postprocess.dart && \
63 64 65 66 67 68
  tar cf flutter.docset.tar.gz --use-compress-program="gzip --best" flutter.docset
  if [[ $? -ne 0 ]]; then
      >&2 echo "Dashing docset generation failed"
      tail -200 $dashing_log
      exit 1
  fi
69 70
}

71
function deploy_docs() {
72
    case "$LUCI_BRANCH" in
73
        master)
74
            echo "$(date): Updating $LUCI_BRANCH docs: https://master-api.flutter.dev/"
75 76 77 78 79
            # Disable search indexing on the master staging site so searches get only
            # the stable site.
            echo -e "User-agent: *\nDisallow: /" > "$FLUTTER_ROOT/dev/docs/doc/robots.txt"
            ;;
        stable)
80
            echo "$(date): Updating $LUCI_BRANCH docs: https://api.flutter.dev/"
81 82 83 84 85
            # Enable search indexing on the master staging site so searches get only
            # the stable site.
            echo -e "# All robots welcome!" > "$FLUTTER_ROOT/dev/docs/doc/robots.txt"
            ;;
        *)
86
            >&2 echo "Docs deployment cannot be run on the $LUCI_BRANCH branch."
87
            exit 0
88 89 90
    esac
}

91 92 93 94 95
# Move the offline archives into place, after all the processing of the doc
# directory is done. This avoids the tools recursively processing the archives
# as part of their process.
function move_offline_into_place() {
  # Must be run from "$FLUTTER_ROOT/dev/docs"
96
  echo "$(date): Moving offline data into place."
97 98 99
  mkdir -p doc/offline
  mv flutter.docs.zip doc/offline/flutter.docs.zip
  du -sh doc/offline/flutter.docs.zip
100
  if [[ "$LUCI_BRANCH" == "stable" ]]; then
101
    echo -e "<entry>\n  <version>${FLUTTER_VERSION_STRING}</version>\n  <url>https://api.flutter.dev/offline/flutter.docset.tar.gz</url>\n</entry>" > doc/offline/flutter.xml
102
  else
103
    echo -e "<entry>\n  <version>${FLUTTER_VERSION_STRING}</version>\n  <url>https://master-api.flutter.dev/offline/flutter.docset.tar.gz</url>\n</entry>" > doc/offline/flutter.xml
104 105 106
  fi
  mv flutter.docset.tar.gz doc/offline/flutter.docset.tar.gz
  du -sh doc/offline/flutter.docset.tar.gz
107 108
}

109 110 111 112 113 114 115
# 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")")"

116
echo "$(date): Running docs.sh"
117

118
if [[ ! -d "$FLUTTER_ROOT" || ! -f "$FLUTTER_ROOT/bin/flutter" ]]; then
119
  >&2 echo "Unable to locate the Flutter installation (using FLUTTER_ROOT: $FLUTTER_ROOT)"
120 121
  exit 1
fi
Ian Hickson's avatar
Ian Hickson committed
122

123 124 125 126 127
FLUTTER_BIN="$FLUTTER_ROOT/bin"
DART_BIN="$FLUTTER_ROOT/bin/cache/dart-sdk/bin"
FLUTTER="$FLUTTER_BIN/flutter"
DART="$DART_BIN/dart"
export PATH="$FLUTTER_BIN:$DART_BIN:$PATH"
128

129 130 131 132 133
# Make sure dart is installed by invoking Flutter to download it.
# This also creates the 'version' file.
FLUTTER_VERSION=$("$FLUTTER" --version --machine)
export FLUTTER_VERSION
FLUTTER_VERSION_STRING=$(cat "$FLUTTER_ROOT/version")
134

135 136
# If the pub cache directory exists in the root, then use that.
FLUTTER_PUB_CACHE="$FLUTTER_ROOT/.pub-cache"
137
if [[ -d "$FLUTTER_PUB_CACHE" ]]; then
138 139
  # This has to be exported, because pub interprets setting it to the empty
  # string in the same way as setting it to ".".
140 141 142
  export PUB_CACHE="${PUB_CACHE:-"$FLUTTER_PUB_CACHE"}"
fi

143
generate_docs
144
# Skip publishing docs for PRs and release candidate branches
145
if [[ -n "$LUCI_CI" && -z "$LUCI_PR" ]]; then
146
  (cd "$FLUTTER_ROOT/dev/docs"; create_offline_zip)
147
  (cd "$FLUTTER_ROOT/dev/docs"; create_docset)
148 149
  (cd "$FLUTTER_ROOT/dev/docs"; move_offline_into_place)
  deploy_docs
150
fi