Sha256: 56e8cb5b3f0457532b3edde6ecc6f147e3c45c5f166a0cc0e050c13130a502bf

Contents?: true

Size: 915 Bytes

Versions: 2

Compression:

Stored size: 915 Bytes

Contents

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

2 entries across 2 versions & 1 rubygems

Version Path
dusen-0.2.1 lib/dusen/parser.rb
dusen-0.2.0 lib/dusen/parser.rb