Class: Vedeu::Interfaces::Clear Private

Inherits:
Object
  • Object
show all
Includes:
Common
Defined in:
lib/vedeu/interfaces/clear.rb

Overview

This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.

Clear the named interface.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Common

#absent?, #array?, #boolean, #boolean?, #empty_value?, #escape?, #falsy?, #hash?, #line_model?, #numeric?, #positionable?, #present?, #snake_case, #stream_model?, #string?, #symbol?, #truthy?, #view_model?

Constructor Details

#initialize(name = Vedeu.focus) ⇒ Vedeu::Interfaces::Clear

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Return a new instance of Vedeu::Interfaces::Clear.

Parameters:

  • name (NilClass|Symbol|String) (defaults to: Vedeu.focus)

    The name of the model or target model to act upon. May default to ‘Vedeu.focus`.



34
35
36
# File 'lib/vedeu/interfaces/clear.rb', line 34

def initialize(name = Vedeu.focus)
  @name = present?(name) ? name : Vedeu.focus
end

Instance Attribute Details

#nameNilClass|Symbol|String (readonly, protected)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns The name of the model, the target model or the name of the associated model.

Returns:

  • (NilClass|Symbol|String)

    The name of the model, the target model or the name of the associated model.



47
48
49
# File 'lib/vedeu/interfaces/clear.rb', line 47

def name
  @name
end

Class Method Details

.by_nameArray<Array<Vedeu::Cells::Char>>

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

See Also:



26
27
28
29
30
# File 'lib/vedeu/interfaces/clear.rb', line 26

def render(name = Vedeu.focus)
  name || Vedeu.focus

  new(name).render
end

.clear_by_nameArray<Array<Vedeu::Cells::Char>>

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

See Also:



25
26
27
28
29
# File 'lib/vedeu/interfaces/clear.rb', line 25

def render(name = Vedeu.focus)
  name || Vedeu.focus

  new(name).render
end

.render(name = Vedeu.focus) ⇒ Array<Array<Vedeu::Cells::Char>>

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

See Also:



20
21
22
23
24
# File 'lib/vedeu/interfaces/clear.rb', line 20

def render(name = Vedeu.focus)
  name || Vedeu.focus

  new(name).render
end

Instance Method Details

#charsString (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns A string of blank characters.

Returns:

  • (String)

    A string of blank characters.



52
53
54
# File 'lib/vedeu/interfaces/clear.rb', line 52

def chars
  @_chars ||= (' ' * width)
end

#colourVedeu::Colours::Colour (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.



57
58
59
# File 'lib/vedeu/interfaces/clear.rb', line 57

def colour
  @_colour ||= interface.colour
end

#geometryVedeu::Geometries::Geometry (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns the named geometry from the geometries repository.



62
63
64
# File 'lib/vedeu/interfaces/clear.rb', line 62

def geometry
  @_geometry ||= Vedeu.geometries.by_name(name)
end

#heightFixnum (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Fixnum)


67
68
69
# File 'lib/vedeu/interfaces/clear.rb', line 67

def height
  @_height ||= geometry.height
end

#interfaceVedeu::Interfaces::Interface (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns the named interface/view from the interfaces repository.



72
73
74
# File 'lib/vedeu/interfaces/clear.rb', line 72

def interface
  Vedeu.interfaces.by_name(name)
end

#outputArray<Array<Vedeu::Cells::Char>> (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

For each visible line of the interface, set the foreground and background colours to those specified when the interface was defined, then starting write space characters over the area which the interface occupies.

Returns:



82
83
84
85
86
87
88
89
90
# File 'lib/vedeu/interfaces/clear.rb', line 82

def output
  Vedeu.timer("Clearing interface: '#{name}'") do
    @_clear ||= Array.new(height) do |iy|
      Array.new(width) do |ix|
        Vedeu::Cells::Clear.new(output_attributes(iy, ix))
      end
    end
  end
end

#output_attributes(iy, ix) ⇒ Hash<Symbol => ] (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns Hash<Symbol => ].

Parameters:

  • iy (Fixnum)
  • ix (Fixnum)

Returns:

  • (Hash<Symbol => ])

    Hash<Symbol => ]



95
96
97
98
99
100
101
# File 'lib/vedeu/interfaces/clear.rb', line 95

def output_attributes(iy, ix)
  {
    colour:   colour,
    name:     name,
    position: Vedeu::Geometries::Position.new((y + iy), (x + ix)),
  }
end

#renderArray<Array<Vedeu::Cells::Char>>

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:



39
40
41
# File 'lib/vedeu/interfaces/clear.rb', line 39

def render
  Vedeu.render_output(output)
end

#widthFixnum (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Fixnum)


104
105
106
# File 'lib/vedeu/interfaces/clear.rb', line 104

def width
  @_width ||= geometry.width
end

#xFixnum (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Fixnum)


114
115
116
# File 'lib/vedeu/interfaces/clear.rb', line 114

def x
  @_x ||= geometry.x
end

#yFixnum (private)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Fixnum)


109
110
111
# File 'lib/vedeu/interfaces/clear.rb', line 109

def y
  @_y ||= geometry.y
end