bitmap_cmd_editor 1.0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (37) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +15 -0
  3. data/.travis.yml +3 -0
  4. data/Gemfile +12 -0
  5. data/LICENSE.txt +22 -0
  6. data/README.md +46 -0
  7. data/Rakefile +35 -0
  8. data/bin/bitmap_cmd_editor +10 -0
  9. data/bitmap_cmd_editor.gemspec +33 -0
  10. data/features/clear_table.feature +23 -0
  11. data/features/colours_pixel.feature +30 -0
  12. data/features/command_bitmap_cmd_editor.feature +48 -0
  13. data/features/create_bitmap.feature +29 -0
  14. data/features/draw_horinzontal_segment.feature +33 -0
  15. data/features/draw_vertical_segment.feature +33 -0
  16. data/features/fill_region.feature +44 -0
  17. data/features/show_content.feature +40 -0
  18. data/features/step_definitions/clear_table_step.rb +4 -0
  19. data/features/step_definitions/colours_pixel_step.rb +10 -0
  20. data/features/step_definitions/create_bitmap_step.rb +19 -0
  21. data/features/support/env.rb +2 -0
  22. data/lib/bitmap_cmd_editor.rb +3 -0
  23. data/lib/bitmap_cmd_editor/bitmap.rb +195 -0
  24. data/lib/bitmap_cmd_editor/client.rb +34 -0
  25. data/lib/bitmap_cmd_editor/exceptions.rb +17 -0
  26. data/lib/bitmap_cmd_editor/validators/clear_image_validator.rb +20 -0
  27. data/lib/bitmap_cmd_editor/validators/colour_pixel_validator.rb +34 -0
  28. data/lib/bitmap_cmd_editor/validators/command_validator.rb +21 -0
  29. data/lib/bitmap_cmd_editor/validators/create_image_validator.rb +34 -0
  30. data/lib/bitmap_cmd_editor/validators/error_message.rb +38 -0
  31. data/lib/bitmap_cmd_editor/validators/fill_region_validator.rb +34 -0
  32. data/lib/bitmap_cmd_editor/validators/horizontal_line_validator.rb +38 -0
  33. data/lib/bitmap_cmd_editor/validators/print_table_validator.rb +20 -0
  34. data/lib/bitmap_cmd_editor/validators/validator_herlper.rb +33 -0
  35. data/lib/bitmap_cmd_editor/validators/vertical_line_validator.rb +38 -0
  36. data/lib/bitmap_cmd_editor/version.rb +27 -0
  37. metadata +237 -0
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 83ea6dff7912df7eb97e55b8c5e1fc7449c99360
4
+ data.tar.gz: cbf771084d9a2863758607d49aa25ad96602b47d
5
+ SHA512:
6
+ metadata.gz: 2bb8445a8cfbc59d18e7ce67b825ef93c40a4d90ef38694be8c9e78c3927e6ea385c60a6ec54bbe26eee2729fa154f4c03c0d4500c5d6fa61321f1d50b10da03
7
+ data.tar.gz: fe2a2155685721af6b4196358094c9e1477c5599a59486b18ea907919619674f9d1a53bf3f4fb298645d0e5eeda5d646bc426209f457216f68587aa1d6fad9f0
@@ -0,0 +1,15 @@
1
+ cd c/.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ *.bundle
11
+ *.so
12
+ *.o
13
+ *.a
14
+ mkmf.log
15
+ *.gem
@@ -0,0 +1,3 @@
1
+ language: ruby
2
+ rvm:
3
+ - 2.0.0-p598
data/Gemfile ADDED
@@ -0,0 +1,12 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in bitmap_cmd_editor.gemspec
4
+ gemspec
5
+ gem 'yard'
6
+
7
+ group :test do
8
+ gem 'shoulda-matchers'
9
+ gem 'cucumber'
10
+ gem 'rspec-expectations'
11
+ gem 'aruba'
12
+ end
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2015 Diego Hernán Piccinini Lagos
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,46 @@
1
+ # BitmapCmdEditor
2
+
3
+ This is an interactive command script, input consists of a string containing a sequence of commands, where a command is represented by a single capital letter at the beginning of the line. Parameters of the command are separated by white spaces and they follow the command character.
4
+
5
+ Pixel co-ordinates are a pair of integers: a column number between 1 and 250, and a row number between 1 and 250. Bitmaps starts at coordinates 1,1. Colours are specified by capital letters.
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'bitmap_cmd_editor'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install bitmap_cmd_editor
22
+
23
+ ## Usage
24
+
25
+ After install the gem in your system you will have avaible the command bitmap_cmd_editor.
26
+ So, run in your terminal `bitmap_cmd_editor` then you should see this:
27
+
28
+ Available Commands:
29
+ -------------------
30
+
31
+ I M N - Create a new M x N image with all pixels coloured white (O).
32
+ C - Clears the table, setting all pixels to white (O).
33
+ L X Y C - Colours the pixel (X,Y) with colour C.
34
+ V X Y1 Y2 C - Draw a vertical segment of colour C in column X between rows Y1 and Y2 (inclusive).
35
+ H X1 X2 Y C - Draw a horizontal segment of colour C in row Y between columns X1 and X2 (inclusive).
36
+ F X Y C - Fill the region R with the colour C. R is defined as: Pixel (X,Y) belongs to R. Any other pixel which is the same colour as (X,Y) and shares a common side with any pixel in R also belongs to this region.
37
+ S - Show the contents of the current image
38
+ X - Terminate the session
39
+
40
+ ## Contributing
41
+
42
+ 1. Fork it ( https://github.com/diegopiccinini/bitmap_cmd_editor.git/fork )
43
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
44
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
45
+ 4. Push to the branch (`git push origin my-new-feature`)
46
+ 5. Create a new Pull Request
@@ -0,0 +1,35 @@
1
+ # encoding: utf-8
2
+
3
+ require 'rubygems'
4
+
5
+ begin
6
+ require 'bundler'
7
+ rescue LoadError => e
8
+ warn e.message
9
+ warn "Run `gem install bundler` to install Bundler."
10
+ exit -1
11
+ end
12
+
13
+ begin
14
+ Bundler.setup(:development)
15
+ rescue Bundler::BundlerError => e
16
+ warn e.message
17
+ warn "Run `bundle install` to install missing gems."
18
+ exit e.status_code
19
+ end
20
+
21
+ require 'rake'
22
+
23
+ require 'rubygems/tasks'
24
+ Gem::Tasks.new
25
+
26
+ YARD::Rake::YardocTask.new do |t|
27
+ t.files = ['app/**/*.rb', 'lib/**/*.rb', '-', 'doc/FAQ.md', 'doc/Changes.md']
28
+ t.options = ['--any', '--extra', '--opts'] # optional
29
+ end
30
+
31
+ task :test => :cucumber
32
+
33
+
34
+
35
+
@@ -0,0 +1,10 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rubygems'
4
+
5
+ begin
6
+ require 'bitmap_cmd_editor'
7
+ Client.get_commands
8
+ rescue LoadError => e
9
+ abort 'Could not load "bitmap_cmd_editor"'
10
+ end
@@ -0,0 +1,33 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'bitmap_cmd_editor/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "bitmap_cmd_editor"
8
+ spec.version = BitmapCmdEditor::VERSION
9
+ spec.platform = Gem::Platform::RUBY
10
+ spec.authors = ["Diego Hernán Piccinini Lagos"]
11
+ spec.email = ["diego@guiasrails.es"]
12
+ spec.summary = %q{Produce a Ruby 2.0 program that simulates a basic interactive bitmap editor. Bitmaps are represented as an M x N matrix of pixels with each element representing a colour.}
13
+ spec.description = %q{The input consists of a string containing a sequence of commands, where a command is represented by a single capital letter at the beginning of the line. Parameters of the command are separated by white spaces and they follow the command character.
14
+
15
+ Pixel co-ordinates are a pair of integers: a column number between 1 and 250, and a row number between 1 and 250. Bitmaps starts at coordinates 1,1. Colours are specified by capital letters.}
16
+ spec.homepage = ""
17
+ spec.license = "MIT"
18
+
19
+ spec.files = `git ls-files -z`.split("\x0")
20
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
21
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
22
+ spec.require_paths = ["lib"]
23
+ spec.required_ruby_version = ">= 2.0.0"
24
+ spec.add_development_dependency "bundler", "~> 1.7"
25
+ spec.add_development_dependency "rake", "~> 10.0"
26
+ spec.add_development_dependency "shoulda-matchers", '2.8.0'
27
+ spec.add_development_dependency "rspec-expectations", '3.2.0'
28
+ spec.add_development_dependency "cucumber", '2.0.0'
29
+ spec.add_development_dependency "aruba"
30
+ spec.add_development_dependency "yard"
31
+
32
+ spec.has_rdoc = 'yard'
33
+ end
@@ -0,0 +1,23 @@
1
+ Feature: Clear table
2
+ the command C - Clears the table, setting all pixels to white (O)
3
+
4
+ Scenario: Cleaning the table
5
+ Given a bitmap created
6
+ And The user type "I 5 6"
7
+ And The user type "L 2 3 A"
8
+ And the bitmap should be
9
+ |O|O|O|O|O|
10
+ |O|O|O|O|O|
11
+ |O|A|O|O|O|
12
+ |O|O|O|O|O|
13
+ |O|O|O|O|O|
14
+ |O|O|O|O|O|
15
+ When The user type "C"
16
+ Then the bitmap should be
17
+ |O|O|O|O|O|
18
+ |O|O|O|O|O|
19
+ |O|O|O|O|O|
20
+ |O|O|O|O|O|
21
+ |O|O|O|O|O|
22
+ |O|O|O|O|O|
23
+
@@ -0,0 +1,30 @@
1
+ Feature: Colours a Pixel
2
+ the command L X Y C - Colours the pixel (X,Y) with colour C.
3
+ Scenario: Colouring a Bitmap
4
+ Given a bitmap was created typing the command "I 5 6"
5
+ When The user type "L 4 1 E"
6
+ And The user type "L 3 2 B"
7
+ Then the bitmap should be
8
+ |O|O|O|E|O|
9
+ |O|O|B|O|O|
10
+ |O|O|O|O|O|
11
+ |O|O|O|O|O|
12
+ |O|O|O|O|O|
13
+ |O|O|O|O|O|
14
+
15
+ Scenario Outline: Trying to colour a Bitmap with invalid commands
16
+ Given a bitmap was created typing the command <Command I>
17
+ When The user tries to colour <Command L>
18
+ Then He should see the message <Message>
19
+
20
+ Examples:
21
+ |Command I| Command L | Message |
22
+ | "I 5 6" | "L 7 2 A" | "a valid columns values are between 1 and 5, and you try 7" |
23
+ | "I 5 6" | "L -1 2 A" | "a valid columns values are between 1 and 5, and you try -1" |
24
+ | "I 6 3" | "L 3 9 A" | "a valid rows values are between 1 and 3, and you try 9" |
25
+ | "I 5 4" | "L 3 0 A" | "a valid rows values are between 1 and 4, and you try 0" |
26
+ | "I 5 4" | "L 3 4 A C" | "this command require 3 arguments" |
27
+ | "I 5 4" | "L 3 4" | "this command require 3 arguments" |
28
+ | "I 5 4" | "L S 4 A" | "the coordinates M N must be integers" |
29
+ | "I 5 4" | "L 4 H A" | "the coordinates M N must be integers" |
30
+ | "I 5 4" | "L 4 3 5H" | "the colour must be a Capital Letter A-Z" |
@@ -0,0 +1,48 @@
1
+ Feature: Command bitmap_cmd_editor
2
+ Scenario: Welcome Message and Exit
3
+ When I run `bitmap_cmd_editor` interactively
4
+ And I type "X"
5
+ Then it should pass with:
6
+ """
7
+ Welcome to the Bitmap Command Editor
8
+ ------------------------------------
9
+
10
+ Available Commands:
11
+ -------------------
12
+
13
+ I M N - Create a new M x N image with all pixels coloured white (O).
14
+ C - Clears the table, setting all pixels to white (O).
15
+ L X Y C - Colours the pixel (X,Y) with colour C.
16
+ V X Y1 Y2 C - Draw a vertical segment of colour C in column X between rows Y1 and Y2 (inclusive).
17
+ H X1 X2 Y C - Draw a horizontal segment of colour C in row Y between columns X1 and X2 (inclusive).
18
+ F X Y C - Fill the region R with the colour C. R is defined as: Pixel (X,Y) belongs to R. Any other pixel which is the same colour as (X,Y) and shares a common side with any pixel in R also belongs to this region.
19
+ S - Show the contents of the current image
20
+ X - Terminate the session
21
+
22
+ End the Session...
23
+ """
24
+ Scenario: Welcome Message and not Exit
25
+ When I run `bitmap_cmd_editor` interactively
26
+ And I type "Y"
27
+ And I type "X"
28
+ Then it should pass with:
29
+ """
30
+ Welcome to the Bitmap Command Editor
31
+ ------------------------------------
32
+
33
+ Available Commands:
34
+ -------------------
35
+
36
+ I M N - Create a new M x N image with all pixels coloured white (O).
37
+ C - Clears the table, setting all pixels to white (O).
38
+ L X Y C - Colours the pixel (X,Y) with colour C.
39
+ V X Y1 Y2 C - Draw a vertical segment of colour C in column X between rows Y1 and Y2 (inclusive).
40
+ H X1 X2 Y C - Draw a horizontal segment of colour C in row Y between columns X1 and X2 (inclusive).
41
+ F X Y C - Fill the region R with the colour C. R is defined as: Pixel (X,Y) belongs to R. Any other pixel which is the same colour as (X,Y) and shares a common side with any pixel in R also belongs to this region.
42
+ S - Show the contents of the current image
43
+ X - Terminate the session
44
+
45
+ This command is not available, please check the available commands
46
+
47
+ End the Session...
48
+ """
@@ -0,0 +1,29 @@
1
+ Feature: Create a Bitmap
2
+ the command I M N - Create a new M x N image with all pixels coloured white (O).
3
+
4
+ Scenario: Create a new M x N image
5
+ Given a bitmap created
6
+ When The user type "I 5 6"
7
+ Then this bitmap should be created
8
+ |O|O|O|O|O|
9
+ |O|O|O|O|O|
10
+ |O|O|O|O|O|
11
+ |O|O|O|O|O|
12
+ |O|O|O|O|O|
13
+ |O|O|O|O|O|
14
+
15
+ Scenario Outline: Trying create an invalid image
16
+ Given a bitmap created
17
+ When The user attempts to create <Command>
18
+ Then He should see the message <Message>
19
+ Examples:
20
+ | Command | Message |
21
+ | "I 500 6" | "the maximun columns allowed are 250 and you want 500" |
22
+ | "I 5 645" | "the maximun rows allowed are 250 and you want 645" |
23
+ | "I 0 6" | "the minimun columns allowed is 1 and you want 0" |
24
+ | "I 7 -6" | "the minimun rows allowed is 1 and you want -6" |
25
+ | "I 500 6" | "the maximun columns allowed are 250 and you want 500" |
26
+ | "I 7 8 10"| "this command require 2 arguments" |
27
+ | "I 7" | "this command require 2 arguments" |
28
+ | "I S 3" | "the coordinates M N must be integers" |
29
+ | "I 2 H" | "the coordinates M N must be integers" |
@@ -0,0 +1,33 @@
1
+ Feature: Draw a horizontal segment
2
+ With command H X1 X2 Y C - Draw a horizontal segment of colour C
3
+ in row Y between columns X1 and X2 (inclusive).
4
+ Scenario: Drawing a horinzontal segment
5
+ Given a bitmap was created typing the command "I 5 6"
6
+ When The user type "H 2 4 3 C"
7
+ Then the bitmap should be
8
+ |O|O|O|O|O|
9
+ |O|O|O|O|O|
10
+ |O|C|C|C|O|
11
+ |O|O|O|O|O|
12
+ |O|O|O|O|O|
13
+ |O|O|O|O|O|
14
+
15
+ Scenario Outline: Trying to draw a horizontal line with invalid commands
16
+ Given a bitmap was created typing the command <Command I>
17
+ When The user tries to colour <Command L>
18
+ Then He should see the message <Message>
19
+
20
+ Examples:
21
+ |Command I | Command L | Message |
22
+ | "I 5 6" | "H 2 7 4 A" | "a valid columns values are between 1 and 5, and you try 7" |
23
+ | "I 5 6" | "H 2 11 4 A" | "a valid columns values are between 1 and 5, and you try 11" |
24
+ | "I 5 6" | "H -1 2 4 A" | "a valid columns values are between 1 and 5, and you try -1" |
25
+ | "I 5 6" | "H 1 -3 4 A" | "a valid columns values are between 1 and 5, and you try -3" |
26
+ | "I 6 3" | "H 3 5 9 A" | "a valid rows values are between 1 and 3, and you try 9" |
27
+ | "I 5 4" | "H 3 4 0 A" | "a valid rows values are between 1 and 4, and you try 0" |
28
+ | "I 5 4" | "H 3 4 A C R" | "this command require 4 arguments" |
29
+ | "I 5 4" | "H 3 4" | "this command require 4 arguments" |
30
+ | "I 5 4" | "H S 4 5 A" | "the coordinates M N must be integers" |
31
+ | "I 5 4" | "H 4 H 6 A" | "the coordinates M N must be integers" |
32
+ | "I 5 4" | "H 4 2 Z A" | "the coordinates M N must be integers" |
33
+ | "I 5 4" | "H 4 1 4 5H" | "the colour must be a Capital Letter A-Z" |
@@ -0,0 +1,33 @@
1
+ Feature: Draw a vertical segment
2
+ With command V X Y1 Y2 C - Draw a vertical segment of colour C in column X
3
+ between rows Y1 and Y2 (inclusive).
4
+ Scenario: Drawing a vertical segment
5
+ Given a bitmap was created typing the command "I 5 6"
6
+ When The user type "V 2 1 4 W"
7
+ Then the bitmap should be
8
+ |O|W|O|O|O|
9
+ |O|W|O|O|O|
10
+ |O|W|O|O|O|
11
+ |O|W|O|O|O|
12
+ |O|O|O|O|O|
13
+ |O|O|O|O|O|
14
+
15
+ Scenario Outline: Trying to draw a vertical line with invalid commands
16
+ Given a bitmap was created typing the command <Command I>
17
+ When The user tries to colour <Command L>
18
+ Then He should see the message <Message>
19
+
20
+ Examples:
21
+ |Command I | Command L | Message |
22
+ | "I 5 6" | "V 7 2 4 A" | "a valid columns values are between 1 and 5, and you try 7" |
23
+ | "I 5 6" | "V -1 2 4 A" | "a valid columns values are between 1 and 5, and you try -1" |
24
+ | "I 6 3" | "V 3 9 3 A" | "a valid rows values are between 1 and 3, and you try 9" |
25
+ | "I 5 4" | "V 3 0 4 A" | "a valid rows values are between 1 and 4, and you try 0" |
26
+ | "I 6 3" | "V 3 3 9 A" | "a valid rows values are between 1 and 3, and you try 9" |
27
+ | "I 5 4" | "V 3 1 -2 A" | "a valid rows values are between 1 and 4, and you try -2" |
28
+ | "I 5 4" | "V 3 4 A C R" | "this command require 4 arguments" |
29
+ | "I 5 4" | "V 3 4" | "this command require 4 arguments" |
30
+ | "I 5 4" | "V S 4 5 A" | "the coordinates M N must be integers" |
31
+ | "I 5 4" | "V 4 H 6 A" | "the coordinates M N must be integers" |
32
+ | "I 5 4" | "V 4 2 Z A" | "the coordinates M N must be integers" |
33
+ | "I 5 4" | "V 4 1 4 5H" | "the colour must be a Capital Letter A-Z" |
@@ -0,0 +1,44 @@
1
+ Feature: Fill the region R with the colour C
2
+ with command F X Y C - Fill the region R with the colour C.
3
+ R is defined as: Pixel (X,Y) belongs to R.
4
+ Any other pixel which is the same colour as (X,Y) and shares a common side with any pixel in R also belongs to this region.
5
+
6
+ Scenario: Filling a Region
7
+ Given a bitmap was created typing the command "I 5 6"
8
+ And The user type "L 4 1 E"
9
+ And The user type "L 3 2 E"
10
+ And The user type "L 4 2 E"
11
+ And The user type "L 3 3 E"
12
+ And The user type "L 2 5 E"
13
+ And the bitmap should be
14
+ |O|O|O|E|O|
15
+ |O|O|E|E|O|
16
+ |O|O|E|O|O|
17
+ |O|O|O|O|O|
18
+ |O|E|O|O|O|
19
+ |O|O|O|O|O|
20
+ When The user type "F 4 2 H"
21
+ Then the bitmap should be
22
+ |O|O|O|H|O|
23
+ |O|O|H|H|O|
24
+ |O|O|H|O|O|
25
+ |O|O|O|O|O|
26
+ |O|E|O|O|O|
27
+ |O|O|O|O|O|
28
+
29
+ Scenario Outline: Trying to filling a Bitmap with invalid commands
30
+ Given a bitmap was created typing the command <Command I>
31
+ When The user tries to colour <Command L>
32
+ Then He should see the message <Message>
33
+
34
+ Examples:
35
+ |Command I| Command L | Message |
36
+ | "I 5 6" | "F 7 2 A" | "a valid columns values are between 1 and 5, and you try 7" |
37
+ | "I 5 6" | "F -1 2 A" | "a valid columns values are between 1 and 5, and you try -1" |
38
+ | "I 6 3" | "F 3 9 A" | "a valid rows values are between 1 and 3, and you try 9" |
39
+ | "I 5 4" | "F 3 0 A" | "a valid rows values are between 1 and 4, and you try 0" |
40
+ | "I 5 4" | "F 3 4 A C" | "this command require 3 arguments" |
41
+ | "I 5 4" | "F 3 4" | "this command require 3 arguments" |
42
+ | "I 5 4" | "F S 4 A" | "the coordinates M N must be integers" |
43
+ | "I 5 4" | "F 4 H A" | "the coordinates M N must be integers" |
44
+ | "I 5 4" | "F 4 3 5H" | "the colour must be a Capital Letter A-Z" |