logoris 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 5c0a5ee228e43ad63eb4c346a40ddca9de1c64f8
4
+ data.tar.gz: 74a47516c17a20e3f649770b673f5a703194c8f0
5
+ SHA512:
6
+ metadata.gz: 3812249325fce444e80b3e8f4753907ca776f72728e64abdb3207b30d0099ea5306916cdeca31a43e612df0d926e4442f545b42a7f766b897e5880435c8ea3cc
7
+ data.tar.gz: 3d8008c9ad306714073ef05f34117bd32855bb29903387c691822e791da72a20149f005cdd256c68cd0be5002a35c325be25025ae9561d2544b400f2281c1421
@@ -0,0 +1,12 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+
11
+ # rspec failure tracking
12
+ .rspec_status
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
@@ -0,0 +1,5 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.4.0
5
+ before_install: gem install bundler -v 1.14.6
@@ -0,0 +1,74 @@
1
+ # Contributor Covenant Code of Conduct
2
+
3
+ ## Our Pledge
4
+
5
+ In the interest of fostering an open and welcoming environment, we as
6
+ contributors and maintainers pledge to making participation in our project and
7
+ our community a harassment-free experience for everyone, regardless of age, body
8
+ size, disability, ethnicity, gender identity and expression, level of experience,
9
+ nationality, personal appearance, race, religion, or sexual identity and
10
+ orientation.
11
+
12
+ ## Our Standards
13
+
14
+ Examples of behavior that contributes to creating a positive environment
15
+ include:
16
+
17
+ * Using welcoming and inclusive language
18
+ * Being respectful of differing viewpoints and experiences
19
+ * Gracefully accepting constructive criticism
20
+ * Focusing on what is best for the community
21
+ * Showing empathy towards other community members
22
+
23
+ Examples of unacceptable behavior by participants include:
24
+
25
+ * The use of sexualized language or imagery and unwelcome sexual attention or
26
+ advances
27
+ * Trolling, insulting/derogatory comments, and personal or political attacks
28
+ * Public or private harassment
29
+ * Publishing others' private information, such as a physical or electronic
30
+ address, without explicit permission
31
+ * Other conduct which could reasonably be considered inappropriate in a
32
+ professional setting
33
+
34
+ ## Our Responsibilities
35
+
36
+ Project maintainers are responsible for clarifying the standards of acceptable
37
+ behavior and are expected to take appropriate and fair corrective action in
38
+ response to any instances of unacceptable behavior.
39
+
40
+ Project maintainers have the right and responsibility to remove, edit, or
41
+ reject comments, commits, code, wiki edits, issues, and other contributions
42
+ that are not aligned to this Code of Conduct, or to ban temporarily or
43
+ permanently any contributor for other behaviors that they deem inappropriate,
44
+ threatening, offensive, or harmful.
45
+
46
+ ## Scope
47
+
48
+ This Code of Conduct applies both within project spaces and in public spaces
49
+ when an individual is representing the project or its community. Examples of
50
+ representing a project or community include using an official project e-mail
51
+ address, posting via an official social media account, or acting as an appointed
52
+ representative at an online or offline event. Representation of a project may be
53
+ further defined and clarified by project maintainers.
54
+
55
+ ## Enforcement
56
+
57
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
58
+ reported by contacting the project team at kgruber1@emich.edu. All
59
+ complaints will be reviewed and investigated and will result in a response that
60
+ is deemed necessary and appropriate to the circumstances. The project team is
61
+ obligated to maintain confidentiality with regard to the reporter of an incident.
62
+ Further details of specific enforcement policies may be posted separately.
63
+
64
+ Project maintainers who do not follow or enforce the Code of Conduct in good
65
+ faith may face temporary or permanent repercussions as determined by other
66
+ members of the project's leadership.
67
+
68
+ ## Attribution
69
+
70
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71
+ available at [http://contributor-covenant.org/version/1/4][version]
72
+
73
+ [homepage]: http://contributor-covenant.org
74
+ [version]: http://contributor-covenant.org/version/1/4/
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in logoris.gemspec
4
+ gemspec
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2017 Kent Gruber
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.
@@ -0,0 +1,63 @@
1
+ ![This guy is cool.](http://i.imgur.com/0PB84Kg.png)
2
+
3
+ # Logoris
4
+
5
+ Logoris a Ruby gem that provides a simple, unified interface to manage logging for command-line applications to the appropriate standard stream.
6
+
7
+ ### Why should I use this?
8
+
9
+ Do you hate having to manage your standard streams? Are your stderr events actually going to stdout, and you're like "whoa I didn't even know?" -- and you want a simple way to do this? You silly rabbit you: this is the gem for you.
10
+
11
+ #### STDOUT
12
+
13
+ Basically, when you do a `puts`, then you're going to STDOUT. This is where most of the good stuff happens.
14
+
15
+ #### STDERR
16
+
17
+ Whoa, you got some sort of gnarly error. Maybe some sort of diagnostics information that isn't really supposed to be parsed by normal input that happens for STDOUT? Well, we have STDERR for that stuff, silly.
18
+
19
+ ## Installation
20
+
21
+ $ gem install logoris
22
+
23
+ ## Usage
24
+
25
+ ```ruby
26
+ require 'logoris'
27
+
28
+ # create a new logoris instance, ya' know
29
+ logger = Logoris.new(log_file: "/var/log/some_application.log")
30
+
31
+ logger.error "This will go to STDERR" # for your errors
32
+ logger.out "This will go to STDOUT" # for your normal stuff
33
+
34
+ # why not check if the log exists?
35
+ logger.log_exists?(logger.log_file)
36
+ # => true
37
+ # there's almost no reason for this method
38
+ # but, there's a method to my madness
39
+ # :)
40
+ ```
41
+
42
+ Maybe you want to log your errors and regular output in their own special files?
43
+
44
+ ```ruby
45
+ # assuming you've already created a new logoris instance, ya' know
46
+
47
+ # log them errors
48
+ logger.error_file = "error.log"
49
+ logger.error "This will go a to file (error.log), and to stderr"
50
+
51
+ # log them... not errors?
52
+ logger.out_file = "not_errors.log"
53
+ logger.out "This will go a to file (not_errors.log), and to stdout"
54
+
55
+ # Totes proving it works via this static example.
56
+ File.readlines(logger.error_file)
57
+ # => ["This will go a to file (error.log), and to stderr\n"]
58
+ ```
59
+
60
+ ## License
61
+
62
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
63
+
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "logoris"
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__)
@@ -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,34 @@
1
+ # Path setting slight of hand you can ignore if not running it for debugging, basically
2
+ $LOAD_PATH.unshift File.expand_path('../../lib', __FILE__)
3
+
4
+ # requre the gem
5
+ require 'logoris'
6
+
7
+ # New Logoris instance.
8
+ logger = Logoris.new
9
+
10
+ # Use STDOUT, per usual.
11
+ logger.out "Normal stuff."
12
+
13
+ # Use STDERR, usually for, like, diagnostics for errors
14
+ # and stuff like that.
15
+ logger.error "Error stuff."
16
+
17
+
18
+ # If you were to run this example, you could check the streams
19
+ # are beining handled properly by redirecting the output yourself!
20
+ #
21
+ # ```shell
22
+ # ruby example.rb 2> error.txt
23
+ # ```
24
+ #
25
+ # ```shell
26
+ # ruby example.rb > out.txt
27
+ # ```
28
+ #
29
+ # Redirect both to a file? Easy!
30
+ # ```shell
31
+ # ruby example.rb &> log_em_both.txt
32
+ # ```
33
+ #
34
+ # Do whatever you need to do fam'.
@@ -0,0 +1,81 @@
1
+ class Logoris
2
+
3
+ VERSION = "1.0.0"
4
+
5
+ # The optional out_file to log stdout events.
6
+ # @return [String]
7
+ attr_accessor :out_file
8
+
9
+ # The optional error_file to log stderr events.
10
+ # @return [String]
11
+ attr_accessor :error_file
12
+
13
+ # The optional error_file to log both stdout and stderr events.
14
+ # @return [String]
15
+ attr_accessor :log_file
16
+
17
+ # @param [Hash] args Logoris options
18
+ # @option options [Boolean] :out_file the file to log stdout events
19
+ # @option options [Boolean] :error_file the file to log stderr events
20
+ # @return [void]
21
+ def initialize(args={})
22
+ @out_file = false # Do not log stdout events to a file by default.
23
+ @error_file = false # Do not log stderr events to a file by default.
24
+ @log_file = false # Do not log both stdout and stderr events to a file by default.
25
+ out_file = args[:out_file] if args[:out_file] # Set file for stdout, if given.
26
+ error_file = args[:error_file] if args[:error_file] # Set file for stderr, if given.
27
+ log_file = args[:log_file] if args[:log_file] # Set file for stdout and stderr, if given.
28
+ end
29
+
30
+ # @param [String] message
31
+ # @return [void]
32
+ def out(message)
33
+ STDOUT.puts message
34
+ to_log(@out_file, message) if @out_file
35
+ to_log(@log_file, message) if @log_file
36
+ end
37
+
38
+ # @param [String] message
39
+ # @return [void]
40
+ def error(message)
41
+ STDERR.puts message
42
+ to_log(@error_file, message) if @error_file
43
+ to_log(@log_file, message) if @log_file
44
+ end
45
+
46
+ # @param [String] file
47
+ # @return [void]
48
+ def error_file=(file)
49
+ FileUtils.touch(file) unless log_exists?(file)
50
+ @error_file = file
51
+ end
52
+
53
+ # @param [String] file
54
+ # @return [void]
55
+ def out_file=(file)
56
+ FileUtils.touch(file) unless log_exists?(file)
57
+ @out_file = file
58
+ end
59
+
60
+ # @param [String] file
61
+ # @return [void]
62
+ def log_file=(file)
63
+ FileUtils.touch(file) unless log_exists?(file)
64
+ @log_file = file
65
+ end
66
+
67
+ # @param [String] file
68
+ # @param [String] message
69
+ # @return [void]
70
+ def to_log(file, message)
71
+ File.open(file, 'a') { |f| f.puts message }
72
+ to_log(@log_file, message) if @log_file
73
+ end
74
+
75
+ # @param [String] file
76
+ # @return [Boolean]
77
+ def log_exists?(file)
78
+ File.exists?(file)
79
+ end
80
+
81
+ end
@@ -0,0 +1,27 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'logoris'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "logoris"
8
+ spec.version = Logoris::VERSION
9
+ spec.authors = ["Kent 'picat' Gruber"]
10
+ spec.email = ["kgruber1@emich.edu"]
11
+
12
+ spec.summary = %q{A simple, unified interface to manage logging for command-line applications to the appropriate standard stream.}
13
+ spec.description = %q{Logoris a Ruby gem that provides a simple, unified interface to manage logging for command-line applications to the appropriate standard stream. Do you hate having to manage your standard streams? Are your stderr events actually going to stdout, and you're like "whoa I didn't even know?" -- and you want a simple way to do this? You silly rabbit you: this is the gem for you.}
14
+ spec.homepage = "https://github.com/picatz/logoris"
15
+ spec.license = "MIT"
16
+
17
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
18
+ f.match(%r{^(test|spec|features)/})
19
+ end
20
+ spec.bindir = "exe"
21
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
22
+ spec.require_paths = ["lib"]
23
+
24
+ spec.add_development_dependency "bundler", "~> 1.14"
25
+ spec.add_development_dependency "rake", "~> 10.0"
26
+ spec.add_development_dependency "rspec", "~> 3.0"
27
+ end
metadata ADDED
@@ -0,0 +1,104 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: logoris
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Kent 'picat' Gruber
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2017-03-19 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.14'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.14'
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
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '3.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '3.0'
55
+ description: 'Logoris a Ruby gem that provides a simple, unified interface to manage
56
+ logging for command-line applications to the appropriate standard stream. Do you
57
+ hate having to manage your standard streams? Are your stderr events actually going
58
+ to stdout, and you''re like "whoa I didn''t even know?" -- and you want a simple
59
+ way to do this? You silly rabbit you: this is the gem for you.'
60
+ email:
61
+ - kgruber1@emich.edu
62
+ executables: []
63
+ extensions: []
64
+ extra_rdoc_files: []
65
+ files:
66
+ - ".gitignore"
67
+ - ".rspec"
68
+ - ".travis.yml"
69
+ - CODE_OF_CONDUCT.md
70
+ - Gemfile
71
+ - LICENSE.txt
72
+ - README.md
73
+ - Rakefile
74
+ - bin/console
75
+ - bin/setup
76
+ - examples/example.rb
77
+ - lib/logoris.rb
78
+ - logoris.gemspec
79
+ homepage: https://github.com/picatz/logoris
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.6.8
100
+ signing_key:
101
+ specification_version: 4
102
+ summary: A simple, unified interface to manage logging for command-line applications
103
+ to the appropriate standard stream.
104
+ test_files: []