roku_builder 4.25.1 → 4.25.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0a3905a9a153133cba22710cb79609fce822905727e99a348c682148c9224836
4
- data.tar.gz: 05b39e2c73538bdd1d8c665f06cbcd52694fd0891355a352c2cf01c75d72212f
3
+ metadata.gz: 852ae89e38456c17e455675a4901b37914f6109a47202137efecef4e4cb68309
4
+ data.tar.gz: 95f9cd039b170352a7f7868ec9ff52663e6e22add7dd3bf883a96112ea9680d4
5
5
  SHA512:
6
- metadata.gz: eb41fefe18f84f23cf38b7404d08c1b8ae84466373e0098711766b2006ff75f607c92ebc640b4188059bf92924f1e7c9eadd3e06d8f929f9f5664462781ac558
7
- data.tar.gz: 9a6f5e63ba200dcd844274b3a8513d2c01da66248a74a8df5e095a7280572a120613b0891f218bc05e3c250cae33c5aab195e7fee976292628a3e903c94c2b30
6
+ metadata.gz: 14157cf2cfb8268d30f9acee98af461e7b0c500a57bb6ec2e95254e1b7c3859087eb5ed0fd2e57b9ed660aa1c825f1d8623250a6a409c8062a2d77ee8d74f156
7
+ data.tar.gz: 6e50b5767da2018fd30550766fb681167a1ded341d85b810eae2ba95517080c16df74f46aad1bc5ec37658e3cb35b94e1c7659b1e36292fd1daae7aef17d4415
@@ -41,7 +41,7 @@ module RokuBuilder
41
41
  @ind = line.index(/[^#{@character}]/)
42
42
  else
43
43
  if @prev_line
44
- if @prev_line =~ /^\'/ or @prev_line =~ /\'indent-ignore/
44
+ if @prev_line =~ /^\s*\'/ or @prev_line =~ /\'indent-ignore/
45
45
  # Don't change indentation
46
46
  elsif @prev_line =~ /[\{\[\(:]$/
47
47
  @ind += @count
@@ -61,7 +61,7 @@ module RokuBuilder
61
61
  @ind += @count
62
62
  end
63
63
  end
64
- if line =~ /^\'/ or line =~ /\'indent-ignore/
64
+ if line =~ /^\s*\'/ or line =~ /\'indent-ignore/
65
65
  # Don't change indentation
66
66
  elsif line =~ /^\s*[\}\]\)]/
67
67
  @ind -= @count
@@ -1,9 +1,4 @@
1
1
  [
2
- {
3
- "regex": "\\sas\\s+(Object|Boolean|String|Integer|LongInteger|Double|Float|Function|Dynamic)",
4
- "severity": "warning",
5
- "message": "Found function return type. Consider removing"
6
- } ,
7
2
  {
8
3
  "regex": "DoesExist",
9
4
  "severity": "warning",
@@ -0,0 +1,15 @@
1
+ Static Channel Analysis
2
+ Copyright © 2022 Roku, Inc.
3
+
4
+ The Static Channel Analysis and associated documentation (collectively, the “Software”)
5
+ is licensed under the Apache License, Version 2.0 (the "License");
6
+ you may not use this Software except in compliance with the License.
7
+ You may obtain a copy of the License at
8
+
9
+ http://www.apache.org/licenses/LICENSE-2.0
10
+
11
+ Unless required by applicable law or agreed to in writing, the Software
12
+ distributed under the License is distributed on an "AS IS" BASIS,
13
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ See the License for the specific language governing permissions and
15
+ limitations under the License.
@@ -0,0 +1,141 @@
1
+ Static Channel Analysis
2
+ =======================
3
+
4
+ Performs BrightScript code static analysis. Provides info about debug code present, deprecated usage etc. Checks
5
+ manifest file for proper attributes.
6
+
7
+ Requires Java to be installed in the system.
8
+
9
+ Tool usage from command line
10
+ ----------------------------
11
+
12
+ Usage:
13
+
14
+ `java -jar PATH_TO_JAR PATH_TO_PROJECT_OR_ZIP`
15
+
16
+ Examples:
17
+
18
+ - `java -jar sca-cmd.jar my_project`
19
+ - `java -jar sca-cmd.jar my_project.zip`
20
+
21
+ **Severity level choice:**
22
+
23
+ You can specify verbosity level using `--severity` command line parameter. This parameter is optional. It is possible to
24
+ use short version `-s` instead of `--severity`.
25
+
26
+ Usage:
27
+
28
+ `java -jar PATH_TO_JAR PATH_TO_PROJECT_OR_ZIP --severity SEVERITY_LEVEL`
29
+
30
+ Example:
31
+
32
+ `java -jar sca-cmd.jar my_project --severity info`
33
+
34
+ Available `SEVERITY_LEVEL` values are: `info`, `warning` and `error`:
35
+
36
+ - `info` - print all of the logs
37
+ - `warning` - print warnings and errors
38
+ - `error` - print errors only
39
+
40
+ If severity level is not specified `warning` is used.
41
+
42
+ **Category filter:**
43
+
44
+ You can filter output logs by categories using `--filter-categories` command line parameter. Short version is `-c`. This
45
+ parameter is optional.
46
+
47
+ Usage:
48
+
49
+ `java -jar PATH_TO_JAR PATH_TO_PROJECT_OR_ZIP --filter-categories COMMA_SEPARATED_CATEGORIES`
50
+
51
+ Example:
52
+
53
+ `java -jar sca-cmd.jar my_project --filter-categories deprecated_components,manifest,package`
54
+
55
+ List of categories:
56
+
57
+ - `uncategorized`
58
+ - `deprecated_components`
59
+ - `deprecated_apis`
60
+ - `manifest`
61
+ - `raf`
62
+ - `package`
63
+ - `red`
64
+ - `deep_linking`
65
+ - `performance`
66
+ - `billing`
67
+ - `channel_store`
68
+
69
+ If categories are not specified output logs are not filtered.
70
+
71
+ **Exit with status code 1:**
72
+
73
+ You can specify verbosity level on which program should exit with status code `1` using `--exit` command line parameter.
74
+ This parameter is optional. It is possible to use short version `-e` instead of `--exit`.
75
+
76
+ Usage:
77
+
78
+ `java -jar PATH_TO_JAR PATH_TO_PROJECT_OR_ZIP --exit COMMA_SEPARATED_SEVERITY_LEVELS`
79
+
80
+ Example:
81
+
82
+ `java -jar sca-cmd.jar my_project --exit error,warning`
83
+
84
+ Available `SEVERITY_LEVEL` values are: `info`, `warning` and `error`:
85
+
86
+ If specified severity levels are present in the response, program will exit with status code `1`, otherwise with status
87
+ code `0`.
88
+
89
+ If exit severity levels are not specified the program exits with status code `0`.
90
+
91
+ **Output format choice:**
92
+
93
+ You can generate local report file by specifying file path in `--output` and file format in `--format` command line
94
+ parameters. Destination folder for report file should be already created in your file system. It is possible to use
95
+ short versions `-o` and `-f` instead of `--output` and `--format` accordingly.
96
+
97
+ Usage:
98
+
99
+ `java -jar PATH_TO_JAR PATH_TO_PROJECT_OR_ZIP --output PATH_TO_REPORT_FILE --format COMMA_SEPARATED_FORMATS`
100
+
101
+ Example:
102
+
103
+ `java -jar sca-cmd.jar my_project --output "../reports/report.xml" --format console,junit`
104
+
105
+ Supported format values are: `console` and `junit`:
106
+
107
+ - `console` - print all outputs to console
108
+ - `json` - save all outputs to specified json file
109
+ - `junit` - save all outputs to specified JUnit xml file
110
+
111
+ If format is not specified `console` is used. If specified any file format but not specified output file path a default
112
+ file path value is used. For `junit`, this is `reports/SCA_Report.xml`. For `json`, this is `reports/SCA_Report.json`
113
+
114
+ **Usage without manual java invocation:**
115
+
116
+ Archive structure:
117
+
118
+ ```
119
+ .
120
+ └── sca-cmd
121
+ ├── bin
122
+ │   ├── sca-cmd
123
+ │   └── sca-cmd.bat
124
+ └── lib
125
+ └── sca-cmd.jar
126
+ ```
127
+
128
+ Usage examples:
129
+
130
+ - Mac/Linux/UNIX: `./sca-cmd PATH_TO_PROJECT_OR_ZIP`
131
+ - Windows: `sca-cmd.bat PATH_TO_PROJECT_OR_ZIP`
132
+
133
+ You must be in the `bin` folder to use this command. `sca-cmd` is just `sh` script inside, it can be used in Unix-like
134
+ systems. `sca-cmd.bat` is for Windows systems. Each script takes the same command line arguments as `sca-cmd.jar`.
135
+ Actually, it just invokes `sca-cmd.jar` from the `lib` folder with passed arguments.
136
+
137
+ **EXE usage on Windows:**
138
+
139
+ EXE usage is the same as for `bat` file. It also takes the same arguments.
140
+
141
+ Example: `sca-cmd.exe PATH_TO_PROJECT_OR_ZIP`
@@ -1,7 +1,7 @@
1
- #!/usr/bin/env sh
1
+ #!/bin/sh
2
2
 
3
3
  #
4
- # Copyright 2015 the original author or authors.
4
+ # Copyright © 2015-2021 the original authors.
5
5
  #
6
6
  # Licensed under the Apache License, Version 2.0 (the "License");
7
7
  # you may not use this file except in compliance with the License.
@@ -17,79 +17,113 @@
17
17
  #
18
18
 
19
19
  ##############################################################################
20
- ##
21
- ## sca-cmd start up script for UN*X
22
- ##
20
+ #
21
+ # sca-cmd start up script for POSIX generated by Gradle.
22
+ #
23
+ # Important for running:
24
+ #
25
+ # (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
26
+ # noncompliant, but you have some other compliant shell such as ksh or
27
+ # bash, then to run this script, type that shell name before the whole
28
+ # command line, like:
29
+ #
30
+ # ksh sca-cmd
31
+ #
32
+ # Busybox and similar reduced shells will NOT work, because this script
33
+ # requires all of these POSIX shell features:
34
+ # * functions;
35
+ # * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
36
+ # «${var#prefix}», «${var%suffix}», and «$( cmd )»;
37
+ # * compound commands having a testable exit status, especially «case»;
38
+ # * various built-in commands including «command», «set», and «ulimit».
39
+ #
40
+ # Important for patching:
41
+ #
42
+ # (2) This script targets any POSIX shell, so it avoids extensions provided
43
+ # by Bash, Ksh, etc; in particular arrays are avoided.
44
+ #
45
+ # The "traditional" practice of packing multiple parameters into a
46
+ # space-separated string is a well documented source of bugs and security
47
+ # problems, so this is (mostly) avoided, by progressively accumulating
48
+ # options in "$@", and eventually passing that to Java.
49
+ #
50
+ # Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
51
+ # and SCA_CMD_OPTS) rely on word-splitting, this is performed explicitly;
52
+ # see the in-line comments for details.
53
+ #
54
+ # There are tweaks for specific operating systems such as AIX, CygWin,
55
+ # Darwin, MinGW, and NonStop.
56
+ #
57
+ # (3) This script is generated from the Groovy template
58
+ # https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
59
+ # within the Gradle project.
60
+ #
61
+ # You can find Gradle at https://github.com/gradle/gradle/.
62
+ #
23
63
  ##############################################################################
24
64
 
25
65
  # Attempt to set APP_HOME
66
+
26
67
  # Resolve links: $0 may be a link
27
- PRG="$0"
28
- # Need this for relative symlinks.
29
- while [ -h "$PRG" ] ; do
30
- ls=`ls -ld "$PRG"`
31
- link=`expr "$ls" : '.*-> \(.*\)$'`
32
- if expr "$link" : '/.*' > /dev/null; then
33
- PRG="$link"
34
- else
35
- PRG=`dirname "$PRG"`"/$link"
36
- fi
68
+ app_path=$0
69
+
70
+ # Need this for daisy-chained symlinks.
71
+ while
72
+ APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
73
+ [ -h "$app_path" ]
74
+ do
75
+ ls=$( ls -ld "$app_path" )
76
+ link=${ls#*' -> '}
77
+ case $link in #(
78
+ /*) app_path=$link ;; #(
79
+ *) app_path=$APP_HOME$link ;;
80
+ esac
37
81
  done
38
- SAVED="`pwd`"
39
- cd "`dirname \"$PRG\"`/.." >/dev/null
40
- APP_HOME="`pwd -P`"
41
- cd "$SAVED" >/dev/null
82
+
83
+ APP_HOME=$( cd "${APP_HOME:-./}.." && pwd -P ) || exit
42
84
 
43
85
  APP_NAME="sca-cmd"
44
- APP_BASE_NAME=`basename "$0"`
86
+ APP_BASE_NAME=${0##*/}
45
87
 
46
88
  # Add default JVM options here. You can also use JAVA_OPTS and SCA_CMD_OPTS to pass JVM options to this script.
47
89
  DEFAULT_JVM_OPTS=""
48
90
 
49
91
  # Use the maximum available, or set MAX_FD != -1 to use that value.
50
- MAX_FD="maximum"
92
+ MAX_FD=maximum
51
93
 
52
94
  warn () {
53
95
  echo "$*"
54
- }
96
+ } >&2
55
97
 
56
98
  die () {
57
99
  echo
58
100
  echo "$*"
59
101
  echo
60
102
  exit 1
61
- }
103
+ } >&2
62
104
 
63
105
  # OS specific support (must be 'true' or 'false').
64
106
  cygwin=false
65
107
  msys=false
66
108
  darwin=false
67
109
  nonstop=false
68
- case "`uname`" in
69
- CYGWIN* )
70
- cygwin=true
71
- ;;
72
- Darwin* )
73
- darwin=true
74
- ;;
75
- MINGW* )
76
- msys=true
77
- ;;
78
- NONSTOP* )
79
- nonstop=true
80
- ;;
110
+ case "$( uname )" in #(
111
+ CYGWIN* ) cygwin=true ;; #(
112
+ Darwin* ) darwin=true ;; #(
113
+ MSYS* | MINGW* ) msys=true ;; #(
114
+ NONSTOP* ) nonstop=true ;;
81
115
  esac
82
116
 
83
- CLASSPATH=$APP_HOME/lib/sca-cmd.jar:$APP_HOME/lib/sca-library.jar:$APP_HOME/lib/commons-cli-1.4.jar:$APP_HOME/lib/jackson-module-jaxb-annotations-2.12.2.jar:$APP_HOME/lib/jackson-databind-2.12.2.jar:$APP_HOME/lib/jackson-annotations-2.12.2.jar:$APP_HOME/lib/jackson-core-2.12.2.jar:$APP_HOME/lib/jackson-dataformat-xml-2.12.2.jar:$APP_HOME/lib/commons-io-2.8.0.jar:$APP_HOME/lib/commons-lang3-3.12.0.jar:$APP_HOME/lib/commons-compress-1.20.jar:$APP_HOME/lib/woodstox-core-6.2.4.jar:$APP_HOME/lib/stax2-api-4.2.1.jar:$APP_HOME/lib/jakarta.xml.bind-api-2.3.2.jar:$APP_HOME/lib/jakarta.activation-api-1.2.1.jar
117
+ CLASSPATH=$APP_HOME/lib/sca-cmd.jar:$APP_HOME/lib/sca-library.jar:$APP_HOME/lib/utils-2.3.0.jar:$APP_HOME/lib/configuration-2.0.0.jar:$APP_HOME/lib/compress-2.3.1.jar:$APP_HOME/lib/io-2.4.0.jar:$APP_HOME/lib/imaging-2.0.0.jar:$APP_HOME/lib/manifest-2.3.0.jar:$APP_HOME/lib/commons-cli-1.5.0.jar:$APP_HOME/lib/jackson-databind-2.13.1.jar:$APP_HOME/lib/jackson-core-2.13.1.jar:$APP_HOME/lib/jackson-annotations-2.13.1.jar:$APP_HOME/lib/jackson-dataformat-xml-2.13.1.jar:$APP_HOME/lib/commons-lang3-3.12.0.jar:$APP_HOME/lib/woodstox-core-6.2.7.jar:$APP_HOME/lib/stax2-api-4.2.1.jar:$APP_HOME/lib/commons-compress-1.21.jar:$APP_HOME/lib/commons-io-2.11.0.jar
84
118
 
85
119
 
86
120
  # Determine the Java command to use to start the JVM.
87
121
  if [ -n "$JAVA_HOME" ] ; then
88
122
  if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
89
123
  # IBM's JDK on AIX uses strange locations for the executables
90
- JAVACMD="$JAVA_HOME/jre/sh/java"
124
+ JAVACMD=$JAVA_HOME/jre/sh/java
91
125
  else
92
- JAVACMD="$JAVA_HOME/bin/java"
126
+ JAVACMD=$JAVA_HOME/bin/java
93
127
  fi
94
128
  if [ ! -x "$JAVACMD" ] ; then
95
129
  die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
@@ -98,7 +132,7 @@ Please set the JAVA_HOME variable in your environment to match the
98
132
  location of your Java installation."
99
133
  fi
100
134
  else
101
- JAVACMD="java"
135
+ JAVACMD=java
102
136
  which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
103
137
 
104
138
  Please set the JAVA_HOME variable in your environment to match the
@@ -106,80 +140,94 @@ location of your Java installation."
106
140
  fi
107
141
 
108
142
  # Increase the maximum file descriptors if we can.
109
- if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
110
- MAX_FD_LIMIT=`ulimit -H -n`
111
- if [ $? -eq 0 ] ; then
112
- if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
113
- MAX_FD="$MAX_FD_LIMIT"
114
- fi
115
- ulimit -n $MAX_FD
116
- if [ $? -ne 0 ] ; then
117
- warn "Could not set maximum file descriptor limit: $MAX_FD"
118
- fi
119
- else
120
- warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
121
- fi
143
+ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
144
+ case $MAX_FD in #(
145
+ max*)
146
+ MAX_FD=$( ulimit -H -n ) ||
147
+ warn "Could not query maximum file descriptor limit"
148
+ esac
149
+ case $MAX_FD in #(
150
+ '' | soft) :;; #(
151
+ *)
152
+ ulimit -n "$MAX_FD" ||
153
+ warn "Could not set maximum file descriptor limit to $MAX_FD"
154
+ esac
122
155
  fi
123
156
 
124
- # For Darwin, add options to specify how the application appears in the dock
125
- if $darwin; then
126
- GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
127
- fi
157
+ # Collect all arguments for the java command, stacking in reverse order:
158
+ # * args from the command line
159
+ # * the main class name
160
+ # * -classpath
161
+ # * -D...appname settings
162
+ # * --module-path (only if needed)
163
+ # * DEFAULT_JVM_OPTS, JAVA_OPTS, and SCA_CMD_OPTS environment variables.
128
164
 
129
165
  # For Cygwin or MSYS, switch paths to Windows format before running java
130
- if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
131
- APP_HOME=`cygpath --path --mixed "$APP_HOME"`
132
- CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
133
-
134
- JAVACMD=`cygpath --unix "$JAVACMD"`
135
-
136
- # We build the pattern for arguments to be converted via cygpath
137
- ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
138
- SEP=""
139
- for dir in $ROOTDIRSRAW ; do
140
- ROOTDIRS="$ROOTDIRS$SEP$dir"
141
- SEP="|"
142
- done
143
- OURCYGPATTERN="(^($ROOTDIRS))"
144
- # Add a user-defined pattern to the cygpath arguments
145
- if [ "$GRADLE_CYGPATTERN" != "" ] ; then
146
- OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
147
- fi
166
+ if "$cygwin" || "$msys" ; then
167
+ APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
168
+ CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
169
+
170
+ JAVACMD=$( cygpath --unix "$JAVACMD" )
171
+
148
172
  # Now convert the arguments - kludge to limit ourselves to /bin/sh
149
- i=0
150
- for arg in "$@" ; do
151
- CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
152
- CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
153
-
154
- if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
155
- eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
156
- else
157
- eval `echo args$i`="\"$arg\""
173
+ for arg do
174
+ if
175
+ case $arg in #(
176
+ -*) false ;; # don't mess with options #(
177
+ /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
178
+ [ -e "$t" ] ;; #(
179
+ *) false ;;
180
+ esac
181
+ then
182
+ arg=$( cygpath --path --ignore --mixed "$arg" )
158
183
  fi
159
- i=`expr $i + 1`
184
+ # Roll the args list around exactly as many times as the number of
185
+ # args, so each arg winds up back in the position where it started, but
186
+ # possibly modified.
187
+ #
188
+ # NB: a `for` loop captures its iteration list before it begins, so
189
+ # changing the positional parameters here affects neither the number of
190
+ # iterations, nor the values presented in `arg`.
191
+ shift # remove old arg
192
+ set -- "$@" "$arg" # push replacement arg
160
193
  done
161
- case $i in
162
- 0) set -- ;;
163
- 1) set -- "$args0" ;;
164
- 2) set -- "$args0" "$args1" ;;
165
- 3) set -- "$args0" "$args1" "$args2" ;;
166
- 4) set -- "$args0" "$args1" "$args2" "$args3" ;;
167
- 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
168
- 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
169
- 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
170
- 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
171
- 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
172
- esac
173
194
  fi
174
195
 
175
- # Escape application args
176
- save () {
177
- for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
178
- echo " "
179
- }
180
- APP_ARGS=`save "$@"`
196
+ # Collect all arguments for the java command;
197
+ # * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $SCA_CMD_OPTS can contain fragments of
198
+ # shell script including quotes and variable substitutions, so put them in
199
+ # double quotes to make sure that they get re-expanded; and
200
+ # * put everything else in single quotes, so that it's not re-expanded.
201
+
202
+ set -- \
203
+ -classpath "$CLASSPATH" \
204
+ com.roku.sca.cmd.CommandLineInterface \
205
+ "$@"
206
+
207
+ # Use "xargs" to parse quoted args.
208
+ #
209
+ # With -n1 it outputs one arg per line, with the quotes and backslashes removed.
210
+ #
211
+ # In Bash we could simply go:
212
+ #
213
+ # readarray ARGS < <( xargs -n1 <<<"$var" ) &&
214
+ # set -- "${ARGS[@]}" "$@"
215
+ #
216
+ # but POSIX shell has neither arrays nor command substitution, so instead we
217
+ # post-process each arg (as a line of input to sed) to backslash-escape any
218
+ # character that might be a shell metacharacter, then use eval to reverse
219
+ # that process (while maintaining the separation between arguments), and wrap
220
+ # the whole thing up as a single "set" statement.
221
+ #
222
+ # This will of course break if any of these variables contains a newline or
223
+ # an unmatched quote.
224
+ #
181
225
 
182
- # Collect all arguments for the java command, following the shell quoting and substitution rules
183
- eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $SCA_CMD_OPTS -classpath "\"$CLASSPATH\"" com.roku.sca.cmd.CommandLineInterface "$APP_ARGS"
226
+ eval "set -- $(
227
+ printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $SCA_CMD_OPTS" |
228
+ xargs -n1 |
229
+ sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
230
+ tr '\n' ' '
231
+ )" '"$@"'
184
232
 
185
233
  exec "$JAVACMD" "$@"
@@ -67,7 +67,7 @@ goto fail
67
67
  :execute
68
68
  @rem Setup the command line
69
69
 
70
- set CLASSPATH=%APP_HOME%\lib\sca-cmd.jar;%APP_HOME%\lib\sca-library.jar;%APP_HOME%\lib\commons-cli-1.4.jar;%APP_HOME%\lib\jackson-module-jaxb-annotations-2.12.2.jar;%APP_HOME%\lib\jackson-databind-2.12.2.jar;%APP_HOME%\lib\jackson-annotations-2.12.2.jar;%APP_HOME%\lib\jackson-core-2.12.2.jar;%APP_HOME%\lib\jackson-dataformat-xml-2.12.2.jar;%APP_HOME%\lib\commons-io-2.8.0.jar;%APP_HOME%\lib\commons-lang3-3.12.0.jar;%APP_HOME%\lib\commons-compress-1.20.jar;%APP_HOME%\lib\woodstox-core-6.2.4.jar;%APP_HOME%\lib\stax2-api-4.2.1.jar;%APP_HOME%\lib\jakarta.xml.bind-api-2.3.2.jar;%APP_HOME%\lib\jakarta.activation-api-1.2.1.jar
70
+ set CLASSPATH=%APP_HOME%\lib\sca-cmd.jar;%APP_HOME%\lib\sca-library.jar;%APP_HOME%\lib\utils-2.3.0.jar;%APP_HOME%\lib\configuration-2.0.0.jar;%APP_HOME%\lib\compress-2.3.1.jar;%APP_HOME%\lib\io-2.4.0.jar;%APP_HOME%\lib\imaging-2.0.0.jar;%APP_HOME%\lib\manifest-2.3.0.jar;%APP_HOME%\lib\commons-cli-1.5.0.jar;%APP_HOME%\lib\jackson-databind-2.13.1.jar;%APP_HOME%\lib\jackson-core-2.13.1.jar;%APP_HOME%\lib\jackson-annotations-2.13.1.jar;%APP_HOME%\lib\jackson-dataformat-xml-2.13.1.jar;%APP_HOME%\lib\commons-lang3-3.12.0.jar;%APP_HOME%\lib\woodstox-core-6.2.7.jar;%APP_HOME%\lib\stax2-api-4.2.1.jar;%APP_HOME%\lib\commons-compress-1.21.jar;%APP_HOME%\lib\commons-io-2.11.0.jar
71
71
 
72
72
 
73
73
  @rem Execute sca-cmd
@@ -2,5 +2,5 @@
2
2
 
3
3
  module RokuBuilder
4
4
  # Version of the RokuBuilder Gem
5
- VERSION = "4.25.1"
5
+ VERSION = "4.25.5"
6
6
  end
@@ -41,16 +41,6 @@ module RokuBuilder
41
41
  assert_equal Array, warnings.class
42
42
  assert_equal 0, warnings.count
43
43
  end
44
- def test_performance_function_return_types
45
- warnings = test_file(text: "function test() as String\n? \"test\"\nend function")
46
- assert_equal 1, warnings.count
47
- assert_match(/function return/, warnings[0][:message])
48
- end
49
- def test_performance_function_return_types_lowercase
50
- warnings = test_file(text: "function test() as string\n? \"test\"\nend function")
51
- assert_equal 1, warnings.count
52
- assert_match(/function return/, warnings[0][:message])
53
- end
54
44
  def test_performance_aa_does_exist
55
45
  warnings = test_file(text: "exists = aa.doesExist(\"test\")")
56
46
  assert_equal 1, warnings.count
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: roku_builder
3
3
  version: !ruby/object:Gem::Version
4
- version: 4.25.1
4
+ version: 4.25.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - greeneca
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-03-10 00:00:00.000000000 Z
11
+ date: 2022-05-30 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rubyzip
@@ -499,6 +499,8 @@ files:
499
499
  - lib/roku_builder/plugins/packager.rb
500
500
  - lib/roku_builder/plugins/performance_config.json
501
501
  - lib/roku_builder/plugins/profiler.rb
502
+ - lib/roku_builder/plugins/sca-cmd/LICENSE
503
+ - lib/roku_builder/plugins/sca-cmd/README.md
502
504
  - lib/roku_builder/plugins/sca-cmd/bin/sca-cmd
503
505
  - lib/roku_builder/plugins/sca-cmd/bin/sca-cmd.bat
504
506
  - lib/roku_builder/plugins/sca-cmd/lib/sca-cmd.jar