Module: Psychgus::Stylables::NoSymStylable

Includes:
Psychgus::Styler
Included in:
Psychgus::Stylers::NoSymStyler
Defined in:
lib/psychgus/stylables.rb

Overview

A Symbol remover for Scalars.

Examples:

require 'psychgus'

data = {
  :eggs => {
    :styles => ['Fried', 'Scrambled', ['BBQ', 'Ketchup']],
    :colors => ['Brown', 'White', ['Blue', 'Green']]
}}

flow = Psychgus::FlowStyler.new(4)

puts data.to_yaml(stylers: [Psychgus::NoSymStyler.new,flow])

# Output:
# ---
# Eggs:
#   Styles: [Fried, Scrambled, [BBQ, Ketchup]]
#   Colors: [Brown, White, [Blue, Green]]

puts data.to_yaml(stylers: [Psychgus::NoSymStyler.new(cap: false),flow])

# ---
# eggs:
#   styles: [Fried, Scrambled, [BBQ, Ketchup]]
#   colors: [Brown, White, [Blue, Green]]

See Also:

Constant Summary

Constants included from Psychgus::Styler

Psychgus::Styler::EMPTY

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Psychgus::Styler

#style, #style_alias, #style_document, #style_mapping, #style_sequence, #style_stream

Instance Attribute Details

#captrue, false Also known as: cap?

Returns whether to capitalize the symbol.

Returns:

  • (true, false)

    whether to capitalize the symbol



196
197
198
# File 'lib/psychgus/stylables.rb', line 196

def cap
  @cap
end

Instance Method Details

#initialize(cap: true, **kargs) ⇒ Object

Parameters:

  • cap (true, false) (defaults to: true)

    whether to capitalize the symbol

  • kargs (Hash)

    capture extra keyword args, so no error for undefined args



202
203
204
# File 'lib/psychgus/stylables.rb', line 202

def initialize(cap: true,**kargs)
  @cap = cap
end

#style_scalar(sniffer, node) ⇒ Object

If node.value is a symbol, change it into a string and capitalize it.



209
210
211
212
213
214
215
# File 'lib/psychgus/stylables.rb', line 209

def style_scalar(sniffer,node)
  return if node.value.nil? || node.value.empty?
  return if node.value[0] != ':'

  node.value = node.value[1..-1]
  node.value = node.value.capitalize if @cap
end