ambition 0.5.1 → 0.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README +17 -3
 - data/ambition.gemspec +5 -5
 - data/lib/ambition/api.rb +23 -3
 - data/lib/ambition/context.rb +30 -30
 - data/lib/ambition/core_ext.rb +1 -0
 - data/lib/ambition/enumerable.rb +1 -1
 - data/lib/ambition/processors/base.rb +13 -2
 - data/lib/ambition/processors/ruby.rb +2 -2
 - data/lib/ambition/processors/select.rb +2 -2
 - data/lib/ambition/processors/slice.rb +2 -2
 - data/lib/ambition/processors/sort.rb +2 -2
 - data/lib/ambition/sexp_translator.rb +1 -1
 - metadata +2 -2
 
    
        data/README
    CHANGED
    
    | 
         @@ -1,10 +1,24 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            Ambition
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
      
 1 
     | 
    
         
            +
            = Ambition
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
      
 3 
     | 
    
         
            +
             
     | 
| 
      
 4 
     | 
    
         
            +
            == Get it
         
     | 
| 
      
 5 
     | 
    
         
            +
             
     | 
| 
       3 
6 
     | 
    
         | 
| 
       4 
     | 
    
         
            -
            http://github.com/defunkt/ambition
         
     | 
| 
       5 
7 
     | 
    
         | 
| 
       6 
8 
     | 
    
         
             
            $ git clone git://github.com/defunkt/ambition.git
         
     | 
| 
       7 
9 
     | 
    
         | 
| 
      
 10 
     | 
    
         
            +
            == Resources
         
     | 
| 
      
 11 
     | 
    
         
            +
             
     | 
| 
      
 12 
     | 
    
         
            +
             * http://ambition.rubyforge.org/
         
     | 
| 
      
 13 
     | 
    
         
            +
             * http://groups.google.com/group/ambition-rb/
         
     | 
| 
      
 14 
     | 
    
         
            +
             * http://errtheblog.com/posts/63-full-of-ambition
         
     | 
| 
      
 15 
     | 
    
         
            +
             * http://errtheblog.com/posts/82-adapting-ambitiously
         
     | 
| 
      
 16 
     | 
    
         
            +
             * http://errtheblog.com/posts/86-sugary-adapters
         
     | 
| 
      
 17 
     | 
    
         
            +
             * http://errtheblog.com/posts/64-even-more-ambitious
         
     | 
| 
      
 18 
     | 
    
         
            +
             
     | 
| 
      
 19 
     | 
    
         
            +
             
     | 
| 
      
 20 
     | 
    
         
            +
             
     | 
| 
      
 21 
     | 
    
         
            +
            == Author
         
     | 
| 
       8 
22 
     | 
    
         | 
| 
       9 
23 
     | 
    
         
             
            Chris Wanstrath
         
     | 
| 
       10 
24 
     | 
    
         
             
            chris@ozmm.org
         
     | 
    
        data/ambition.gemspec
    CHANGED
    
    | 
         @@ -1,11 +1,11 @@ 
     | 
|
| 
       1 
1 
     | 
    
         | 
| 
       2 
     | 
    
         
            -
            # Gem::Specification for Ambition-0.5. 
     | 
| 
      
 2 
     | 
    
         
            +
            # Gem::Specification for Ambition-0.5.2
         
     | 
| 
       3 
3 
     | 
    
         
             
            # Originally generated by Echoe
         
     | 
| 
       4 
4 
     | 
    
         | 
| 
       5 
5 
     | 
    
         
             
            Gem::Specification.new do |s|
         
     | 
| 
       6 
6 
     | 
    
         
             
              s.name = %q{ambition}
         
     | 
| 
       7 
     | 
    
         
            -
              s.version = "0.5. 
     | 
| 
       8 
     | 
    
         
            -
              s.date = %q{2008-02- 
     | 
| 
      
 7 
     | 
    
         
            +
              s.version = "0.5.2"
         
     | 
| 
      
 8 
     | 
    
         
            +
              s.date = %q{2008-02-29}
         
     | 
| 
       9 
9 
     | 
    
         
             
              s.summary = %q{Ambition builds yer API calls from plain jane Ruby.}
         
     | 
| 
       10 
10 
     | 
    
         
             
              s.email = %q{chris@ozmm.org}
         
     | 
| 
       11 
11 
     | 
    
         
             
              s.homepage = %q{http://errtheblog.com/}
         
     | 
| 
         @@ -29,7 +29,7 @@ end 
     | 
|
| 
       29 
29 
     | 
    
         
             
            # require 'rake/testtask'
         
     | 
| 
       30 
30 
     | 
    
         
             
            # require 'rake/rdoctask'
         
     | 
| 
       31 
31 
     | 
    
         
             
            # 
         
     | 
| 
       32 
     | 
    
         
            -
            # Version = '0.5. 
     | 
| 
      
 32 
     | 
    
         
            +
            # Version = '0.5.2'
         
     | 
| 
       33 
33 
     | 
    
         
             
            # 
         
     | 
| 
       34 
34 
     | 
    
         
             
            # module Rake::TaskManager
         
     | 
| 
       35 
35 
     | 
    
         
             
            #   def delete_task(task_class, *args, &block)
         
     | 
| 
         @@ -94,7 +94,7 @@ end 
     | 
|
| 
       94 
94 
     | 
    
         
             
            #   rdoc.rdoc_files.add(files)
         
     | 
| 
       95 
95 
     | 
    
         
             
            #   rdoc.main     = "README" 
         
     | 
| 
       96 
96 
     | 
    
         
             
            #   rdoc.title    = "ambition"
         
     | 
| 
       97 
     | 
    
         
            -
            #   rdoc.template = File.exists?(t="/Users/chris/ruby/projects/err/rock/template.rb") ? t : "/var/www/rock/template.rb"
         
     | 
| 
      
 97 
     | 
    
         
            +
            #   # rdoc.template = File.exists?(t="/Users/chris/ruby/projects/err/rock/template.rb") ? t : "/var/www/rock/template.rb"
         
     | 
| 
       98 
98 
     | 
    
         
             
            #   rdoc.rdoc_dir = 'doc' 
         
     | 
| 
       99 
99 
     | 
    
         
             
            #   rdoc.options << '--inline-source'
         
     | 
| 
       100 
100 
     | 
    
         
             
            # end
         
     | 
    
        data/lib/ambition/api.rb
    CHANGED
    
    | 
         @@ -1,4 +1,8 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            module Ambition
         
     | 
| 
      
 1 
     | 
    
         
            +
            module Ambition #:nodoc:
         
     | 
| 
      
 2 
     | 
    
         
            +
              # Module that you will extend from in your adapters in your toplevel file.
         
     | 
| 
      
 3 
     | 
    
         
            +
              # 
         
     | 
| 
      
 4 
     | 
    
         
            +
              # For example, for ambitious_sphinx in lib/ambition/adapters/ambitious_sphinx.rb, we have:
         
     | 
| 
      
 5 
     | 
    
         
            +
              #   ActiveRecord::Base.extend Ambition::API
         
     | 
| 
       2 
6 
     | 
    
         
             
              module API
         
     | 
| 
       3 
7 
     | 
    
         
             
                include Enumerable
         
     | 
| 
       4 
8 
     | 
    
         | 
| 
         @@ -14,6 +18,7 @@ module Ambition 
     | 
|
| 
       14 
18 
     | 
    
         
             
                  context << Processors::Sort.new(context, block)
         
     | 
| 
       15 
19 
     | 
    
         
             
                end
         
     | 
| 
       16 
20 
     | 
    
         | 
| 
      
 21 
     | 
    
         
            +
                # Entries that our context is able to find.
         
     | 
| 
       17 
22 
     | 
    
         
             
                def entries
         
     | 
| 
       18 
23 
     | 
    
         
             
                  ambition_context.kick
         
     | 
| 
       19 
24 
     | 
    
         
             
                end
         
     | 
| 
         @@ -31,45 +36,60 @@ module Ambition 
     | 
|
| 
       31 
36 
     | 
    
         | 
| 
       32 
37 
     | 
    
         
             
                ##
         
     | 
| 
       33 
38 
     | 
    
         
             
                # Convenience methods
         
     | 
| 
      
 39 
     | 
    
         
            +
                
         
     | 
| 
      
 40 
     | 
    
         
            +
                # See Enumerable#detect
         
     | 
| 
       34 
41 
     | 
    
         
             
                def detect(&block)
         
     | 
| 
       35 
42 
     | 
    
         
             
                  select(&block).first
         
     | 
| 
       36 
43 
     | 
    
         
             
                end
         
     | 
| 
       37 
44 
     | 
    
         | 
| 
      
 45 
     | 
    
         
            +
                # See Array#first
         
     | 
| 
       38 
46 
     | 
    
         
             
                def first(count = 1)
         
     | 
| 
       39 
47 
     | 
    
         
             
                  sliced = slice(0, count)
         
     | 
| 
       40 
48 
     | 
    
         
             
                  count == 1 ? Array(sliced.kick).first : sliced
         
     | 
| 
       41 
49 
     | 
    
         
             
                end
         
     | 
| 
       42 
50 
     | 
    
         | 
| 
      
 51 
     | 
    
         
            +
                # See Array#each, applied to +entries+
         
     | 
| 
       43 
52 
     | 
    
         
             
                def each(&block)
         
     | 
| 
       44 
53 
     | 
    
         
             
                  entries.each(&block)
         
     | 
| 
       45 
54 
     | 
    
         
             
                end
         
     | 
| 
       46 
55 
     | 
    
         | 
| 
      
 56 
     | 
    
         
            +
                # See Enumerable#any?
         
     | 
| 
       47 
57 
     | 
    
         
             
                def any?(&block)
         
     | 
| 
       48 
58 
     | 
    
         
             
                  select(&block).size > 0
         
     | 
| 
       49 
59 
     | 
    
         
             
                end
         
     | 
| 
       50 
60 
     | 
    
         | 
| 
      
 61 
     | 
    
         
            +
                # See Enumerable#all?
         
     | 
| 
       51 
62 
     | 
    
         
             
                def all?(&block)
         
     | 
| 
       52 
63 
     | 
    
         
             
                  size == select(&block).size
         
     | 
| 
       53 
64 
     | 
    
         
             
                end
         
     | 
| 
       54 
65 
     | 
    
         | 
| 
      
 66 
     | 
    
         
            +
                # See Array#empty?
         
     | 
| 
       55 
67 
     | 
    
         
             
                def empty?
         
     | 
| 
       56 
68 
     | 
    
         
             
                  size.zero?
         
     | 
| 
       57 
69 
     | 
    
         
             
                end
         
     | 
| 
       58 
70 
     | 
    
         | 
| 
       59 
     | 
    
         
            -
             
     | 
| 
       60 
     | 
    
         
            -
                #  
     | 
| 
      
 71 
     | 
    
         
            +
             
     | 
| 
      
 72 
     | 
    
         
            +
                # Builds a new +Context+.
         
     | 
| 
       61 
73 
     | 
    
         
             
                def ambition_context
         
     | 
| 
       62 
74 
     | 
    
         
             
                  Context.new(self)
         
     | 
| 
       63 
75 
     | 
    
         
             
                end
         
     | 
| 
       64 
76 
     | 
    
         | 
| 
      
 77 
     | 
    
         
            +
                # Gives you the current ambitious adapter.
         
     | 
| 
       65 
78 
     | 
    
         
             
                def ambition_adapter
         
     | 
| 
       66 
79 
     | 
    
         
             
                  name   = respond_to?(:name) ? name : self.class.name
         
     | 
| 
       67 
80 
     | 
    
         
             
                  parent = respond_to?(:superclass) ? superclass : self.class.superclass
         
     | 
| 
       68 
81 
     | 
    
         
             
                  @@ambition_adapter[name] || @@ambition_adapter[parent.name]
         
     | 
| 
       69 
82 
     | 
    
         
             
                end
         
     | 
| 
       70 
83 
     | 
    
         | 
| 
      
 84 
     | 
    
         
            +
                
         
     | 
| 
      
 85 
     | 
    
         
            +
                # Assign the ambition adapter. Typically, you use this in the toplevel file of your adapter.
         
     | 
| 
      
 86 
     | 
    
         
            +
                #
         
     | 
| 
      
 87 
     | 
    
         
            +
                # For example, for ambitious_sphinx, in our lib/ambition/adapters/ambitious_sphinx.rb:
         
     | 
| 
      
 88 
     | 
    
         
            +
                #
         
     | 
| 
      
 89 
     | 
    
         
            +
                #   ActiveRecord::Base.ambition_adapter = Ambition::Adapters::AmbitiousSphinx
         
     | 
| 
       71 
90 
     | 
    
         
             
                def ambition_adapter=(klass)
         
     | 
| 
       72 
91 
     | 
    
         
             
                  @@ambition_adapter ||= {}
         
     | 
| 
      
 92 
     | 
    
         
            +
                  # should this be doing the same check for respond_to?(:name) like above?
         
     | 
| 
       73 
93 
     | 
    
         
             
                  @@ambition_adapter[name] = klass
         
     | 
| 
       74 
94 
     | 
    
         
             
                end
         
     | 
| 
       75 
95 
     | 
    
         | 
    
        data/lib/ambition/context.rb
    CHANGED
    
    | 
         @@ -1,22 +1,32 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            module Ambition
         
     | 
| 
      
 1 
     | 
    
         
            +
            module Ambition #:nodoc:
         
     | 
| 
      
 2 
     | 
    
         
            +
              # This class includes several methods you will likely want to be accessing through your
         
     | 
| 
      
 3 
     | 
    
         
            +
              # Query and Translator classes:
         
     | 
| 
      
 4 
     | 
    
         
            +
              #
         
     | 
| 
      
 5 
     | 
    
         
            +
              # * +clauses+
         
     | 
| 
      
 6 
     | 
    
         
            +
              # * +owner+
         
     | 
| 
      
 7 
     | 
    
         
            +
              # * +stash+
         
     | 
| 
       2 
8 
     | 
    
         
             
              class Context
         
     | 
| 
      
 9 
     | 
    
         
            +
                undef_method :to_s
         
     | 
| 
       3 
10 
     | 
    
         
             
                include API
         
     | 
| 
       4 
     | 
    
         
            -
             
     | 
| 
       5 
     | 
    
         
            -
                 
     | 
| 
       6 
     | 
    
         
            -
                #  
     | 
| 
       7 
     | 
    
         
            -
                #  
     | 
| 
       8 
     | 
    
         
            -
                #
         
     | 
| 
       9 
     | 
    
         
            -
                # 
     | 
| 
      
 11 
     | 
    
         
            +
                
         
     | 
| 
      
 12 
     | 
    
         
            +
                # A hash of arrays, one key per processor.
         
     | 
| 
      
 13 
     | 
    
         
            +
                # So, if someone called User.select, your
         
     | 
| 
      
 14 
     | 
    
         
            +
                # +clauses+ hash would have a :select key with
         
     | 
| 
      
 15 
     | 
    
         
            +
                # an array of translated strings via your Select
         
     | 
| 
      
 16 
     | 
    
         
            +
                # class.
         
     | 
| 
      
 17 
     | 
    
         
            +
                # 
         
     | 
| 
      
 18 
     | 
    
         
            +
                # This is accessible from your Query and Translator classes.
         
     | 
| 
      
 19 
     | 
    
         
            +
                attr_reader :clauses
         
     | 
| 
      
 20 
     | 
    
         
            +
                
         
     | 
| 
      
 21 
     | 
    
         
            +
                # The class everything was called on.  Like `User`
         
     | 
| 
       10 
22 
     | 
    
         
             
                #
         
     | 
| 
       11 
     | 
    
         
            -
                # 
     | 
| 
       12 
     | 
    
         
            -
                 
     | 
| 
       13 
     | 
    
         
            -
                 
     | 
| 
       14 
     | 
    
         
            -
                # 
     | 
| 
       15 
     | 
    
         
            -
                #             class.
         
     | 
| 
      
 23 
     | 
    
         
            +
                # This is accessible from your Query and Translator classes.
         
     | 
| 
      
 24 
     | 
    
         
            +
                attr_reader :owner
         
     | 
| 
      
 25 
     | 
    
         
            +
                
         
     | 
| 
      
 26 
     | 
    
         
            +
                # A place for you to stick stuff.  Available to all Translators and your Query class.
         
     | 
| 
       16 
27 
     | 
    
         
             
                #
         
     | 
| 
       17 
     | 
    
         
            -
                # 
     | 
| 
       18 
     | 
    
         
            -
                 
     | 
| 
       19 
     | 
    
         
            -
                attr_reader :clauses, :owner, :stash
         
     | 
| 
      
 28 
     | 
    
         
            +
                # This is accessible from your Query and Translator classes.
         
     | 
| 
      
 29 
     | 
    
         
            +
                attr_reader :stash
         
     | 
| 
       20 
30 
     | 
    
         | 
| 
       21 
31 
     | 
    
         
             
                def initialize(owner)
         
     | 
| 
       22 
32 
     | 
    
         
             
                  @owner   = owner
         
     | 
| 
         @@ -24,10 +34,12 @@ module Ambition 
     | 
|
| 
       24 
34 
     | 
    
         
             
                  @stash   = {}
         
     | 
| 
       25 
35 
     | 
    
         
             
                end
         
     | 
| 
       26 
36 
     | 
    
         | 
| 
      
 37 
     | 
    
         
            +
                # Gets the ambition_context. From a Ambition::Context, this is actually +self+.
         
     | 
| 
       27 
38 
     | 
    
         
             
                def ambition_context
         
     | 
| 
       28 
39 
     | 
    
         
             
                  self
         
     | 
| 
       29 
40 
     | 
    
         
             
                end
         
     | 
| 
       30 
41 
     | 
    
         | 
| 
      
 42 
     | 
    
         
            +
                # Adds a clause to this context.
         
     | 
| 
       31 
43 
     | 
    
         
             
                def <<(clause)
         
     | 
| 
       32 
44 
     | 
    
         
             
                  @clauses[clause.key] ||= []
         
     | 
| 
       33 
45 
     | 
    
         
             
                  @clauses[clause.key] << clause.to_s
         
     | 
| 
         @@ -38,22 +50,10 @@ module Ambition 
     | 
|
| 
       38 
50 
     | 
    
         
             
                  Processors::Base.translator(self, :Query)
         
     | 
| 
       39 
51 
     | 
    
         
             
                end
         
     | 
| 
       40 
52 
     | 
    
         | 
| 
       41 
     | 
    
         
            -
                def  
     | 
| 
       42 
     | 
    
         
            -
                  adapter_query. 
     | 
| 
       43 
     | 
    
         
            -
             
     | 
| 
       44 
     | 
    
         
            -
             
     | 
| 
       45 
     | 
    
         
            -
                def to_s
         
     | 
| 
       46 
     | 
    
         
            -
                  adapter_query.to_s
         
     | 
| 
       47 
     | 
    
         
            -
                end
         
     | 
| 
       48 
     | 
    
         
            -
             
     | 
| 
       49 
     | 
    
         
            -
                def kick
         
     | 
| 
       50 
     | 
    
         
            -
                  adapter_query.kick
         
     | 
| 
       51 
     | 
    
         
            -
                end
         
     | 
| 
       52 
     | 
    
         
            -
             
     | 
| 
       53 
     | 
    
         
            -
                def size
         
     | 
| 
       54 
     | 
    
         
            -
                  adapter_query.size
         
     | 
| 
      
 53 
     | 
    
         
            +
                def method_missing(method, *args, &block)
         
     | 
| 
      
 54 
     | 
    
         
            +
                  return super unless adapter_query.respond_to? method
         
     | 
| 
      
 55 
     | 
    
         
            +
                  adapter_query.send(method, *args, &block)
         
     | 
| 
       55 
56 
     | 
    
         
             
                end
         
     | 
| 
       56 
     | 
    
         
            -
                alias_method :length, :size
         
     | 
| 
       57 
57 
     | 
    
         | 
| 
       58 
58 
     | 
    
         
             
                def inspect
         
     | 
| 
       59 
59 
     | 
    
         
             
                  "(Query object: call #to_s or #to_hash to inspect, call an Enumerable (such as #each or #first) to request data)"
         
     | 
    
        data/lib/ambition/core_ext.rb
    CHANGED
    
    
    
        data/lib/ambition/enumerable.rb
    CHANGED
    
    
| 
         @@ -1,5 +1,5 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            module Ambition
         
     | 
| 
       2 
     | 
    
         
            -
              module Processors
         
     | 
| 
      
 1 
     | 
    
         
            +
            module Ambition #:nodoc:
         
     | 
| 
      
 2 
     | 
    
         
            +
              module Processors #:nodoc:
         
     | 
| 
       3 
3 
     | 
    
         
             
                class Base
         
     | 
| 
       4 
4 
     | 
    
         
             
                  ##
         
     | 
| 
       5 
5 
     | 
    
         
             
                  # Processing methods
         
     | 
| 
         @@ -93,15 +93,26 @@ module Ambition 
     | 
|
| 
       93 
93 
     | 
    
         
             
                    eval variable, @block
         
     | 
| 
       94 
94 
     | 
    
         
             
                  end
         
     | 
| 
       95 
95 
     | 
    
         | 
| 
      
 96 
     | 
    
         
            +
                  # Gives you the current translator. Uses +self.translator+ to look it up,
         
     | 
| 
      
 97 
     | 
    
         
            +
                  # if it isn't known yet.
         
     | 
| 
       96 
98 
     | 
    
         
             
                  def translator
         
     | 
| 
       97 
99 
     | 
    
         
             
                    @translator ||= self.class.translator(@context)
         
     | 
| 
       98 
100 
     | 
    
         
             
                  end
         
     | 
| 
       99 
101 
     | 
    
         | 
| 
       100 
102 
     | 
    
         
             
                  def self.translator(context, name = nil)
         
     | 
| 
      
 103 
     | 
    
         
            +
                    # Grok the adapter name
         
     | 
| 
       101 
104 
     | 
    
         
             
                    name   ||= self.name.split('::').last
         
     | 
| 
      
 105 
     | 
    
         
            +
                    # Get the module for it
         
     | 
| 
       102 
106 
     | 
    
         
             
                    klass    = context.owner.ambition_adapter.const_get(name)
         
     | 
| 
       103 
107 
     | 
    
         
             
                    instance = klass.new
         
     | 
| 
       104 
108 
     | 
    
         | 
| 
      
 109 
     | 
    
         
            +
                    # Make sure that the instance has everything it will need:
         
     | 
| 
      
 110 
     | 
    
         
            +
                    #
         
     | 
| 
      
 111 
     | 
    
         
            +
                    # * context
         
     | 
| 
      
 112 
     | 
    
         
            +
                    # * owner
         
     | 
| 
      
 113 
     | 
    
         
            +
                    # * clauses
         
     | 
| 
      
 114 
     | 
    
         
            +
                    # * stash
         
     | 
| 
      
 115 
     | 
    
         
            +
                    # * negated?
         
     | 
| 
       105 
116 
     | 
    
         
             
                    unless instance.respond_to? :context
         
     | 
| 
       106 
117 
     | 
    
         
             
                      klass.class_eval do
         
     | 
| 
       107 
118 
     | 
    
         
             
                        attr_accessor :context, :negated
         
     | 
    
        metadata
    CHANGED
    
    | 
         @@ -3,8 +3,8 @@ rubygems_version: 0.9.4 
     | 
|
| 
       3 
3 
     | 
    
         
             
            specification_version: 1
         
     | 
| 
       4 
4 
     | 
    
         
             
            name: ambition
         
     | 
| 
       5 
5 
     | 
    
         
             
            version: !ruby/object:Gem::Version 
         
     | 
| 
       6 
     | 
    
         
            -
              version: 0.5. 
     | 
| 
       7 
     | 
    
         
            -
            date: 2008-02- 
     | 
| 
      
 6 
     | 
    
         
            +
              version: 0.5.2
         
     | 
| 
      
 7 
     | 
    
         
            +
            date: 2008-02-29 00:00:00 -08:00
         
     | 
| 
       8 
8 
     | 
    
         
             
            summary: Ambition builds yer API calls from plain jane Ruby.
         
     | 
| 
       9 
9 
     | 
    
         
             
            require_paths: 
         
     | 
| 
       10 
10 
     | 
    
         
             
            - lib
         
     |