summaryrefslogtreecommitdiffstats
path: root/app/models/setting.rb
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-05-18 02:19:08 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-05-18 02:19:08 +0000
commitc5554dd65e270f9a883494a62fe70603cf6fd807 (patch)
treefd1d08102970750799ddf840a70c7fb50f00fe5c /app/models/setting.rb
parent71088ed8473a65fcdf9c5b141661e4f9d1fc4ad6 (diff)
downloadredmine-c5554dd65e270f9a883494a62fe70603cf6fd807.tar.gz
redmine-c5554dd65e270f9a883494a62fe70603cf6fd807.zip
remove trailing white-spaces from setting model source.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@5828 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/setting.rb')
-rw-r--r--app/models/setting.rb40
1 files changed, 20 insertions, 20 deletions
diff --git a/app/models/setting.rb b/app/models/setting.rb
index 8f5b83b05..80e084e9c 100644
--- a/app/models/setting.rb
+++ b/app/models/setting.rb
@@ -1,16 +1,16 @@
-# redMine - project management software
-# Copyright (C) 2006-2007 Jean-Philippe Lang
+# Redmine - project management software
+# Copyright (C) 2006-2011 Jean-Philippe Lang
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
-#
+#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
-#
+#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
@@ -28,12 +28,12 @@ class Setting < ActiveRecord::Base
'%b %d, %Y',
'%B %d, %Y'
]
-
+
TIME_FORMATS = [
'%H:%M',
'%I:%M %p'
]
-
+
ENCODINGS = %w(US-ASCII
windows-1250
windows-1251
@@ -73,22 +73,22 @@ class Setting < ActiveRecord::Base
Big5
Big5-HKSCS
TIS-620)
-
+
cattr_accessor :available_settings
@@available_settings = YAML::load(File.open("#{RAILS_ROOT}/config/settings.yml"))
Redmine::Plugin.all.each do |plugin|
next unless plugin.settings
- @@available_settings["plugin_#{plugin.id}"] = {'default' => plugin.settings[:default], 'serialized' => true}
+ @@available_settings["plugin_#{plugin.id}"] = {'default' => plugin.settings[:default], 'serialized' => true}
end
-
+
validates_uniqueness_of :name
validates_inclusion_of :name, :in => @@available_settings.keys
- validates_numericality_of :value, :only_integer => true, :if => Proc.new { |setting| @@available_settings[setting.name]['format'] == 'int' }
+ validates_numericality_of :value, :only_integer => true, :if => Proc.new { |setting| @@available_settings[setting.name]['format'] == 'int' }
# Hash used to cache setting values
@cached_settings = {}
@cached_cleared_on = Time.now
-
+
def value
v = read_attribute(:value)
# Unserialize serialized settings
@@ -96,18 +96,18 @@ class Setting < ActiveRecord::Base
v = v.to_sym if @@available_settings[name]['format'] == 'symbol' && !v.blank?
v
end
-
+
def value=(v)
v = v.to_yaml if v && @@available_settings[name] && @@available_settings[name]['serialized']
write_attribute(:value, v.to_s)
end
-
+
# Returns the value of the setting named name
def self.[](name)
v = @cached_settings[name]
v ? v : (@cached_settings[name] = find_or_default(name).value)
end
-
+
def self.[]=(name, v)
setting = find_or_default(name)
setting.value = (v ? v : "")
@@ -115,7 +115,7 @@ class Setting < ActiveRecord::Base
setting.save
setting.value
end
-
+
# Defines getter and setter for each setting
# Then setting values can be read using: Setting.some_setting_name
# or set using Setting.some_setting_name = "some value"
@@ -135,16 +135,16 @@ class Setting < ActiveRecord::Base
END_SRC
class_eval src, __FILE__, __LINE__
end
-
+
# Helper that returns an array based on per_page_options setting
def self.per_page_options_array
per_page_options.split(%r{[\s,]}).collect(&:to_i).select {|n| n > 0}.sort
end
-
+
def self.openid?
Object.const_defined?(:OpenID) && self[:openid].to_i > 0
end
-
+
# Checks if settings have changed since the values were read
# and clears the cache hash if it's the case
# Called once per request
@@ -156,13 +156,13 @@ class Setting < ActiveRecord::Base
logger.info "Settings cache cleared." if logger
end
end
-
+
private
# Returns the Setting instance for the setting named name
# (record found in database or new record with default value)
def self.find_or_default(name)
name = name.to_s
- raise "There's no setting named #{name}" unless @@available_settings.has_key?(name)
+ raise "There's no setting named #{name}" unless @@available_settings.has_key?(name)
setting = find_by_name(name)
setting ||= new(:name => name, :value => @@available_settings[name]['default']) if @@available_settings.has_key? name
end