multi_logger 0.0.1 → 0.1.0

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 7781fb7ec45c05fd258ffd68a4fa97e5a892133f
4
+ data.tar.gz: 8b735244380af2fcd0b781ddafea50d05be2a183
5
+ SHA512:
6
+ metadata.gz: 436ffcf55924ee88d289f3b04f32ba698d35499cdb2fd1c9467c1938474eb20480f86dd9248b34ab4877383f072873b0140f453623c1e2287459a6c6148b7fce
7
+ data.tar.gz: e2501ae314f9c04e8e79f7cd74685e2b2993337c242e88317c935f635d893c2f209ab1694bb8b484bb56a9d7f5d988cef35af355d6311a4e435d9c77122989ea
@@ -0,0 +1,9 @@
1
+ # Change log
2
+
3
+ ## 0.1.0 - 2013/09/13
4
+
5
+ * [Enhancement] Accept `shift_age` and `shift size` as an argument to the `Logger.new` - Keisuke KITA
6
+
7
+ ## 0.0.1 - 2013/05/30
8
+
9
+ * Initial publication
data/README.md CHANGED
@@ -18,9 +18,17 @@ Or install it yourself as:
18
18
 
19
19
  ## Usage
20
20
 
21
- To setup a logger, create a initializer script like `[Rails.root]/config/initializers/logger.rb`. In the script, call `MultiLogger.add_logger(log_name)` to create new logger. For example, calling `MultiLogger.add_logger('mail')` will create a log file located at `log/mail.log`.
21
+ To setup a logger, create an initializer script such as `[Rails.root]/config/initializers/logger.rb` with:
22
22
 
23
- In Rails, you can access the logger by calling `logger.log_name` or `Rails.logger.log_name`. For example, calling `logger.mail.debug('42')` will log the message in the mail log.
23
+ MultiLogger.add_logger('mail')
24
+
25
+ This will create a log file located at `log/mail.log`.
26
+
27
+ Then In Rails, you can log by calling the following:
28
+
29
+ Rails.logger.mail.debug('42')
30
+
31
+ The `Rails.` reference can be omitted at the usual places in Rails (e.g. controllers and views).
24
32
 
25
33
  Note that log_name must not collide with existing method names in Rails logger, so names such as 'debug' or 'info' can not be used. You should try calling `add_logger` in Rails console to test if it is ok or raises an error.
26
34
 
@@ -28,14 +36,11 @@ Note that log_name must not collide with existing method names in Rails logger,
28
36
 
29
37
  You can assign formatter to loggers directly, or pass the formatter during setup:
30
38
 
31
- class CustomFormatter
32
- def call(severity, time, progname, msg)
33
- formatted_severity = sprintf("%-5s",severity.to_s)
34
- formatted_time = time.strftime("%Y-%m-%d %H:%M:%S")
35
- "[#{formatted_severity} #{formatted_time}] #{msg.strip}\n"
36
- end
37
- end
38
- formatter = CustomFormatter.new
39
+ formatter = Proc.new{|severity, time, progname, msg|
40
+ formatted_severity = sprintf("%-5s",severity.to_s)
41
+ formatted_time = time.strftime("%Y-%m-%d %H:%M:%S")
42
+ "[#{formatted_severity} #{formatted_time} #{$$}] #{msg.to_s.strip}\n"
43
+ }
39
44
  MultiLogger.add_logger('mail', formatter:formatter)
40
45
  MultiLogger.add_logger('user', formatter:formatter)
41
46
 
@@ -9,7 +9,7 @@ module MultiLogger
9
9
  if rails_logger_class.method_defined?(name)
10
10
  raise "'#{name}' is reserved in #{rails_logger_class} and can not be used as a log accessor name."
11
11
  else
12
- logger = Logger.new(get_path(name, options[:path]))
12
+ logger = Logger.new(*extract_options(name, options))
13
13
  rails_logger_class.class_eval do
14
14
  define_method name.to_sym do
15
15
  logger
@@ -33,6 +33,7 @@ module MultiLogger
33
33
  if !path.end_with?('.log')
34
34
  path += '.log'
35
35
  end
36
+ path
36
37
  end
37
38
 
38
39
  def get_rails_logger_class
@@ -44,5 +45,16 @@ module MultiLogger
44
45
  raise 'Rails logger not found'
45
46
  end
46
47
  end
48
+
49
+ def extract_options(name, options)
50
+ if options[:shift_age] && options[:shift_size]
51
+ [get_path(name, options[:path]), options[:shift_age], options[:shift_size]]
52
+ elsif options[:shift_age]
53
+ # options[:shift_age] => 'daily', 'weekly'
54
+ [get_path(name, options[:path]), options[:shift_age]]
55
+ else
56
+ [get_path(name, options[:path])]
57
+ end
58
+ end
47
59
  end
48
60
  end
@@ -1,3 +1,3 @@
1
1
  module MultiLogger
2
- VERSION = "0.0.1"
2
+ VERSION = "0.1.0"
3
3
  end
metadata CHANGED
@@ -1,30 +1,27 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: multi_logger
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.1
5
- prerelease:
4
+ version: 0.1.0
6
5
  platform: ruby
7
6
  authors:
8
7
  - lulalala
9
8
  autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2013-05-30 00:00:00.000000000 Z
11
+ date: 2013-09-13 00:00:00.000000000 Z
13
12
  dependencies:
14
13
  - !ruby/object:Gem::Dependency
15
14
  name: railties
16
15
  requirement: !ruby/object:Gem::Requirement
17
- none: false
18
16
  requirements:
19
- - - ! '>='
17
+ - - '>='
20
18
  - !ruby/object:Gem::Version
21
19
  version: '0'
22
20
  type: :runtime
23
21
  prerelease: false
24
22
  version_requirements: !ruby/object:Gem::Requirement
25
- none: false
26
23
  requirements:
27
- - - ! '>='
24
+ - - '>='
28
25
  - !ruby/object:Gem::Version
29
26
  version: '0'
30
27
  description: Create multiple loggers in Rails.
@@ -35,6 +32,7 @@ extensions: []
35
32
  extra_rdoc_files: []
36
33
  files:
37
34
  - .gitignore
35
+ - CHANGES.md
38
36
  - Gemfile
39
37
  - LICENSE.txt
40
38
  - README.md
@@ -44,27 +42,26 @@ files:
44
42
  - multi_logger.gemspec
45
43
  homepage: https://github.com/lulalala/multi_logger
46
44
  licenses: []
45
+ metadata: {}
47
46
  post_install_message:
48
47
  rdoc_options: []
49
48
  require_paths:
50
49
  - lib
51
50
  required_ruby_version: !ruby/object:Gem::Requirement
52
- none: false
53
51
  requirements:
54
- - - ! '>='
52
+ - - '>='
55
53
  - !ruby/object:Gem::Version
56
54
  version: '0'
57
55
  required_rubygems_version: !ruby/object:Gem::Requirement
58
- none: false
59
56
  requirements:
60
- - - ! '>='
57
+ - - '>='
61
58
  - !ruby/object:Gem::Version
62
59
  version: '0'
63
60
  requirements: []
64
61
  rubyforge_project:
65
- rubygems_version: 1.8.24
62
+ rubygems_version: 2.0.5
66
63
  signing_key:
67
- specification_version: 3
64
+ specification_version: 4
68
65
  summary: Provide helper to define loggers and access them. Each logger will log into
69
66
  a different file under the log folder.
70
67
  test_files: []