blob: 04874644259cc895560a1dfee7b347bb773759d6 (
plain)
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
#! /usr/bin/env bash
# file : msvc-common/msvc-rc-common
# copyright : Copyright (c) 2014-2018 Code Synthesis Ltd
# license : MIT; see accompanying LICENSE file
# Note: shouldn't be executed directly, src_dir must be set.
# Common rc.exe driver that expects the SDKBIN and INCLUDE variables to be set
# for the specific MSVC version/configuration.
source "$src_dir/msvc-common/msvc-common"
# Translate absolute paths from POSIX to Windows. Use bash array to store
# arguments in case they contain spaces.
#
# This needs to be done for both certain option values and arguments.
# Arguments are tricky in that unless we recognize every option, and option
# may look a lot like an absolute POSIX path (e.g., /nologo). The heuristics
# that we are going to use here is that if the argument starts with / and
# contains at least one more /, then we consider it an argument. Otherwise --
# an options. We will also explicitly recognize certain options which may not
# fit this scheme well.
#
# Note that the order of the cases is important. Specifically, we want, e.g.,
# /D before /D*.
#
# Note that rc.exe /? is missing some options that are documented in MSDN.
#
args=()
while [ $# -gt 0 ]; do
case ${1^^} in # Uppercase for case-insensitive comparison.
# /I <dir>
#
[/-]I)
args=("${args[@]}" "$1")
shift
args=("${args[@]}" "$(translate $1)")
shift
;;
# /I<dir>
#
[/-]I*)
args=("${args[@]}" "$(split_translate 2 $1)")
shift
;;
# /f[om] <file>
#
[/-]F[OM])
args=("${args[@]}" "$1")
shift
args=("${args[@]}" "$(translate $1)")
shift
;;
# /f[om]<file>
#
[/-]F[OM]*)
args=("${args[@]}" "$(split_translate 3 $1)")
shift
;;
# /q <file>
#
[/-]Q)
args=("${args[@]}" "$1")
shift
args=("${args[@]}" "$(translate $1)")
shift
;;
# /q<file>
#
[/-]Q*)
args=("${args[@]}" "$(split_translate 2 $1)")
shift
;;
# Handle other options with separate values. This makes sure we don't try
# to path-translate them.
#
[/-]D | \
[/-]U)
args=("${args[@]}" "$1")
shift
args=("${args[@]}" "$1")
shift
;;
# Handle other options with combined values that could possibly be
# interpreted as paths, for example /DFOO=foo/bar.
#
[/-]D*)
args=("${args[@]}" "$1")
shift
;;
# Option or argument.
#
*)
# If contains at least two slashes, treat it as a path.
#
if [[ "$1" == /*/* ]]; then
args=("${args[@]}" "$(translate $1)")
else
args=("${args[@]}" "$1")
fi
shift
;;
esac
done
export INCLUDE
# rc.exe always sends diagnostics to stdout.
#
msvc_exec 1 "$SDKBIN\\rc.exe" "${args[@]}"
|