block_logger 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (5) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +21 -0
  3. data/README.md +6 -0
  4. data/lib/block_logger.rb +66 -0
  5. metadata +104 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: a9665f97cc309e2045c231ecb66fa35e0bf82920
4
+ data.tar.gz: 29e5a8c9c30ea9a92c4bf5b77f8f21ce154ea984
5
+ SHA512:
6
+ metadata.gz: 5cf02940fe01333b36631fa8bd5189462a51a89ae325ecade542c2a8cc2c92ee79b5dd961e31233e215ae4bc8fcd81f3d8281e7a4d155e244bcfa7907ab5c0a3
7
+ data.tar.gz: baf8169b489a9833b9906f02494bdbcfb7d07830d46aefee752c323938cdf211cbcdcab195fe6d322f379f7145eb1e1b071b5e57c930ca5e6123f1494abb7fdc
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 Jan Xie
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,6 @@
1
+ # BlockLogger
2
+
3
+ [![MIT License](https://img.shields.io/packagist/l/doctrine/orm.svg)](LICENSE)
4
+
5
+ A convenient logger.
6
+
@@ -0,0 +1,66 @@
1
+ require 'logging'
2
+
3
+ class BlockLogger
4
+
5
+ VERSION = '0.1.0'
6
+
7
+ DEFAULT_LOG_LEVEL = :info
8
+ DEFAULT_LOG_PATTERN = "%.1l, [%d] %5l -- %c: %m\n".freeze
9
+
10
+ Logging.logger.root.level = DEFAULT_LOG_LEVEL
11
+
12
+ Logging.logger.root.appenders = Logging.appenders.stdout(
13
+ layout: Logging.layouts.pattern.new(pattern: DEFAULT_LOG_PATTERN))
14
+
15
+ class <<self
16
+ def trace?(name)
17
+ !!traces[name]
18
+ end
19
+
20
+ def set_trace(name, v=true)
21
+ traces[name] = v
22
+ end
23
+
24
+ def traces
25
+ @traces ||= {}
26
+ end
27
+ end
28
+
29
+ attr :name
30
+
31
+ def initialize(name, logger=nil)
32
+ @name = name
33
+ @logger = logger || Logging.logger[name]
34
+ end
35
+
36
+ def trace(msg, **kwargs)
37
+ if self.class.trace?(name)
38
+ @logger.info "TRACE #{msg}#{serialize_kwargs(kwargs)}"
39
+ end
40
+ end
41
+
42
+ def fatal(msg, **kwargs)
43
+ @logger.fatal "#{msg}#{serialize_kwargs(kwargs)}"
44
+ end
45
+
46
+ def error(msg, **kwargs)
47
+ @logger.error "#{msg}#{serialize_kwargs(kwargs)}"
48
+ end
49
+
50
+ def warn(msg, **kwargs)
51
+ @logger.warn "#{msg}#{serialize_kwargs(kwargs)}"
52
+ end
53
+
54
+ def info(msg, **kwargs)
55
+ @logger.info "#{msg}#{serialize_kwargs(kwargs)}"
56
+ end
57
+
58
+ def debug(msg, **kwargs)
59
+ @logger.debug "#{msg}#{serialize_kwargs(kwargs)}"
60
+ end
61
+
62
+ def serialize_kwargs(kwargs)
63
+ " #{kwargs.map {|k,v| "#{k}=#{v}" }.join(' ')}"
64
+ end
65
+
66
+ end
metadata ADDED
@@ -0,0 +1,104 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: block_logger
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Jan Xie
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-04-13 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: logging
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '2.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '2.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.5'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.5'
41
+ - !ruby/object:Gem::Dependency
42
+ name: minitest
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '='
46
+ - !ruby/object:Gem::Version
47
+ version: 5.8.3
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '='
53
+ - !ruby/object:Gem::Version
54
+ version: 5.8.3
55
+ - !ruby/object:Gem::Dependency
56
+ name: yard
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '='
60
+ - !ruby/object:Gem::Version
61
+ version: 0.8.7.6
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - '='
67
+ - !ruby/object:Gem::Version
68
+ version: 0.8.7.6
69
+ description:
70
+ email:
71
+ - jan.h.xie@gmail.com
72
+ executables: []
73
+ extensions: []
74
+ extra_rdoc_files: []
75
+ files:
76
+ - LICENSE
77
+ - README.md
78
+ - lib/block_logger.rb
79
+ homepage: https://github.com/janx/block_logger
80
+ licenses:
81
+ - MIT
82
+ metadata: {}
83
+ post_install_message:
84
+ rdoc_options: []
85
+ require_paths:
86
+ - lib
87
+ required_ruby_version: !ruby/object:Gem::Requirement
88
+ requirements:
89
+ - - ">="
90
+ - !ruby/object:Gem::Version
91
+ version: '0'
92
+ required_rubygems_version: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ requirements: []
98
+ rubyforge_project:
99
+ rubygems_version: 2.4.5.1
100
+ signing_key:
101
+ specification_version: 4
102
+ summary: A convenient logger.
103
+ test_files: []
104
+ has_rdoc: