# encoding: utf-8 # Copyright (c) 2009 Durran Jordan # # Permission is hereby granted, free of charge, to any person obtaining # a copy of this software and associated documentation files (the # "Software"), to deal in the Software without restriction, including # without limitation the rights to use, copy, modify, merge, publish, # distribute, sublicense, and/or sell copies of the Software, and to # permit persons to whom the Software is furnished to do so, subject to # the following conditions: # # The above copyright notice and this permission notice shall be # included in all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. require "rubygems" gem "activesupport", ">= 2.2.2", "<3.0.pre" gem "mongo", ">= 0.18.3" gem "durran-validatable", ">= 2.0.1" gem "will_paginate", ">= 2.3.11", "<3.0.pre" require "delegate" require "observer" require "singleton" require "time" require "validatable" require "active_support/callbacks" require "active_support/core_ext" require "active_support/inflector" require "active_support/time_with_zone" require "will_paginate/collection" require "mongo" require "mongoid/associations" require "mongoid/associations/options" require "mongoid/attributes" require "mongoid/callbacks" require "mongoid/collection" require "mongoid/commands" require "mongoid/config" require "mongoid/contexts" require "mongoid/criteria" require "mongoid/cursor" require "mongoid/enslavement" require "mongoid/extensions" require "mongoid/errors" require "mongoid/factory" require "mongoid/field" require "mongoid/fields" require "mongoid/finders" require "mongoid/identity" require "mongoid/indexes" require "mongoid/matchers" require "mongoid/memoization" require "mongoid/named_scope" require "mongoid/scope" require "mongoid/timestamps" require "mongoid/versioning" require "mongoid/components" require "mongoid/document" module Mongoid #:nodoc class << self # Sets the Mongoid configuration options. Best used by passing a block. # # Example: # # Mongoid.configure do |config| # name = "mongoid_test" # host = "localhost" # config.allow_dynamic_fields = false # config.master = Mongo::Connection.new.db(name) # config.slaves = [ # Mongo::Connection.new(host, 27018, :slave_ok => true).db(name), # Mongo::Connection.new(host, 27019, :slave_ok => true).db(name) # ] # end # # Returns: # # The Mongoid +Config+ singleton instance. def configure config = Config.instance block_given? ? yield(config) : config end alias :config :configure end # Take all the public instance methods from the Config singleton and allow # them to be accessed through the Mongoid module directly. # # Example: # # Mongoid.database = Mongo::Connection.new.db("test") Config.public_instance_methods(false).each do |name| (class << self; self; end).class_eval <<-EOT def #{name}(*args) configure.send("#{name}", *args) end EOT end end