Sha256: 13d9eb9900a435bc6a33e9481fdcf8254f8363ca498a4145a046ba34fb34662c

Contents?: true

Size: 934 Bytes

Versions: 5

Compression:

Stored size: 934 Bytes

Contents

# encoding: utf-8

module Dusen
  class Parser

    WESTERNISH_WORD_CHARACTER =  '\\w\\-\\.@_ÄÖÜäöüß' # this is wrong on so many levels
    TEXT_QUERY = /(?:"([^"]+)"|([#{WESTERNISH_WORD_CHARACTER}]+))/
    FIELD_QUERY = /(\w+)\:#{TEXT_QUERY}/

    def self.parse(query_string)
      query_string = query_string.dup # we are going to delete substrings in-place
      query = Query.new
      extract_field_query_tokens(query_string, query)
      extract_text_query_tokens(query_string, query)
      query
    end

    def self.extract_text_query_tokens(query_string, query)
      while query_string.sub!(TEXT_QUERY, '')
        value = "#{$1}#{$2}"
        query << Token.new(value)
      end
    end

    def self.extract_field_query_tokens(query_string, query)
      while query_string.sub!(FIELD_QUERY, '')
        field = $1
        value = "#{$2}#{$3}"
        query << Token.new(field, value)
      end
    end

  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
dusen-0.4.2 lib/dusen/parser.rb
dusen-0.4.1 lib/dusen/parser.rb
dusen-0.4.0 lib/dusen/parser.rb
dusen-0.3.0 lib/dusen/parser.rb
dusen-0.2.2 lib/dusen/parser.rb