Merge "Suppress all progress messages from Ninja if ANDROID_QUIET_BUILD is set."

This commit is contained in:
Alexander Smundak
2021-12-12 22:26:58 +00:00
committed by Gerrit Code Review
2 changed files with 21 additions and 12 deletions

View File

@@ -22,32 +22,41 @@ import (
) )
type simpleStatusOutput struct { type simpleStatusOutput struct {
writer io.Writer writer io.Writer
formatter formatter formatter formatter
keepANSI bool keepANSI bool
outputLevel status.MsgLevel
} }
// NewSimpleStatusOutput returns a StatusOutput that represents the // NewSimpleStatusOutput returns a StatusOutput that represents the
// current build status similarly to Ninja's built-in terminal // current build status similarly to Ninja's built-in terminal
// output. // output.
func NewSimpleStatusOutput(w io.Writer, formatter formatter, keepANSI bool) status.StatusOutput { func NewSimpleStatusOutput(w io.Writer, formatter formatter, keepANSI bool, quietBuild bool) status.StatusOutput {
level := status.StatusLvl
if quietBuild {
level = status.PrintLvl
}
return &simpleStatusOutput{ return &simpleStatusOutput{
writer: w, writer: w,
formatter: formatter, formatter: formatter,
keepANSI: keepANSI, keepANSI: keepANSI,
outputLevel: level,
} }
} }
func (s *simpleStatusOutput) Message(level status.MsgLevel, message string) { func (s *simpleStatusOutput) Message(level status.MsgLevel, message string) {
if level >= status.StatusLvl { if level >= s.outputLevel {
fmt.Fprintln(s.writer, s.formatter.message(level, message)) fmt.Fprintln(s.writer, s.formatter.message(level, message))
} }
} }
func (s *simpleStatusOutput) StartAction(action *status.Action, counts status.Counts) { func (s *simpleStatusOutput) StartAction(_ *status.Action, _ status.Counts) {
} }
func (s *simpleStatusOutput) FinishAction(result status.ActionResult, counts status.Counts) { func (s *simpleStatusOutput) FinishAction(result status.ActionResult, counts status.Counts) {
if s.outputLevel > status.StatusLvl {
return
}
str := result.Description str := result.Description
if str == "" { if str == "" {
str = result.Command str = result.Command

View File

@@ -29,9 +29,9 @@ import (
func NewStatusOutput(w io.Writer, statusFormat string, forceSimpleOutput, quietBuild, forceKeepANSI bool) status.StatusOutput { func NewStatusOutput(w io.Writer, statusFormat string, forceSimpleOutput, quietBuild, forceKeepANSI bool) status.StatusOutput {
formatter := newFormatter(statusFormat, quietBuild) formatter := newFormatter(statusFormat, quietBuild)
if !forceSimpleOutput && isSmartTerminal(w) { if forceSimpleOutput || quietBuild || !isSmartTerminal(w) {
return NewSmartStatusOutput(w, formatter) return NewSimpleStatusOutput(w, formatter, forceKeepANSI, quietBuild)
} else { } else {
return NewSimpleStatusOutput(w, formatter, forceKeepANSI) return NewSmartStatusOutput(w, formatter)
} }
} }