ext_logger 0.1.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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: ed3ad2d587a8dc3a9ee714afc68b3c470a7a320b
4
+ data.tar.gz: 60331d8b572e0a0e43314d053208137876ab97b8
5
+ SHA512:
6
+ metadata.gz: af593b2419a49ae2932203e0f91e9d8ba1b1d31c9c9ddb8f887ce1f881491d8e14bb5bead43240be365a29f433da69ce4800d4697d2bf7b56a36d34cdbf314c7
7
+ data.tar.gz: f8dacf4ba99c009ccbddf2e078a175e7087d8461a14fc0ec18b0e74241c3d90d7d3297207b28f7366cc85e918119b27fdceb27da7f244eba15b0f76115b6c7ad
data/.gitignore ADDED
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
data/.idea/.rakeTasks ADDED
@@ -0,0 +1,7 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <Settings><!--This file was automatically generated by Ruby plugin.
3
+ You are allowed to:
4
+ 1. Remove rake task
5
+ 2. Add existing rake tasks
6
+ To add existing rake tasks automatically delete this file and reload the project.
7
+ --><RakeGroup description="" fullCmd="" taksId="rake"><RakeTask description="Build ext_logger-0.1.1.gem into the pkg directory" fullCmd="build" taksId="build" /><RakeTask description="Build and install ext_logger-0.1.1.gem into system gems" fullCmd="install" taksId="install" /><RakeTask description="Create tag v0.1.1 and build and push ext_logger-0.1.1.gem to Rubygems" fullCmd="release" taksId="release" /><RakeTask description="" fullCmd="default" taksId="default" /></RakeGroup></Settings>
@@ -0,0 +1,11 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <module type="RUBY_MODULE" version="4">
3
+ <component name="ModuleRunConfigurationManager">
4
+ <shared />
5
+ </component>
6
+ <component name="NewModuleRootManager">
7
+ <content url="file://$MODULE_DIR$" />
8
+ <orderEntry type="inheritedJdk" />
9
+ <orderEntry type="sourceFolder" forTests="false" />
10
+ </component>
11
+ </module>
@@ -0,0 +1,6 @@
1
+ <component name="InspectionProjectProfileManager">
2
+ <profile version="1.0">
3
+ <option name="myName" value="Project Default" />
4
+ <inspection_tool class="Rubocop" enabled="false" level="WARNING" enabled_by_default="false" />
5
+ </profile>
6
+ </component>
data/.idea/misc.xml ADDED
@@ -0,0 +1,4 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ProjectRootManager" version="2" project-jdk-name="RVM: ruby-2.1.5" project-jdk-type="RUBY_SDK" />
4
+ </project>
data/.idea/modules.xml ADDED
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ProjectModuleManager">
4
+ <modules>
5
+ <module fileurl="file://$PROJECT_DIR$/.idea/ext_logger.iml" filepath="$PROJECT_DIR$/.idea/ext_logger.iml" />
6
+ </modules>
7
+ </component>
8
+ </project>
data/.idea/vcs.xml ADDED
@@ -0,0 +1,6 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="VcsDirectoryMappings">
4
+ <mapping directory="$PROJECT_DIR$" vcs="Git" />
5
+ </component>
6
+ </project>
@@ -0,0 +1,268 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ChangeListManager">
4
+ <list default="true" id="09d7e2e9-1cd6-481d-b2bb-16f8f2694524" name="Default" comment="">
5
+ <change type="DELETED" beforePath="$PROJECT_DIR$/.ruby-gemset" afterPath="" />
6
+ <change type="DELETED" beforePath="$PROJECT_DIR$/.ruby-version" afterPath="" />
7
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/.idea/workspace.xml" afterPath="$PROJECT_DIR$/.idea/workspace.xml" />
8
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/README.md" afterPath="$PROJECT_DIR$/README.md" />
9
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/ext_logger.gemspec" afterPath="$PROJECT_DIR$/ext_logger.gemspec" />
10
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/lib/ext_logger/version.rb" afterPath="$PROJECT_DIR$/lib/ext_logger/version.rb" />
11
+ </list>
12
+ <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" />
13
+ <option name="TRACKING_ENABLED" value="true" />
14
+ <option name="SHOW_DIALOG" value="false" />
15
+ <option name="HIGHLIGHT_CONFLICTS" value="true" />
16
+ <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
17
+ <option name="LAST_RESOLUTION" value="IGNORE" />
18
+ </component>
19
+ <component name="FileEditorManager">
20
+ <leaf>
21
+ <file leaf-file-name="README.md" pinned="false" current-in-tab="false">
22
+ <entry file="file://$PROJECT_DIR$/README.md">
23
+ <provider selected="true" editor-type-id="split-provider[text-editor;markdown-preview-editor]">
24
+ <state split_layout="SPLIT">
25
+ <first_editor relative-caret-position="75">
26
+ <caret line="5" column="75" lean-forward="false" selection-start-line="5" selection-start-column="75" selection-end-line="5" selection-end-column="75" />
27
+ <folding />
28
+ </first_editor>
29
+ <second_editor />
30
+ </state>
31
+ </provider>
32
+ </entry>
33
+ </file>
34
+ <file leaf-file-name="ext_logger.gemspec" pinned="false" current-in-tab="false">
35
+ <entry file="file://$PROJECT_DIR$/ext_logger.gemspec">
36
+ <provider selected="true" editor-type-id="text-editor">
37
+ <state relative-caret-position="240">
38
+ <caret line="16" column="41" lean-forward="true" selection-start-line="16" selection-start-column="41" selection-end-line="16" selection-end-column="41" />
39
+ <folding />
40
+ </state>
41
+ </provider>
42
+ </entry>
43
+ </file>
44
+ <file leaf-file-name="version.rb" pinned="false" current-in-tab="true">
45
+ <entry file="file://$PROJECT_DIR$/lib/ext_logger/version.rb">
46
+ <provider selected="true" editor-type-id="text-editor">
47
+ <state relative-caret-position="30">
48
+ <caret line="2" column="18" lean-forward="false" selection-start-line="2" selection-start-column="18" selection-end-line="2" selection-end-column="18" />
49
+ <folding />
50
+ </state>
51
+ </provider>
52
+ </entry>
53
+ </file>
54
+ <file leaf-file-name="logger.rb" pinned="false" current-in-tab="false">
55
+ <entry file="file://$PROJECT_DIR$/lib/ext_logger/logger.rb">
56
+ <provider selected="true" editor-type-id="text-editor">
57
+ <state relative-caret-position="503">
58
+ <caret line="102" column="32" lean-forward="false" selection-start-line="102" selection-start-column="32" selection-end-line="102" selection-end-column="32" />
59
+ <folding />
60
+ </state>
61
+ </provider>
62
+ </entry>
63
+ </file>
64
+ </leaf>
65
+ </component>
66
+ <component name="Git.Settings">
67
+ <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
68
+ </component>
69
+ <component name="IdeDocumentHistory">
70
+ <option name="CHANGED_PATHS">
71
+ <list>
72
+ <option value="$PROJECT_DIR$/.ruby-gemset" />
73
+ <option value="$PROJECT_DIR$/README.md" />
74
+ <option value="$PROJECT_DIR$/ext_logger.gemspec" />
75
+ <option value="$PROJECT_DIR$/lib/ext_logger/version.rb" />
76
+ </list>
77
+ </option>
78
+ </component>
79
+ <component name="JsBuildToolGruntFileManager" detection-done="true" sorting="DEFINITION_ORDER" />
80
+ <component name="JsBuildToolPackageJson" detection-done="true" sorting="DEFINITION_ORDER" />
81
+ <component name="JsGulpfileManager">
82
+ <detection-done>true</detection-done>
83
+ <sorting>DEFINITION_ORDER</sorting>
84
+ </component>
85
+ <component name="ProjectFrameBounds" fullScreen="true">
86
+ <option name="width" value="1280" />
87
+ <option name="height" value="800" />
88
+ </component>
89
+ <component name="ProjectView">
90
+ <navigator currentView="ProjectPane" proportions="" version="1">
91
+ <flattenPackages />
92
+ <showMembers />
93
+ <showModules />
94
+ <showLibraryContents />
95
+ <hideEmptyPackages />
96
+ <abbreviatePackageNames />
97
+ <autoscrollToSource />
98
+ <autoscrollFromSource />
99
+ <sortByType />
100
+ <manualOrder />
101
+ <foldersAlwaysOnTop value="true" />
102
+ </navigator>
103
+ <panes>
104
+ <pane id="Scratches" />
105
+ <pane id="Scope" />
106
+ <pane id="ProjectPane">
107
+ <subPane>
108
+ <expand>
109
+ <path>
110
+ <item name="ext_logger" type="b2602c69:ProjectViewProjectNode" />
111
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
112
+ </path>
113
+ <path>
114
+ <item name="ext_logger" type="b2602c69:ProjectViewProjectNode" />
115
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
116
+ <item name="bin" type="462c0819:PsiDirectoryNode" />
117
+ </path>
118
+ <path>
119
+ <item name="ext_logger" type="b2602c69:ProjectViewProjectNode" />
120
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
121
+ <item name="lib" type="462c0819:PsiDirectoryNode" />
122
+ </path>
123
+ <path>
124
+ <item name="ext_logger" type="b2602c69:ProjectViewProjectNode" />
125
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
126
+ <item name="lib" type="462c0819:PsiDirectoryNode" />
127
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
128
+ </path>
129
+ <path>
130
+ <item name="ext_logger" type="b2602c69:ProjectViewProjectNode" />
131
+ <item name="ext_logger" type="462c0819:PsiDirectoryNode" />
132
+ <item name="pkg" type="462c0819:PsiDirectoryNode" />
133
+ </path>
134
+ </expand>
135
+ <select />
136
+ </subPane>
137
+ </pane>
138
+ </panes>
139
+ </component>
140
+ <component name="PropertiesComponent">
141
+ <property name="nodejs_interpreter_path" value="/usr/local/bin/node" />
142
+ <property name="settings.editor.selected.configurable" value="preferences.lookFeel" />
143
+ <property name="WebServerToolWindowFactoryState" value="false" />
144
+ </component>
145
+ <component name="RecentsManager">
146
+ <key name="MoveFile.RECENT_KEYS">
147
+ <recent name="$PROJECT_DIR$/pkg" />
148
+ </key>
149
+ <key name="CopyFile.RECENT_KEYS">
150
+ <recent name="$PROJECT_DIR$" />
151
+ </key>
152
+ </component>
153
+ <component name="RunDashboard">
154
+ <option name="ruleStates">
155
+ <list>
156
+ <RuleState>
157
+ <option name="name" value="ConfigurationTypeDashboardGroupingRule" />
158
+ </RuleState>
159
+ <RuleState>
160
+ <option name="name" value="StatusDashboardGroupingRule" />
161
+ </RuleState>
162
+ </list>
163
+ </option>
164
+ </component>
165
+ <component name="ShelveChangesManager" show_recycled="false">
166
+ <option name="remove_strategy" value="false" />
167
+ </component>
168
+ <component name="SpringUtil" SPRING_PRE_LOADER_OPTION="true" />
169
+ <component name="TaskManager">
170
+ <task active="true" id="Default" summary="Default task">
171
+ <changelist id="09d7e2e9-1cd6-481d-b2bb-16f8f2694524" name="Default" comment="" />
172
+ <created>1543388051130</created>
173
+ <option name="number" value="Default" />
174
+ <option name="presentableId" value="Default" />
175
+ <updated>1543388051130</updated>
176
+ <workItem from="1543388052866" duration="1061000" />
177
+ </task>
178
+ <servers />
179
+ </component>
180
+ <component name="TimeTrackingManager">
181
+ <option name="totallyTimeSpent" value="1061000" />
182
+ </component>
183
+ <component name="ToolWindowManager">
184
+ <frame x="0" y="0" width="1280" height="800" extended-state="0" />
185
+ <editor active="true" />
186
+ <layout>
187
+ <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" show_stripe_button="true" weight="0.2494043" sideWeight="0.5" order="0" side_tool="false" content_ui="combo" />
188
+ <window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
189
+ <window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
190
+ <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
191
+ <window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
192
+ <window_info id="Terminal" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
193
+ <window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
194
+ <window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
195
+ <window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
196
+ <window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
197
+ <window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
198
+ <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
199
+ <window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
200
+ <window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
201
+ <window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
202
+ <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
203
+ </layout>
204
+ </component>
205
+ <component name="TypeScriptGeneratedFilesManager">
206
+ <option name="version" value="1" />
207
+ </component>
208
+ <component name="VcsContentAnnotationSettings">
209
+ <option name="myLimit" value="2678400000" />
210
+ </component>
211
+ <component name="XDebuggerManager">
212
+ <breakpoint-manager />
213
+ <watches-manager />
214
+ </component>
215
+ <component name="editorHistoryManager">
216
+ <entry file="file://$PROJECT_DIR$/pkg/.ruby-gemset">
217
+ <provider selected="true" editor-type-id="text-editor">
218
+ <state relative-caret-position="0">
219
+ <caret line="0" column="11" lean-forward="false" selection-start-line="0" selection-start-column="11" selection-end-line="0" selection-end-column="11" />
220
+ <folding />
221
+ </state>
222
+ </provider>
223
+ </entry>
224
+ <entry file="file://$PROJECT_DIR$/pkg/.ruby-version">
225
+ <provider selected="true" editor-type-id="text-editor">
226
+ <state relative-caret-position="0">
227
+ <caret line="0" column="0" lean-forward="false" selection-start-line="0" selection-start-column="0" selection-end-line="0" selection-end-column="0" />
228
+ <folding />
229
+ </state>
230
+ </provider>
231
+ </entry>
232
+ <entry file="file://$PROJECT_DIR$/README.md">
233
+ <provider selected="true" editor-type-id="split-provider[text-editor;markdown-preview-editor]">
234
+ <state split_layout="SPLIT">
235
+ <first_editor relative-caret-position="75">
236
+ <caret line="5" column="75" lean-forward="false" selection-start-line="5" selection-start-column="75" selection-end-line="5" selection-end-column="75" />
237
+ <folding />
238
+ </first_editor>
239
+ <second_editor />
240
+ </state>
241
+ </provider>
242
+ </entry>
243
+ <entry file="file://$PROJECT_DIR$/lib/ext_logger/logger.rb">
244
+ <provider selected="true" editor-type-id="text-editor">
245
+ <state relative-caret-position="503">
246
+ <caret line="102" column="32" lean-forward="false" selection-start-line="102" selection-start-column="32" selection-end-line="102" selection-end-column="32" />
247
+ <folding />
248
+ </state>
249
+ </provider>
250
+ </entry>
251
+ <entry file="file://$PROJECT_DIR$/ext_logger.gemspec">
252
+ <provider selected="true" editor-type-id="text-editor">
253
+ <state relative-caret-position="240">
254
+ <caret line="16" column="41" lean-forward="true" selection-start-line="16" selection-start-column="41" selection-end-line="16" selection-end-column="41" />
255
+ <folding />
256
+ </state>
257
+ </provider>
258
+ </entry>
259
+ <entry file="file://$PROJECT_DIR$/lib/ext_logger/version.rb">
260
+ <provider selected="true" editor-type-id="text-editor">
261
+ <state relative-caret-position="30">
262
+ <caret line="2" column="18" lean-forward="false" selection-start-line="2" selection-start-column="18" selection-end-line="2" selection-end-column="18" />
263
+ <folding />
264
+ </state>
265
+ </provider>
266
+ </entry>
267
+ </component>
268
+ </project>
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source "https://rubygems.org"
2
+
3
+ # Specify your gem's dependencies in ext_logger.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2018 Ruby
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
13
+ all 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
21
+ THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,76 @@
1
+ # ExtLogger
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/ext_logger`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ ```explain
6
+ Extended Logger class, log output to console in non-production environment.
7
+ ```
8
+
9
+ ## Installation
10
+
11
+ Add this line to your application's Gemfile:
12
+
13
+ ```ruby
14
+ gem 'ext_logger'
15
+ ```
16
+
17
+ And then execute:
18
+
19
+ $ bundle
20
+
21
+ Or install it yourself as:
22
+
23
+ $ gem install ext_logger
24
+
25
+ ## Usage
26
+
27
+ 1. Initialization object (It automatically creates non-existent directories based on paths):
28
+
29
+ ```ruby
30
+ logger = ExtLogger.new(log_path)
31
+ ```
32
+
33
+ 2. Output of normal log (Extended logger.info):
34
+
35
+ ```ruby
36
+ logger.info("abcdefg")
37
+ ```
38
+
39
+ 3. Output of debug log (Extended logger.info):
40
+
41
+ ```ruby
42
+ logger.debug("abcdefg")
43
+ ```
44
+
45
+ 4. Output of error log (Extended logger.error):
46
+
47
+ ```ruby
48
+ logger.error("abcdefg")
49
+ ```
50
+
51
+ 5. Output of warning log (Extended logger.warn):
52
+
53
+ ```ruby
54
+ logger.warn("abcdefg")
55
+ ```
56
+
57
+ 6. Output of memory usage (Extended logger.warn):
58
+
59
+ ```ruby
60
+ logger.record_memory
61
+ logger.record_memory('end')
62
+ ```
63
+
64
+ ## Development
65
+
66
+ After checking out the repo, run `bin/setup` to install dependencies. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
67
+
68
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
69
+
70
+ ## Contributing
71
+
72
+ Bug reports and pull requests are welcome on GitHub at https://github.com/mst_ruby/ext_logger.
73
+
74
+ ## License
75
+
76
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
data/Rakefile ADDED
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+ task :default => :spec
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "ext_logger"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start(__FILE__)
data/bin/setup ADDED
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,36 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path("../lib", __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require "ext_logger/version"
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "ext_logger"
8
+ spec.version = ExtLogger::VERSION
9
+ spec.authors = ["Ruby"]
10
+ spec.email = ["wu.chao@maisiteng.com"]
11
+
12
+ spec.summary = %q{Extended Logger class, log output to console in non-production environment.}
13
+ spec.description = %q{Extended Logger class, log output to console in non-production environment. Additional instance method ‘record_memory’ to record memory consumption}
14
+ spec.homepage = ""
15
+ spec.license = "MIT"
16
+
17
+ # Prevent pushing this gem to RubyGems.org. To allow pushes either set the 'allowed_push_host'
18
+ # to allow pushing to a single host or delete this section to allow pushing to any host.
19
+ # if spec.respond_to?(:metadata)
20
+ # spec.metadata["allowed_push_host"] = "TODO: Set to 'http://mygemserver.com'"
21
+ # else
22
+ # raise "RubyGems 2.0 or newer is required to protect against " \
23
+ # "public gem pushes."
24
+ # end
25
+
26
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
27
+ f.match(%r{^(test|spec|features)/})
28
+ end
29
+ spec.bindir = "exe"
30
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
31
+ spec.require_paths = ["lib"]
32
+
33
+ # spec.add_development_dependency "rails", "~> 5.0"
34
+ spec.add_development_dependency "bundler", "~> 1.15"
35
+ spec.add_development_dependency "rake", "~> 10.0"
36
+ end
@@ -0,0 +1,142 @@
1
+ require 'logger'
2
+ # require 'rails'
3
+
4
+ class ExtLogger < Logger
5
+ @output_flag = true # flag of output to console
6
+
7
+ # set output flag
8
+ def self.set_output(type=true)
9
+ @output_flag = type
10
+ end
11
+
12
+ # check output flag & env
13
+ def self.output?
14
+ if @output_flag
15
+ return ExtLogger.env != 'production'
16
+ end
17
+ return false
18
+ end
19
+
20
+ # validation the Rails object
21
+ def self.valid_rails
22
+ defined?(::Rails)
23
+ end
24
+
25
+ # get the path of folder or rails project
26
+ def self.root
27
+ self.valid_rails && ::Rails.root ? ::Rails.root.to_s : ::Dir.pwd
28
+ end
29
+
30
+ # get the env
31
+ def self.env
32
+ self.valid_rails && ::Rails.env ? ::Rails.env : 'development'
33
+ end
34
+
35
+ def self.initialize(*args)
36
+ if args.size > 0
37
+ if args[0].is_a?(String)
38
+ rails_flag = false
39
+ if args[0].include?(self.root)
40
+ path = args[0].gsub(self.root, '')
41
+ path = '/log/' + path if !path.include?('log/')
42
+ path = path.gsub('//', '/')
43
+ rails_flag = true
44
+ end
45
+
46
+ # 检查目录存在否
47
+ if !::Dir.exist?(path)
48
+ path_array = path.split('/').select{|item| !item.blank?}
49
+ path = self.root if rails_flag
50
+
51
+ path_array.each_with_index do |item, idx|
52
+ break if idx >= path_array.length - 1
53
+ path += '/' + item
54
+ ::Dir.mkdir(path) if !::Dir.exist?(path)
55
+ end
56
+ end
57
+ end
58
+ end
59
+ super
60
+ end
61
+
62
+ # output info
63
+ def info(*args)
64
+ if ExtLogger.output? && args.size > 0
65
+ puts "INFO: #{args[0]}" if args[0].is_a?(String)
66
+ end
67
+ super
68
+ end
69
+
70
+ # output debug
71
+ def debug(*args)
72
+ if ExtLogger.output? && args.size > 0
73
+ puts "DEBUG: #{args[0]}" if args[0].is_a?(String)
74
+ end
75
+ super
76
+ end
77
+
78
+ # output error
79
+ def error(*args)
80
+ if ExtLogger.output? && args.size > 0
81
+ puts "ERROR: #{args[0]}" if args[0].is_a?(String)
82
+ end
83
+ super
84
+ end
85
+
86
+ # output warning
87
+ def warn(*args)
88
+ if ExtLogger.output? && args.size > 0
89
+ puts "WARN: #{args[0]}" if args[0].is_a?(String)
90
+ end
91
+ super
92
+ end
93
+
94
+ # output the memory usage
95
+ # example: record_memory()
96
+ # example: record_memory('end')
97
+ def record_memory(type='start')
98
+ begin
99
+ type_list = %w(start end)
100
+ @record_memory_error ||= 0
101
+ error_message = 'RECORD MEMORY ERROR:'
102
+ message = ''
103
+ if !type_list.include?(type) # Judging whether the parameters are valid
104
+ self.info error_message + ' params error!' if @record_memory_error == 0
105
+ @record_memory_error = 1
106
+ return
107
+ end
108
+
109
+ # Get process memory
110
+ if File.exist?("/proc/#{Process.pid}/status")
111
+ process_status = File.open("/proc/#{Process.pid}/status")
112
+
113
+ 15.times { process_status.gets }
114
+
115
+ if type != type_list[1]
116
+ @rss_before_action = process_status.gets.split[1].to_f/1000
117
+ message = "START MEMORY: #{@rss_before_action}MB "
118
+ #@rss_before_action = 0
119
+ else
120
+ @rss_after_action = process_status.gets.split[1].to_f/1000
121
+ message = "END MEMORY: #{@rss_after_action}MB CONSUME MEMORY: #{@rss_after_action - @rss_before_action}MB "
122
+ #@rss_after_action = 0
123
+ end
124
+
125
+ process_status.close
126
+ else
127
+ error_message += " Non Linux system, file [/proc/#{Process.pid}/status] not exist!"
128
+ end
129
+
130
+ # Export internal consumption
131
+ self.info message if !message.nil? && message != ''
132
+ if !message.nil? && message != '' && @record_memory_error == 0
133
+ self.info error_message
134
+ @record_memory_error = 1
135
+ end
136
+ rescue Exception=>e
137
+ self.error e.backtrace.join("\n")
138
+ end
139
+ end
140
+
141
+ end
142
+
@@ -0,0 +1,4 @@
1
+ require 'logger'
2
+ class ExtLogger < Logger
3
+ VERSION = "0.1.2"
4
+ end
data/lib/ext_logger.rb ADDED
@@ -0,0 +1,6 @@
1
+ require "ext_logger/version"
2
+ require 'ext_logger/logger'
3
+
4
+ # module ExtLogger
5
+ # # Your code goes here...
6
+ # end
metadata ADDED
@@ -0,0 +1,91 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: ext_logger
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.2
5
+ platform: ruby
6
+ authors:
7
+ - Ruby
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2018-11-28 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.15'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.15'
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.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ description: Extended Logger class, log output to console in non-production environment.
42
+ Additional instance method ‘record_memory’ to record memory consumption
43
+ email:
44
+ - wu.chao@maisiteng.com
45
+ executables: []
46
+ extensions: []
47
+ extra_rdoc_files: []
48
+ files:
49
+ - ".gitignore"
50
+ - ".idea/.rakeTasks"
51
+ - ".idea/ext_logger.iml"
52
+ - ".idea/inspectionProfiles/Project_Default.xml"
53
+ - ".idea/misc.xml"
54
+ - ".idea/modules.xml"
55
+ - ".idea/vcs.xml"
56
+ - ".idea/workspace.xml"
57
+ - Gemfile
58
+ - LICENSE.txt
59
+ - README.md
60
+ - Rakefile
61
+ - bin/console
62
+ - bin/setup
63
+ - ext_logger.gemspec
64
+ - lib/ext_logger.rb
65
+ - lib/ext_logger/logger.rb
66
+ - lib/ext_logger/version.rb
67
+ homepage: ''
68
+ licenses:
69
+ - MIT
70
+ metadata: {}
71
+ post_install_message:
72
+ rdoc_options: []
73
+ require_paths:
74
+ - lib
75
+ required_ruby_version: !ruby/object:Gem::Requirement
76
+ requirements:
77
+ - - ">="
78
+ - !ruby/object:Gem::Version
79
+ version: '0'
80
+ required_rubygems_version: !ruby/object:Gem::Requirement
81
+ requirements:
82
+ - - ">="
83
+ - !ruby/object:Gem::Version
84
+ version: '0'
85
+ requirements: []
86
+ rubyforge_project:
87
+ rubygems_version: 2.6.12
88
+ signing_key:
89
+ specification_version: 4
90
+ summary: Extended Logger class, log output to console in non-production environment.
91
+ test_files: []