Class: Mustermann::Flask

Inherits:
AST::Pattern
  • Object
show all
Includes:
Concat::Native
Defined in:
lib/mustermann/flask.rb

Overview

Flask style pattern implementation.

Examples:

Mustermann.new('/<foo>', type: :flask) === '/bar' # => true

See Also:

Defined Under Namespace

Classes: Converter

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(input, converters: {}, **options) ⇒ Flask

Returns a new instance of Flask.



193
194
195
196
197
# File 'lib/mustermann/flask.rb', line 193

def initialize(input, converters: {}, **options)
  @converters = self.class.converters.dup
  converters.each { |k,v| @converters[k.to_s] = v } if converters
  super(input, **options)
end

Instance Attribute Details

#convertersObject (readonly)

Returns the value of attribute converters.



191
192
193
# File 'lib/mustermann/flask.rb', line 191

def converters
  @converters
end

Class Method Details

.register_converter(name, converter = nil, &block) ⇒ Object

Allows you to register your own converters.

It is reommended to use this on a subclass, so to not influence other subsystems using flask templates.

The object passed in as converter can implement #convert and/or #constraint.

It can also instead implement #new, which will then return an object responding to some of these methods. Arguments from the flask pattern will be passed to #new.

If passed a block, it will be yielded to with a Converter instance and any arguments in the flask pattern.

Examples:

with simple object

require 'mustermann/flask'

MyPattern    = Class.new(Mustermann::Flask)
up_converter = Struct.new(:convert).new(:upcase.to_proc)
MyPattern.register_converter(:upper, up_converter)

MyPattern.new("/<up:name>").params('/foo') # => { "name" => "FOO" }

with block

require 'mustermann/flask'

MyPattern    = Class.new(Mustermann::Flask)
MyPattern.register_converter(:upper) { |c| c.convert = :upcase.to_proc }

MyPattern.new("/<up:name>").params('/foo') # => { "name" => "FOO" }

with converter class

require 'mustermann/flasl'

class MyPattern < Mustermann::Flask
  class Converter
    attr_reader :convert
    def initialize(send: :to_s)
      @convert = send.to_sym.to_proc
    end
  end

  register_converter(:t, Converter)
end

MyPattern.new("/<t(send=upcase):name>").params('/Foo')   # => { "name" => "FOO" }
MyPattern.new("/<t(send=downcase):name>").params('/Foo') # => { "name" => "foo" }

Parameters:

  • name (#to_s)

    converter name

  • converter (#new, #convert, #constraint, nil) (defaults to: nil)


156
157
158
159
# File 'lib/mustermann/flask.rb', line 156

def self.register_converter(name, converter = nil, &block)
  converter ||= Converter.create(&block)
  converters(false)[name.to_s] = converter
end