From 10bc0171899f79bfc4196509ba31f1adc234f39b Mon Sep 17 00:00:00 2001 From: Henry Coles Date: Fri, 13 Dec 2024 09:53:11 +0000 Subject: [PATCH] remove duplication parsing booleans --- .../commandline/OptionsParser.java | 52 ++++++++----------- 1 file changed, 22 insertions(+), 30 deletions(-) diff --git a/pitest-command-line/src/main/java/org/pitest/mutationtest/commandline/OptionsParser.java b/pitest-command-line/src/main/java/org/pitest/mutationtest/commandline/OptionsParser.java index 6c5c7404a..8e8bec934 100644 --- a/pitest-command-line/src/main/java/org/pitest/mutationtest/commandline/OptionsParser.java +++ b/pitest-command-line/src/main/java/org/pitest/mutationtest/commandline/OptionsParser.java @@ -457,21 +457,16 @@ private ParseResult parseCommandLine(final ReportOptions data, data.setArgLine(this.argLine.value(userArgs)); data.addChildJVMArgs(this.jvmArgsProcessor.values(userArgs)); - data.setFullMutationMatrix( - (userArgs.has(this.fullMutationMatrixSpec) && !userArgs.hasArgument(this.fullMutationMatrixSpec)) - || this.fullMutationMatrixSpec.value(userArgs)); - data.setDetectInlinedCode( - (userArgs.has(this.detectInlinedCode) && !userArgs.hasArgument(this.detectInlinedCode)) - || this.detectInlinedCode.value(userArgs)); - data.setIncludeLaunchClasspath( - (userArgs.has(this.includeLaunchClasspathSpec) && !userArgs.hasArgument(this.includeLaunchClasspathSpec)) - || this.includeLaunchClasspathSpec.value(userArgs)); - data.setUseClasspathJar( - (userArgs.has(this.useClasspathJarSpec) && !userArgs.hasArgument(this.useClasspathJarSpec)) - || this.useClasspathJarSpec.value(userArgs)); - data.setShouldCreateTimestampedReports( - (userArgs.has(this.timestampedReportsSpec) && !userArgs.hasArgument(this.timestampedReportsSpec)) - || this.timestampedReportsSpec.value(userArgs)); + data.setFullMutationMatrix(booleanValue(fullMutationMatrixSpec, userArgs)); + + data.setDetectInlinedCode(booleanValue(detectInlinedCode, userArgs)); + + data.setIncludeLaunchClasspath(booleanValue(includeLaunchClasspathSpec, userArgs)); + + data.setUseClasspathJar(booleanValue(useClasspathJarSpec, userArgs)); + + data.setShouldCreateTimestampedReports(booleanValue(timestampedReportsSpec, userArgs)); + data.setNumberOfThreads(this.threadsSpec.value(userArgs)); data.setTimeoutFactor(this.timeoutFactorSpec.value(userArgs)); data.setTimeoutConstant(this.timeoutConstSpec.value(userArgs)); @@ -484,12 +479,10 @@ private ParseResult parseCommandLine(final ReportOptions data, configureVerbosity(data, userArgs); data.addOutputFormats(this.outputFormatSpec.values(userArgs)); - data.setFailWhenNoMutations( - (userArgs.has(this.failWhenNoMutations) && !userArgs.hasArgument(this.failWhenNoMutations)) - || this.failWhenNoMutations.value(userArgs)); - data.setSkipFailingTests( - (userArgs.has(this.skipFailingTests) && !userArgs.hasArgument(this.skipFailingTests)) - || this.skipFailingTests.value(userArgs)); + data.setFailWhenNoMutations(booleanValue(failWhenNoMutations, userArgs)); + + data.setSkipFailingTests(booleanValue(skipFailingTests, userArgs)); + data.setCodePaths(this.codePaths.values(userArgs)); data.setMutationUnitSize(this.mutationUnitSizeSpec.value(userArgs)); data.setHistoryInputLocation(this.historyInputSpec.value(userArgs)); @@ -500,9 +493,7 @@ private ParseResult parseCommandLine(final ReportOptions data, data.setCoverageThreshold(this.coverageThreshHoldSpec.value(userArgs)); data.setMutationEngine(this.mutationEngine.value(userArgs)); data.setFreeFormProperties(listToProperties(this.pluginPropertiesSpec.values(userArgs))); - data.setExportLineCoverage( - (userArgs.has(this.exportLineCoverageSpec) && !userArgs.hasArgument(this.exportLineCoverageSpec)) - || this.exportLineCoverageSpec.value(userArgs)); + data.setExportLineCoverage(booleanValue(exportLineCoverageSpec, userArgs)); setClassPath(userArgs, data); @@ -534,9 +525,7 @@ private void setEncoding(ReportOptions data, OptionSet userArgs) { } private void configureVerbosity(ReportOptions data, OptionSet userArgs) { - boolean isVerbose = (userArgs.has(this.verboseSpec) && !userArgs.hasArgument(this.verboseSpec)) - || this.verboseSpec.value(userArgs); - if (isVerbose) { + if (booleanValue(verboseSpec, userArgs)) { data.setVerbosity(Verbosity.VERBOSE); } else { data.setVerbosity(Verbosity.fromString(this.verbositySpec.value(userArgs))); @@ -545,13 +534,12 @@ private void configureVerbosity(ReportOptions data, OptionSet userArgs) { } private void configureExecutionMode(ReportOptions data, OptionSet userArgs) { - boolean isDryRun = (userArgs.has(this.dryRunSpec) && !userArgs.hasArgument(this.dryRunSpec)) - || this.dryRunSpec.value(userArgs); - if (isDryRun) { + if (booleanValue(dryRunSpec, userArgs)) { data.setExecutionMode(ExecutionMode.DRY_RUN); } } + private void setClassPath(final OptionSet userArgs, final ReportOptions data) { final List elements = new ArrayList<>(); @@ -607,5 +595,9 @@ public void printHelp() { } } + private boolean booleanValue(ArgumentAcceptingOptionSpec spec, OptionSet userArgs) { + return (userArgs.has(spec) && !userArgs.hasArgument(spec)) + || spec.value(userArgs); + } }