|  | #!/bin/bash | 
|  | # Copyright 2018 The Fuchsia Authors. All rights reserved. | 
|  | # Use of this source code is governed by a BSD-style license that can be | 
|  | # found in the LICENSE file. | 
|  |  | 
|  | #### CATEGORY=Software delivery | 
|  | ### start `pave` and `serve-updates` in a single command | 
|  | ## usage: fx serve [-v] [-l host[:port]] [-a target] | 
|  | ##   -l host:port for "pm serve" to listen on | 
|  | ##   --no-auto-config do not configure this host as a package server on the device | 
|  | ##   -v enable more verbose output (must be first argument) | 
|  | ##   -a target ipv6 address for "fx pave --no-bind" | 
|  |  | 
|  | source "$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd)"/lib/vars.sh || exit $? | 
|  | fx-config-read | 
|  |  | 
|  | kill_child_processes() { | 
|  | child_pids=$(jobs -p) | 
|  | if [[ -n "${child_pids}" ]]; then | 
|  | # Note: child_pids must be expanded to args here. | 
|  | kill ${child_pids} 2> /dev/null | 
|  | wait 2> /dev/null | 
|  | fi | 
|  | } | 
|  | trap kill_child_processes EXIT | 
|  |  | 
|  | serve_args=() | 
|  | pave_args=() | 
|  |  | 
|  | fx-standard-switches "$@" | 
|  | set -- "${FX_ARGV[@]}" | 
|  |  | 
|  | while (($#)); do | 
|  | case "$1" in | 
|  | -v|-vv|--verbose) | 
|  | serve_args+=("$1") | 
|  | ;; | 
|  | --no-auto-config) | 
|  | serve_args+=("$1") | 
|  | ;; | 
|  | -l) | 
|  | serve_args+=("$1" "$2") | 
|  | shift | 
|  | ;; | 
|  | -a) | 
|  | pave_args+=("--no-bind" "$1" "$2") | 
|  | shift | 
|  | ;; | 
|  | *) | 
|  | echo 2>&1 "Unknown argument: \"${1}\" ignored" | 
|  | ;; | 
|  | esac | 
|  | shift | 
|  | done | 
|  |  | 
|  | if fx-is-bringup; then | 
|  | fx-error "$0 is not supported in the bringup build configuration, as there are no package features in bringup." | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | fx-command-exec pave "${pave_args[@]}"& | 
|  | pave_pid=$! | 
|  | fx-command-exec serve-updates "${serve_args[@]}" & | 
|  | serve_pid=$! | 
|  |  | 
|  | while true; do | 
|  | sleep 1 | 
|  |  | 
|  | # If any child exits, then exit the whole process, causing other children to | 
|  | # be cleaned up by the exit trap. | 
|  | for pid in "${pave_pid}" "${serve_pid}"; do | 
|  | if ! kill -0 $pid 2> /dev/null; then | 
|  | exit | 
|  | fi | 
|  | done | 
|  | done | 
|  |  | 
|  | # See EXIT trap above for cleanup that occurs |