From 02ea4c5218955d89fa9e7f90c06714379a9e440c Mon Sep 17 00:00:00 2001 From: "Ian A. Mason" Date: Tue, 24 Mar 2020 12:55:59 -0700 Subject: [PATCH] Complaints from the peanut gallery. --- shared/environment.go | 5 +++-- shared/extractor.go | 22 +++++++++++----------- 2 files changed, 14 insertions(+), 13 deletions(-) diff --git a/shared/environment.go b/shared/environment.go index 8277b10..999b5f9 100644 --- a/shared/environment.go +++ b/shared/environment.go @@ -108,6 +108,7 @@ func init() { FetchEnvironment() } +// PrintEnvironment is used for printing the aspects of the environment that concern us func PrintEnvironment() { vars := []string{envpath, envcc, envcxx, envar, envlnk, envcfg, envbc, envlvl, envfile, envobjcopy, envld, envbcgen} @@ -123,7 +124,7 @@ func PrintEnvironment() { } -// also used in testing +// ResetEnvironment resets the globals, it is only used in testing func ResetEnvironment() { LLVMToolChainBinDir = "" LLVMCCName = "" @@ -139,7 +140,7 @@ func ResetEnvironment() { LLVMbcGen = []string{} } -// also used in testing +// FetchEnvironment is used in initializing our globals, it is also used in testing func FetchEnvironment() { LLVMToolChainBinDir = os.Getenv(envpath) LLVMCCName = os.Getenv(envcc) diff --git a/shared/extractor.go b/shared/extractor.go index 1361880..c4b97db 100644 --- a/shared/extractor.go +++ b/shared/extractor.go @@ -50,7 +50,7 @@ import ( "strings" ) -//for distilling the desired commandline options +//ExtractionArgs encapsulate the results of parsing the commandline options type ExtractionArgs struct { Failure bool // indicates failure in parsing the cmd line args Verbose bool // inform the user of what is going on @@ -91,6 +91,7 @@ ea.ArchiverName: %v ea.LlvmLinkerName, ea.ArchiverName) } +//ParseSwitches parses the command line into an ExtractionArgs object. func ParseSwitches(args []string) (ea ExtractionArgs) { var flagSet *flag.FlagSet = flag.NewFlagSet(args[0], flag.ContinueOnError) @@ -656,17 +657,16 @@ func linkBitcodeFiles(ea ExtractionArgs, filesToLink []string) (success bool) { } if getsize(filesToLink) > argMax { //command line size too large for the OS (necessitated by chromium) return linkBitcodeFilesIncrementally(ea, filesToLink, argMax, linkArgs) - } else { - var err error - linkArgs = append(linkArgs, "-o", ea.OutputFile) - linkArgs = append(linkArgs, filesToLink...) - success, err = execCmd(ea.LlvmLinkerName, linkArgs, "") - if !success { - LogError("There was an error linking input files into %s because %v.\n", ea.OutputFile, err) - return - } - informUser("Bitcode file extracted to: %s.\n", ea.OutputFile) } + var err error + linkArgs = append(linkArgs, "-o", ea.OutputFile) + linkArgs = append(linkArgs, filesToLink...) + success, err = execCmd(ea.LlvmLinkerName, linkArgs, "") + if !success { + LogError("There was an error linking input files into %s because %v.\n", ea.OutputFile, err) + return + } + informUser("Bitcode file extracted to: %s.\n", ea.OutputFile) success = true return }