From 94c5949c1289c65ceb727d7b5eb70eeb2dd7669d Mon Sep 17 00:00:00 2001 From: Adam Barth Date: Mon, 15 Feb 2016 00:07:42 -0800 Subject: [PATCH] Internalize our dependency on the Dart SDK This patch teaches the flutter command to download the Dart SDK into cache, removing another step from the Getting Started workflow. The version of the Dart SDK is controlled by the "dart-sdk.version" file in the bin/cache directory. Fixes #54 --- bin/cache/.gitignore | 1 + bin/cache/dart-sdk.version | 1 + bin/cache/update_dart_sdk.sh | 36 ++++++++++++++++++++++++++++++++++++ bin/flutter | 34 +++++++++++++++++++++++----------- 4 files changed, 61 insertions(+), 11 deletions(-) create mode 100644 bin/cache/dart-sdk.version create mode 100755 bin/cache/update_dart_sdk.sh diff --git a/bin/cache/.gitignore b/bin/cache/.gitignore index 565eb5edbd..c9529aa9e8 100644 --- a/bin/cache/.gitignore +++ b/bin/cache/.gitignore @@ -1,3 +1,4 @@ *.snapshot *.stamp artifacts +dart-sdk diff --git a/bin/cache/dart-sdk.version b/bin/cache/dart-sdk.version new file mode 100644 index 0000000000..63e799cf45 --- /dev/null +++ b/bin/cache/dart-sdk.version @@ -0,0 +1 @@ +1.14.1 diff --git a/bin/cache/update_dart_sdk.sh b/bin/cache/update_dart_sdk.sh new file mode 100755 index 0000000000..da5e0c665c --- /dev/null +++ b/bin/cache/update_dart_sdk.sh @@ -0,0 +1,36 @@ +#!/bin/bash +# Copyright 2016 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +DART_SDK_PATH="$FLUTTER_ROOT/bin/cache/dart-sdk" +DART_SDK_STAMP_PATH="$FLUTTER_ROOT/bin/cache/dart-sdk.stamp" +DART_SDK_VERSION=`cat "$FLUTTER_ROOT/bin/cache/dart-sdk.version"` + +if [ ! -f "$DART_SDK_STAMP_PATH" ] || [ "$DART_SDK_VERSION" != `cat "$DART_SDK_STAMP_PATH"` ]; then + echo Downloading Dart SDK $DART_SDK_VERSION... + + case "$(uname -s)" in + Darwin) + DART_ZIP_NAME="dartsdk-macos-x64-release.zip" + ;; + Linux) + DART_ZIP_NAME="dartsdk-linux-x64-release.zip" + ;; + *) + echo "Unknown operating system. Cannot install Dart SDK." + exit 1 + ;; + esac + + DART_SDK_URL="http://gsdview.appspot.com/dart-archive/channels/stable/raw/$DART_SDK_VERSION/sdk/$DART_ZIP_NAME" + + rm -rf "$DART_SDK_PATH" + mkdir -p "$DART_SDK_PATH" + DART_SDK_ZIP="$FLUTTER_ROOT/bin/cache/dart-sdk.zip" + + curl -C - --location -o "$DART_SDK_ZIP" "$DART_SDK_URL" + unzip -o -q "$DART_SDK_ZIP" -d "$FLUTTER_ROOT/bin/cache" + rm "$DART_SDK_ZIP" + echo $DART_SDK_VERSION > "$DART_SDK_STAMP_PATH" +fi diff --git a/bin/flutter b/bin/flutter index 1ec69b6713..2c28b5586d 100755 --- a/bin/flutter +++ b/bin/flutter @@ -7,26 +7,38 @@ set -e export FLUTTER_ROOT=$(dirname $(dirname "${BASH_SOURCE[0]}")) FLUTTER_TOOLS_DIR="$FLUTTER_ROOT/packages/flutter_tools" -FLUTTER_DIR="$FLUTTER_ROOT/packages/flutter" SNAPSHOT_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.snapshot" STAMP_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.stamp" SCRIPT_PATH="$FLUTTER_TOOLS_DIR/bin/flutter_tools.dart" +DART_SDK_PATH="$FLUTTER_ROOT/bin/cache/dart-sdk" -# TODO(abarth): We shouldn't require dart to be on the user's path. -DART=dart +DART="$DART_SDK_PATH/bin/dart" REVISION=`(cd "$FLUTTER_ROOT"; git rev-parse HEAD)` if [ ! -f "$SNAPSHOT_PATH" ] || [ ! -f "$STAMP_PATH" ] || [ `cat "$STAMP_PATH"` != "$REVISION" ] || [ "$FLUTTER_TOOLS_DIR/pubspec.yaml" -nt "$FLUTTER_TOOLS_DIR/pubspec.lock" ]; then - echo Updating flutter tool... - (cd "$FLUTTER_TOOLS_DIR"; pub get > /dev/null) - (cd "$FLUTTER_DIR"; pub get > /dev/null) # Allows us to check if sky_engine's REVISION is correct - $DART --snapshot="$SNAPSHOT_PATH" --package-root="$FLUTTER_TOOLS_DIR/packages" "$SCRIPT_PATH" - echo -n $REVISION > "$STAMP_PATH" + "$FLUTTER_ROOT/bin/cache/update_dart_sdk.sh" + + echo Building flutter tool... + FLUTTER_DIR="$FLUTTER_ROOT/packages/flutter" + PUB="$DART_SDK_PATH/bin/pub" + + (cd "$FLUTTER_TOOLS_DIR"; "$PUB" get > /dev/null) + (cd "$FLUTTER_DIR"; "$PUB" get > /dev/null) # Allows us to check if sky_engine's REVISION is correct + "$DART" --snapshot="$SNAPSHOT_PATH" --package-root="$FLUTTER_TOOLS_DIR/packages" "$SCRIPT_PATH" + echo $REVISION > "$STAMP_PATH" fi +# Add our internalized version of the Dart SDK to the path ahead of any other +# versions that might be installed on this machine. +# +# TODO(abarth): We should teach flutter_tools to our version of the Dart SDK +# explicitly instead of relying upon the PATH. +# +export PATH="$DART_SDK_PATH/bin:$PATH" + set +e -$DART "$SNAPSHOT_PATH" "$@" +"$DART" "$SNAPSHOT_PATH" "$@" # The VM exits with code 253 if the snapshot version is out-of-date. # If it is, we need to snapshot it again. @@ -37,5 +49,5 @@ fi set -e -$DART --snapshot="$SNAPSHOT_PATH" --package-root="$FLUTTER_TOOLS_DIR/packages" "$SCRIPT_PATH" -$DART "$SNAPSHOT_PATH" "$@" +"$DART" --snapshot="$SNAPSHOT_PATH" --package-root="$FLUTTER_TOOLS_DIR/packages" "$SCRIPT_PATH" +"$DART" "$SNAPSHOT_PATH" "$@"