Class: RBT::Cookbooks::ReportUselessDescriptions

Inherits:
Base show all
Defined in:
lib/rbt/checks_and_validations/report_useless_descriptions.rb

Overview

RBT::Cookbooks::ReportUselessDescriptions

Constant Summary collapse

DEFAULT_DESCRIPTION_OF_THE_PROGRAM =
#

DEFAULT_DESCRIPTION_OF_THE_PROGRAM

This is the generic description that was used in the past for the RBT project. If a .yml file still contains this String then we know that it is essentially an empty description, which should be improved on.

#
'Default description of the program.'
ALSO_OPEN_VIA_EDITOR =
#

ALSO_OPEN_VIA_EDITOR

If this variable is set to true then the problematic programs, that is programs that do not have a useful description, will be opened via the editor. This is mostly useful on my home system, since I can sanitize such problematic programs before publishing the whole gem.

#
true
SLEEP_FOR_THIS_AMOUNT =
#

SLEEP_FOR_THIS_AMOUNT

This sleep delay is only useful if we open the .yml file via an editor.

#
0.7

Constants inherited from LeanPrototype

LeanPrototype::ALL_COLOUR_METHODS, LeanPrototype::ARRAY_KDE_KONSOLE_COLOURS_IN_USE, LeanPrototype::DAY_NAMES, LeanPrototype::NAMESPACE, LeanPrototype::SILENT_REDIRECTION

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Base

#cat, #cd_back_to_the_current_working_directory, #consider_reporting_how_many_programs_are_registered, #cookbook_files?, #copy_recursively, #delete_code_of_conduct?, #determine_appdir_prefix_from_this_input, #directory_validation?, #do_not_show_names, #fast_return_file_size_of_this_program, #file_last_symlinked_program?, #file_programs_version_url, #gem_version, #is_a_64bit_system?, #is_ccache_available?, #is_porg_available?, #is_this_binary_registered?, #is_this_program_included?, #make_command?, #make_install_command?, #new_cookbook_instance_for, #program_exists?, #publish_list_of_all_programs_version, #rcp, registered_binaries?, #remove_symlink, #rename_kde_konsole_tab, #repackage, #report_n_programs, #report_working_directory, #return_compile_time_statistics, #return_n_random_characters, #return_version_of_this_program, #run_make_then_make_install, #sanitize_url1_entry, #set_source_directory, #show_overview_over_available_utility_scripts, #symlink_all_files_from_this_directory_to_that_directory, #system_tags?, #upload_list_of_all_programs_version, #use_yaml_database_for_tags?, #warn_and_exit, #wget

Methods inherited from LeanPrototype

#a_or_an?, #abbreviations?, #absolute_path, #action, #add_to_the_commandline_arguments, #all_binaries?, #all_files_from, #all_libraries?, #allowed_cookbook_entries?, #appdir_location_of?, #append_onto_the_internal_hash, #append_what_into, #archive_type_of?, #available_programs?, #be_quiet?, #be_verbose?, #begins_with_a_comment?, #capitalize_first_alphabetical_character, #cd_to_the_log_directory, #cd_to_the_temp_directory, #change_directory, #change_permission, #cheering_person?, #chmod, #chop_off_archive, #clear_commandline_arguments, #cliner, #coloured_and_padded_e, #coloured_and_padded_esystem, #coloured_esystem, #colourize_directory_for_system_results, #colourize_this_error, #colourize_this_file_path, #colourize_this_warning, #commandline_arguments?, #commandline_arguments_without_hyphens?, #comment, #convert_dd_mm_yyyy_to_its_long_variant, #convert_env_variable, #copy_directory, #copy_files, #cpr, #create_directory, #current_hour?, #dd_mmm_yyy, #debug, #debug?, #directory_expanded_cookbooks?, #disable_colours, #display_md5sum?, #do_not_debug, #does_the_cookbook_include_this_program?, #does_this_expanded_cookbook_file_exist_for_this_program?, #does_this_file_exist?, #does_this_file_exist_and_is_it_a_file?, #e, #eblue, #ecomment, #ecrimson, #edir, #editor?, #efancy, #eimp, #enable_colours, #enable_debug, #ensure_main_encoding_for, #eparse, #esystem, #esystem_gold, #etomato, #ewarn, #exit_program, #expanded_cookbooks_directory_exists?, #extract_this_archive, #extract_to?, #file_compiled_programs?, #file_dirname_retaining_trailing_slash, #file_predefined_installation_instructions?, #file_specification_of_registered_cookbook_entries, #find_cookbook_alias_for, #find_this_yaml_file, #first_argument?, #first_non_hyphen_argument?, #get_all_directories_from, #get_all_files_from, #get_all_programs, #get_date, #get_extended_date, #get_files_and_directories_from, #go_to_base_dir, #home_dir?, #host_system?, #infer_the_namespace, #internal_hash?, #internal_hash_set_commandline_arguments, #is_an_archive?, #is_directory?, #is_file?, #is_github_url?, #is_make_available?, #is_meson_installed?, #is_on_gobolinux?, #is_on_windows?, #is_roebe?, #is_superuser?, #is_symlink?, #is_this_a_header?, #is_this_a_library?, #is_this_program_included?, #iso_encoding?, #load_dataset_from_this_expanded_cookbook, #load_yaml, #load_yaml_file_from_the_cookbook_directory_for_this_program, #log_directory?, #main_encoding?, #meson_build_file_exists?, #months?, #move_file, #n_programs_are_available?, #n_programs_available?, #namespace?, #no_directory_exists_at, #no_directory_was_found_at, #no_opn, #no_such_file_exists, #open_in_browser, #open_in_editor, #opncomment, #opne, #opnef, #opnerev, #opnerror, #opnesystem, #opnewarn, #opnfancy, #opnn, #otomato, #packages_directory?, #path_to_this_expanded_cookbooks_dataset, #pkgconfig_directory?, #populate_the_internal_hash_with_default_values, #predefined_installation_instructions?, #prepend_this_commandline_argument, #program_version_of?, #project_base_directory?, #project_yaml_directory?, #query_path?, #rarrow?, #read_file, #read_file_in_default_encoding, #read_file_with_default_encoding, #readlines, #readlines_with_proper_encoding, #register_sigint, #registered_cookbook_entries?, #remove, #remove_archive_from_the_end, #remove_comments_from_each_line, #remove_directory, #remove_double_slashes, #remove_file, #remove_newlines, #remove_parens, #remove_symlink, #remove_the_first_commandline_argument, #remove_this_commandline_argument, #remove_this_entry_from_the_commandline_arguments, #remove_trailing_ANSII_escape_code, #remove_unnecessary_data_from_url, #rename, #report_pwd, #require_the_rbt_aliases, #reset_the_internal_hash, #return_all_archives_from_this_directory, #return_appdir_prefix, #return_commandline_arguments_with_leading_hyphens, #return_current_hour_minutes_second, #return_date, #return_day_of_the_month_based_on_utc, #return_full_time, #return_hours_minutes_seconds_based_on_utc, #return_location_to_this_programs_yaml_file, #return_month_based_on_this_number, #return_month_based_on_utc, #return_opnn, #return_program_name, #return_program_name_for_gobolinux_systems, #return_program_name_via_program_information, #return_pwd, #return_unicode_warning_symbol_or_empty_string, #return_utc, #return_utc_time_in_a_format_similar_to_slackware, #return_weekday_based_on_utc, #return_year_based_on_utc, #rev, #rpn, #run_simulation=, #run_simulation?, #sdir, #sdir_return_pwd, #set_be_silent, #set_be_verbose, #set_first_commandline_argument, #set_namespace, #set_use_colours, #set_use_opn, #set_xorg_buffer, #sfancy, #sfile, #silent_redirection?, #silently_create_this_directory_if_it_does_not_yet_exist, #simp, #source_base_directory?, #ssym, #stderr, #store_into_this_directory?, #string_right_arrow?, #swarn, #symlink, #sysbin_directory?, #sysetc_directory?, #sysinclude_directory?, #syslib_directory?, #sysshare_directory?, #system_directory?, #temp_directory?, #to_bool, #to_camelcase, #to_iso_encoding, #to_unicode, #today?, #touch, #try_to_require_beautiful_url, #try_to_require_the_environment_information_gem, #try_to_require_the_extracter_gem, #try_to_require_the_open_gem, #try_to_require_the_xorg_buffer, #try_to_require_wget, #try_to_return_a_special_compile_component, #unicode_cliner, #unicode_middle_cliner, #use_colours=, #use_colours?, #use_opn=, #use_opn?, #utf_encoding?, #verbose_truth, #word_wrap, #write_what_into, #write_what_into_via_unicode, #yes_or_no

Constructor Details

#initialize(i = ARGV, run_already = true) ⇒ ReportUselessDescriptions

#

initialize

#


73
74
75
76
77
78
79
80
81
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 73

def initialize(
    i           = ARGV,
    run_already = true
  )
  reset
  set_commandline_arguments(i)
  menu
  run if run_already
end

Class Method Details

.[](i = '') ⇒ Object

#

RBT::Cookbooks::ReportUselessDescriptions[]

#


213
214
215
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 213

def self.[](i = '')
  new(i)
end

Instance Method Details

#do_not_open_files_in_the_editorObject

#

do_not_open_files_in_the_editor

#


131
132
133
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 131

def do_not_open_files_in_the_editor
  @also_open_via_editor = false
end
#

menu (menu tag)

#


112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 112

def menu(
    i = commandline_arguments?
  )
  if i.is_a? Array
    i.each {|entry| menu(entry) }
  else
    case i
    # ===================================================================== #
    # === report_useless_descriptions --do-not-open
    # ===================================================================== #
    when /^-?-?do(-|_)?not(-|_)?open$/
      do_not_open_files_in_the_editor
    end
  end
end

#report_resultsObject Also known as: report

#

report_results (report tag)

#


177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 177

def report_results
  _ = @array_these_programs_are_problematic
  opne "A total of #{sfancy(_.size.to_s)} problematic "\
       "descriptions were found."
  if _.empty?
    opne "This is #{lightgreen('excellent')}! All programs "\
         "appear to have a useful description."
  else
    e
    _.each {|this_program|
      e "  - #{simp(this_program)}"
      if @also_open_via_editor
        target = File.basename(this_program.dup)
        target << '.yml' unless target.end_with? '.yml'
        unless target.start_with? RUBY_SRC_RBT_COOKBOOKS
          target.prepend(RUBY_SRC_RBT_COOKBOOKS)
        end 
        open_in_editor(target)
        sleep SLEEP_FOR_THIS_AMOUNT
      end
    }
    e
  end
end

#resetObject

#

reset (reset tag)

#


86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 86

def reset
  super()
  infer_the_namespace
  # ======================================================================= #
  # === @raw_cookbook
  # ======================================================================= #
  @raw_cookbook = actions(:raw_cookbook) { :fast }
  # ======================================================================= #
  # === @array_these_programs_are_problematic
  #
  # Store the problematic programs in the following Array:
  # ======================================================================= #
  @array_these_programs_are_problematic = []
  # ======================================================================= #
  # === @also_open_via_editor
  # ======================================================================= #
  @also_open_via_editor = ALSO_OPEN_VIA_EDITOR
  # ======================================================================= #
  # === @use_this_as_the_key_for_the_description
  # ======================================================================= #
  @use_this_as_the_key_for_the_description = :description
end

#runObject

#

run (run tag)

#


205
206
207
208
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 205

def run
  run_through_every_available_program
  report_results
end

#run_through_every_available_programObject Also known as: iterate_over_every_available_program

#

run_through_every_available_program

#


145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 145

def run_through_every_available_program
  available_programs?.each {|this_program|
    @raw_cookbook.clear

    hash = @raw_cookbook.load_this_program(this_program)

    if hash.has_key? @use_this_as_the_key_for_the_description
      description = hash[@use_this_as_the_key_for_the_description]
    end
    if hash.nil? or hash.empty?
      this_program_is_problematic(this_program)
    else
      # =================================================================== #
      # Nil descriptions or empty descriptions will be reported.
      # =================================================================== #
      if description.nil? or description.strip.empty?
        this_program_is_problematic(this_program)
      # =================================================================== #
      # As will those programs that conform to a default, but
      # pretty useless, description.
      # =================================================================== #
      elsif description.strip == DEFAULT_DESCRIPTION_OF_THE_PROGRAM
        this_program_is_problematic(this_program)
      # else # Else all seems fine.
      end
    end
  }
end

#this_program_is_problematic(this_program) ⇒ Object

#

this_program_is_problematic

#


138
139
140
# File 'lib/rbt/checks_and_validations/report_useless_descriptions.rb', line 138

def this_program_is_problematic(this_program)
  @array_these_programs_are_problematic << this_program
end