Class: XCPretty::Formatter

Inherits:
Object
  • Object
show all
Includes:
ANSI, FormatMethods
Defined in:
lib/xcpretty/formatters/formatter.rb

Direct Known Subclasses

Knock, RSpec, Reporter, Simple

Constant Summary collapse

ERROR =
''
ASCII_ERROR =
'[x]'
WARNING =
'⚠️ '
ASCII_WARNING =
'[!]'

Constants included from FormatMethods

XCPretty::FormatMethods::EMPTY

Constants included from ANSI

ANSI::COLORS, ANSI::EFFECT, ANSI::FORMATTED_MATCHER

Instance Attribute Summary collapse

Attributes included from ANSI

#colorize

Instance Method Summary collapse

Methods included from FormatMethods

#format_aggregate_target, #format_analyze, #format_analyze_target, #format_build_target, #format_check_dependencies, #format_clean, #format_clean_remove, #format_clean_target, #format_codesign, #format_compile, #format_compile_command, #format_compile_storyboard, #format_compile_xib, #format_copy_header_file, #format_copy_plist_file, #format_copy_strings_file, #format_cpresource, #format_failing_test, #format_generate_dsym, #format_libtool, #format_linking, #format_measuring_test, #format_passing_test, #format_pbxcp, #format_pending_test, #format_phase_script_execution, #format_phase_success, #format_preprocess, #format_process_info_plist, #format_process_pch, #format_process_pch_command, #format_shell_command, #format_test_run_finished, #format_test_run_started, #format_test_suite_started, #format_tiffutil, #format_touch, #format_warning, #format_write_auxiliary_files, #format_write_file

Methods included from ANSI

#ansi_parse, #applied_effects, #colorize?, #cyan, #green, #red, #strip, #white, #yellow

Constructor Details

#initialize(use_unicode, colorize) ⇒ Formatter

Returns a new instance of Formatter.



76
77
78
79
80
# File 'lib/xcpretty/formatters/formatter.rb', line 76

def initialize(use_unicode, colorize)
  @use_unicode = use_unicode
  @colorize = colorize
  @parser = Parser.new(self)
end

Instance Attribute Details

#parserObject (readonly)

Returns the value of attribute parser.



74
75
76
# File 'lib/xcpretty/formatters/formatter.rb', line 74

def parser
  @parser
end

Instance Method Details

#finishObject



82
83
# File 'lib/xcpretty/formatters/formatter.rb', line 82

def finish
end

#format_compile_error(file, file_path, reason, line, cursor) ⇒ Object



122
123
124
125
# File 'lib/xcpretty/formatters/formatter.rb', line 122

def format_compile_error(file, file_path, reason, line, cursor)
  "\n#{red(error_symbol + " ")}#{file_path}: #{red(reason)}\n\n" \
    "#{line}\n#{cyan(cursor)}\n\n"
end

#format_compile_warning(file, file_path, reason, line, cursor) ⇒ Object



131
132
133
134
# File 'lib/xcpretty/formatters/formatter.rb', line 131

def format_compile_warning(file, file_path, reason, line, cursor)
  "\n#{yellow(warning_symbol + ' ')}#{file_path}: #{yellow(reason)}\n\n" \
    "#{line}\n#{cyan(cursor)}\n\n"
end

#format_duplicate_symbols(message, file_paths) ⇒ Object



146
147
148
149
# File 'lib/xcpretty/formatters/formatter.rb', line 146

def format_duplicate_symbols(message, file_paths)
  "\n#{red(error_symbol + " " + message)}\n" \
    "> #{file_paths.map { |path| path.split('/').last }.join("\n> ")}\n"
end

#format_error(message) ⇒ Object



118
119
120
# File 'lib/xcpretty/formatters/formatter.rb', line 118

def format_error(message)
  "\n#{red(error_symbol + " " + message)}\n\n"
end

#format_file_missing_error(reason, file_path) ⇒ Object



127
128
129
# File 'lib/xcpretty/formatters/formatter.rb', line 127

def format_file_missing_error(reason, file_path)
  "\n#{red(error_symbol + " " + reason)} #{file_path}\n\n"
end

#format_ld_warning(reason) ⇒ Object



136
137
138
# File 'lib/xcpretty/formatters/formatter.rb', line 136

def format_ld_warning(reason)
  "#{yellow(warning_symbol + ' ' + reason)}"
end

#format_test_summary(executed_message, failures_per_suite) ⇒ Object

Will be printed by default. Override with ” if you don’t want summary



100
101
102
103
104
105
106
107
108
109
110
# File 'lib/xcpretty/formatters/formatter.rb', line 100

def format_test_summary(executed_message, failures_per_suite)
  failures = format_failures(failures_per_suite)
  if failures.empty?
    final_message = green(executed_message)
  else
    final_message = red(executed_message)
  end

  text = [failures, final_message].join("\n\n\n").strip
  "\n\n#{text}"
end

#format_undefined_symbols(message, symbol, reference) ⇒ Object



140
141
142
143
144
# File 'lib/xcpretty/formatters/formatter.rb', line 140

def format_undefined_symbols(message, symbol, reference)
  "\n#{red(error_symbol + " " + message)}\n" \
    "> Symbol: #{symbol}\n" \
    "> Referenced from: #{reference}\n\n"
end

#format_will_not_be_code_signed(message) ⇒ Object



151
152
153
# File 'lib/xcpretty/formatters/formatter.rb', line 151

def format_will_not_be_code_signed(message)
  "#{yellow(warning_symbol + " " + message)}"
end

#optional_newlineObject

If you want to print inline, override #optional_newline with ”



91
92
93
# File 'lib/xcpretty/formatters/formatter.rb', line 91

def optional_newline
  "\n"
end

#pretty_format(text) ⇒ Object

Override if you want to catch something specific with your regex



86
87
88
# File 'lib/xcpretty/formatters/formatter.rb', line 86

def pretty_format(text)
  parser.parse(text)
end

#use_unicode?Boolean

Returns:

  • (Boolean)


95
96
97
# File 'lib/xcpretty/formatters/formatter.rb', line 95

def use_unicode?
  !!@use_unicode
end