|
| 1 | +#!/bin/bash |
| 2 | +# Prepare a new VS Code Insiders release (Part 2) |
| 3 | +# Usage: ./build/docs-release-part2.sh <version> <releaseDate> |
| 4 | +# |
| 5 | +# Example: |
| 6 | +# ./build/docs-release-part2.sh 1.115.0 2026-05-07 |
| 7 | + |
| 8 | +set -e |
| 9 | + |
| 10 | +show_help() { |
| 11 | + cat << EOF |
| 12 | +Usage: ./build/docs-release-part2.sh <version> <releaseDate> |
| 13 | +
|
| 14 | +Optimizes media content, creates Insiders release notes for the next version, |
| 15 | +and updates date metadata in documentation articles. |
| 16 | +
|
| 17 | +Steps performed: |
| 18 | + 1. Optimize PNG images in the release-notes media folder (convert to WebP) |
| 19 | + 2. Optimize MP4 videos in the release-notes media folder |
| 20 | + 3. Create Insiders release notes from the template |
| 21 | + 4. Update DateApproved metadata in documentation articles |
| 22 | +
|
| 23 | +Arguments: |
| 24 | + version The full version string (e.g. 1.115.0) |
| 25 | + releaseDate The release date in YYYY-MM-DD format (e.g. 2026-05-07) |
| 26 | +
|
| 27 | +Options: |
| 28 | + -h, --help Show this help message |
| 29 | +
|
| 30 | +Derived values: |
| 31 | + releaseNumber Extracted from version (e.g. 1.115.0 → 115) |
| 32 | + mediaFolder release-notes/images/1_<releaseNumber> |
| 33 | + milestone v<version> (e.g. v1.115.0) |
| 34 | + lastUpdated Today's date (for Insiders release notes) |
| 35 | +
|
| 36 | +Example: |
| 37 | + ./build/docs-release-part2.sh 1.115.0 2026-05-07 |
| 38 | +EOF |
| 39 | +} |
| 40 | + |
| 41 | +# Check for help flag |
| 42 | +if [[ "$1" == "-h" || "$1" == "--help" ]]; then |
| 43 | + show_help |
| 44 | + exit 0 |
| 45 | +fi |
| 46 | + |
| 47 | +# Validate arguments |
| 48 | +if [ "$#" -ne 2 ]; then |
| 49 | + echo "Error: Expected 2 arguments, got $#." |
| 50 | + echo "Usage: ./build/docs-release-part2.sh <version> <releaseDate>" |
| 51 | + echo "Run with --help for more information." |
| 52 | + exit 1 |
| 53 | +fi |
| 54 | + |
| 55 | +VERSION="$1" |
| 56 | +RELEASE_DATE="$2" |
| 57 | + |
| 58 | +# Validate version format (e.g. 1.115.0) |
| 59 | +if [[ ! "$VERSION" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]]; then |
| 60 | + echo "Error: version must be in the format X.Y.Z (e.g. 1.115.0)." |
| 61 | + exit 1 |
| 62 | +fi |
| 63 | + |
| 64 | +# Validate date format (YYYY-MM-DD) |
| 65 | +if [[ ! "$RELEASE_DATE" =~ ^[0-9]{4}-[0-9]{2}-[0-9]{2}$ ]]; then |
| 66 | + echo "Error: releaseDate must be in YYYY-MM-DD format (e.g. 2026-05-07)." |
| 67 | + exit 1 |
| 68 | +fi |
| 69 | + |
| 70 | +# Derive values from version |
| 71 | +RELEASE_NUMBER=$(echo "$VERSION" | cut -d. -f2) |
| 72 | +MILESTONE="v$VERSION" |
| 73 | +MAJOR_MINOR="1.$RELEASE_NUMBER" |
| 74 | +MEDIA_FOLDER="release-notes/images/1_${RELEASE_NUMBER}" |
| 75 | +LAST_UPDATED=$(date +%Y-%m-%d) |
| 76 | + |
| 77 | +# Determine the script directory and project root |
| 78 | +SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" |
| 79 | +ROOT_DIR="$(cd "$SCRIPT_DIR/.." && pwd)" |
| 80 | + |
| 81 | +echo "=== VS Code Release Preparation (Part 2 — Insiders) ===" |
| 82 | +echo "" |
| 83 | +echo " Version: $VERSION" |
| 84 | +echo " Release number: $RELEASE_NUMBER" |
| 85 | +echo " Release date: $RELEASE_DATE" |
| 86 | +echo " Milestone: $MILESTONE" |
| 87 | +echo " Media folder: $MEDIA_FOLDER" |
| 88 | +echo " Last updated: $LAST_UPDATED" |
| 89 | +echo "" |
| 90 | + |
| 91 | +cd "$ROOT_DIR" |
| 92 | + |
| 93 | +# Step 1: Optimize images |
| 94 | +echo "--- Step 1: Optimize images ---" |
| 95 | +if [ -d "$MEDIA_FOLDER" ]; then |
| 96 | + bash "$SCRIPT_DIR/optimize-images.sh" "$MEDIA_FOLDER" |
| 97 | +else |
| 98 | + echo "Skipping: Media folder not found ($MEDIA_FOLDER)" |
| 99 | +fi |
| 100 | +echo "" |
| 101 | + |
| 102 | +# Step 2: Optimize videos |
| 103 | +echo "--- Step 2: Optimize videos ---" |
| 104 | +if [ -d "$MEDIA_FOLDER" ]; then |
| 105 | + bash "$SCRIPT_DIR/optimize-videos.sh" "$MEDIA_FOLDER" |
| 106 | +else |
| 107 | + echo "Skipping: Media folder not found ($MEDIA_FOLDER)" |
| 108 | +fi |
| 109 | +echo "" |
| 110 | + |
| 111 | +# Step 3: Create Insiders release notes |
| 112 | +echo "--- Step 3: Create Insiders release notes ---" |
| 113 | +node "$SCRIPT_DIR/create-release-notes.js" --insiders "$RELEASE_NUMBER" "$RELEASE_DATE" "$MILESTONE" "$LAST_UPDATED" |
| 114 | +echo "" |
| 115 | + |
| 116 | +# Step 4: Update date metadata |
| 117 | +echo "--- Step 4: Update date metadata ---" |
| 118 | +node "$SCRIPT_DIR/update-dates.js" "$MAJOR_MINOR" "$RELEASE_DATE" |
| 119 | +echo "" |
| 120 | + |
| 121 | +echo "=== Release preparation (Part 2) complete ===" |
0 commit comments