File: launch_vivado.sh

package info (click to toggle)
uhd 3.9.5-1~bpo8%2B1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-backports
  • size: 106,500 kB
  • sloc: cpp: 65,914; ansic: 59,349; python: 13,242; vhdl: 7,651; tcl: 2,668; sh: 1,634; makefile: 1,031; xml: 557; pascal: 230; csh: 94; asm: 20; perl: 11
file content (81 lines) | stat: -rwxr-xr-x 1,733 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#!/bin/bash

#------------------------------------------
# Parse command line args
#------------------------------------------

function help {
    cat <<EOHELP

Usage: $0 [--help|-h] [--no-color] [<vivado args>]

--no-color      : Don't colorize command output
--help, -h      : Shows this message.

EOHELP
}

viv_args=""
colorize=1
for i in "$@"; do
    case $i in
        -h|--help)
            help
            exit 0
            ;;
        --no-color)
            colorize=0
        ;;
        *)
            viv_args="$viv_args $i"
        ;;
    esac
done

#------------------------------------------
# Colorize
#------------------------------------------

# VIV_COLOR_SCHEME must be defined in the environment setup script
if [ $colorize -eq 0 ]; then
    VIV_COLOR_SCHEME=none
fi

case "$VIV_COLOR_SCHEME" in
    default)
        CLR_OFF='tput sgr0'
        ERR_CLR='tput setaf 1'
        CRIWARN_CLR='tput setaf 1'
        WARN_CLR='tput setaf 3'
        ;;
    *)
        CLR_OFF=''
        ERR_CLR=$CLR_OFF
        CRIWARN_CLR=$CLR_OFF
        WARN_CLR=$CLR_OFF
esac

trim() {
    local var="$*"
    var="${var#"${var%%[![:space:]]*}"}"   # remove leading whitespace characters
    var="${var%"${var##*[![:space:]]}"}"   # remove trailing whitespace characters
    echo -n "$var"
}

vivado $viv_args 2>&1 | while IFS= read -r line
do
    case $(trim $line) in
        ERROR:*)
            eval $ERR_CLR; echo "$line"; eval $CLR_OFF
            ;;
        CRITICAL[[:space:]]WARNING:*)
            eval $CRIWARN_CLR; echo "$line"; eval $CLR_OFF
            ;;
        WARNING:*)
            eval $WARN_CLR; echo "$line"; eval $CLR_OFF
            ;;
        *)
            echo "$line"
    esac
done
exit ${PIPESTATUS[0]}