CodeTerminator

CodeTerminator is a gem that helps to exterminate Sarah Connor parse, evaluate and compare html and css code. Also is useful when you need to check html and css code syntaxis.

Features

  • HTML parser
  • CSS parser

Installation

Add this line to your application's Gemfile:

gem 'code_terminator'

And then execute:

$ bundle

Or install it yourself as:

$ gem install code_terminator

Quick Start

HTML

To parse HTML and match the file with html code you just need to do:

    # code = code get from an editor
    # source = Source of the file you want to compare with

    # First, validate syntasis of the code
    ct = CodeTerminator::Html.new
    errors = ct.validate_syntax(code)
    result << errors[0]

    # If code don't have errors, match the code with your html file
    if errors.empty?
      result = ct.match(source, code)
    end

If the code and the source mismatch, ct.match() will return an array with the differences between code and source file. You will know that the code and the source file have the same html elements when the ct.match() return a nil array.

    # hola_mundo.html
    #   <h1>Come with me if you want to live!</h1>
    #
    >> ct.match("hola_mundo.html","<h2>Come with me if you want to live!</h2>")
    #  => [{:element=>{:parent=>"body", :tag=>"p"}, :type=>404, :description=>"p not exist"}]
CSS

To parse CSS and match the file with css code you just need to do:

    # code = code get from an editor
    # source = Source of the file you want to compare with

    # First, validate syntasis of the code
    ct = CodeTerminator::Css.new
    errors = ct.validate_syntax(code)

    # If code do't have errors, match the code with your html file
    if errors.empty?
      result = ct.match(source, code)
    end

If the code and the source mismatch, ct.match() will return an array with the differences between code and source file. You will know that the code and the source file have the same css elements when the ct.match() return a nil array.

    # test.css
    # => h1{ margin: 100px; }
    #
    >> ct.match("test.html","h1{ margin: 50px; }")
    #  => [{:element=>{:selector=>"body", :property=>"background-color", :value=>"yellow"}, :type=>111, :description=>"not the same property background-color: yellow in selector body"}]

Cheat Sheet

match(source, code)

Match if the code have the same elements than the exercise. Return an array with the mismatches.

HTML

   #   hola_mundo.html
   # => <h1>Come with me if you want to live!</h1>
   >> ct = CodeTerminator::Html.new
   >> ct.match("hola_mundo.html","<h2>Come with me if you want to live!</h2>")
   #  => [{:element=>{:parent=>"body", :tag=>"p"}, :type=>404, :description=>"p not exist"}]
   #
CSS
   #   test.css
   # => h1{ margin: 100px; }
   >> ct = CodeTerminator::Css.new
   >> ct.match("hola_mundo.css","h1{ margin: 50px; }")
   #  => [{:element=>{:selector=>"body", :property=>"background-color", :value=>"yellow"}, :type=>111, :description=>"not the same property background-color: yellow in selector body"}]

   #
Errors description

The errors that throw match() are in json format to help you to identify each error type as the following:

  # [element, error_type, description]
  [{:element=>{:selector=>"body", :property=>"background-color", :value=>"yellow"}, :type=>111, :description=>"not the same property background-color: yellow in selector body"}]

Errors Types

  • 101 : Css property not found
  • 111 : Different css property in the selector
  • 330 : Different text in the html tag
  • 333 : Different value in the html attribute
  • 334 : Html attribute doesn't exist in the tag
  • 404 : Element not found
  • 440 : Tag not found in the parent tag


new_file(source, code)

Create a Html/Css file with the code of the editor. Return a boolean that indicate if the file was created or not.

HTML
    >> ct = CodeTerminator::Html.new
    >> ct.new_file("hola_mundo.html", "<h1>Come with me if you want to live!</h1>")
    #   => true
CSS
    >> ct = CodeTerminator::Css.new
    >> ct.new_file("hola_mundo.css", "h1{ margin: 50px; }")
    #   => true

read_file(source)

Read a html file. Return the text of the file.

HTML
    >> ct = CodeTerminator::Html.new
    >> ct.read_file("hola_mundo.html")
     #   => "<h1>Come with me if you want to live!</h1>"
CSS
    >> ct = CodeTerminator::Css.new
    >> ct.read_file("hola_mundo.css")
     #   => "h1{ margin: 50px; }"

validate_syntax(code)

Validate if the syntax is correct. Return an array with errors.

HTML
    >> ct = CodeTerminator::Html.new
    >> ct.validate_syntax("<h1>Come with me if you want to live!</h1")
     #   => [#<Nokogiri::XML::SyntaxError: expected '>'>]
CSS
    >> ct = CodeTerminator::Css.new
    >> ct.validate_syntax("h1{ margi")
     #   => ["error"]

get_elements(source)

Get html elements of a html file. Return a list of elements with their properties.

HTML
    >> ct = CodeTerminator::Html.new
    >> ct.get_elements("hola_mundo.html")
     #   => [{:parent=>"body", :tag=>"div", :attribute=>"class", :value=>"col-md-12"}, {:parent=>"div", :tag=>"h1"}, {:parent=>"h1", :tag=>"text", :content=>"Come with me if you want to live!"}]
CSS
    >> ct = CodeTerminator::Css.new
    >> ct.get_elements("hola_mundo.css")
     #   => [{:selector=>"h1"}, {:selector=>"h1", :property=>"margin", :value=>"50px"}]

get_instructions(source)

Get the instructions to recreate the html code. Return an array with strings .

HTML
    >> ct = CodeTerminator::Html.new
    >> ct.get_instructions("hola_mundo.html")
     #   => ["Add the tag h2 in body", " In h2 add the text 'hola test' ", "Add the tag p in body"]
CSS
    >> ct = CodeTerminator::Css.new
    >> ct.get_instructions("hola_mundo.css")
     #   => ["Create the selector body", "In the selector body add the property ' background-color'  with value 'yellow' "]

Get the elements of the code in html format. Return a string with elements in html.

HTML
     CodeTerminator::Html.print_elements("exercises/hola_mundo.html" )
     #   => "name = h1<br><hr>name = text<br>content = Come with me if you want to live!<br><hr>"
     #
CSS
     CodeTerminator::Css.print_elements("exercises/hola_mundo.css" )
     #   => "selector = h1<br><hr>property = margin<br>value = 50px<br><hr>"
     #

Example

An example of an editor using CodeTerminator is available at https://github.com/eponce19/editor_terminator.git

Development

After checking out the repo, run bin/setup to install dependencies. Then, run rake test to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment. Run bundle exec code_terminator to use the gem in this directory, ignoring other installed copies of this gem.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/eponce19/code_terminator. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

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