Skip to content

sushie1984/sticky_colour

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

StickyColour

The StickyColour gem is a Ruby solution for the pile of paper problem described in https://github.com/fsufitch/dailyprogrammer/blob/master/ideas/pile_of_paper/suggest_paper.md

Installation

  1. git clone https://github.com/sushie1984/sticky_colour.git
  2. gem build stickey_colour.gemspec
  3. gem install ./sticky_colour-MAJOR.MINOR.BUILD.gem

Usage

Prepare a input file containing the values: Have a look at https://github.com/fsufitch/dailyprogrammer/blob/master/ideas/pile_of_paper/paper1.in for an example.

Basically the very first line defines the horizontal and vertical size of the sheet/canvas that is going to be used for the notes.
(e.g.: 10 10).
The upcoming lines defining all sticky-notes that are going to be placed within the sheet/canvas in the manner of colour, horizontal start position, vertical start position, horizontal width, vertical width.
(e.g.: 1 0 0 4 4)
Keep in mind that the values of the sticky-notes have to be within the given horizontal and vertical size.

Init irb with the new gem sticky_colour:

  1. irb
  2. require "sticky_colour"

Call the StickyColour::StartApp with the given file containing the values:
input_file = "path/to/your/input_file"
StickyColour::StartApp.main(input_file)

After StickyColour::StartApp.main is finished call last_run for results:
last_run = StickyColour::StartApp.last_run
last_run['sheet'] --> Returns 2d Array containing the very last state of the sheet including all stacked sticky notes.
last_run['available_colours'] --> Returns a Hash containing the total amount of each sticky-notes colour attribute that is visible after the last state.

Development

The gem is mainly divided into 3 subclasses which can be found in lib/sticky_colour/, exchanging its values through old-style getter/setter:
StickySheet is the class reprasenting the area/field for the StickyNote instances.
StickyNote is the class reprasenting a sticky-note that is going to be put onto the StickySheet.
StickyOutput is the class calculating (based on a specific strategy) the given amount of stacked StickyNotes colours stacked at the StickySheet.

The core method for StickySheet is defined as add
The core mehhod for StickyOutput is defined as calculate_and_print_colour_output_for

Currently StickyOutput implements only the method single_thread_line_calculator which calculates the whole amount iterative line per line.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/sushie1984/sticky_colour.

License

The gem is available as open source under the terms of the MIT License.

About

A ruby gem solution for the pile of paper problem

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published