mirror of
https://github.com/seejohnrun/haste-client.git
synced 2025-12-17 09:11:29 +00:00
Compare commits
13 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
42bad59634 | ||
|
|
e156c031a8 | ||
|
|
ca0c9b239f | ||
|
|
5d88f11605 | ||
|
|
859de525b1 | ||
|
|
75ddd39187 | ||
|
|
b24842ac6f | ||
|
|
636eec2924 | ||
|
|
cf4c274d67 | ||
|
|
f2c6260bd0 | ||
|
|
457520d107 | ||
|
|
9e7b8e86ae | ||
|
|
ca02796551 |
14
README.md
14
README.md
@@ -13,6 +13,16 @@ This can be really really cool in combination with `pbcopy`, like:
|
|||||||
|
|
||||||
after which the contents of `file` will be accessible at a URL which has been copied to your pasteboard.
|
after which the contents of `file` will be accessible at a URL which has been copied to your pasteboard.
|
||||||
|
|
||||||
|
## Making uploading file contents easier
|
||||||
|
|
||||||
|
If you supply a valid file path as argument #1 to the client, it will be uploaded:
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
# equivelant
|
||||||
|
cat file | haste
|
||||||
|
haste file
|
||||||
|
```
|
||||||
|
|
||||||
## Changing the location of your haste server
|
## Changing the location of your haste server
|
||||||
|
|
||||||
By default, haste will point at `http://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
|
By default, haste will point at `http://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
|
||||||
@@ -23,6 +33,10 @@ alias work_haste="HASTE_SERVER=http://something.com haste"
|
|||||||
|
|
||||||
After which you can use `work_haste` to send hastes to that server instead.
|
After which you can use `work_haste` to send hastes to that server instead.
|
||||||
|
|
||||||
|
## Windows Support
|
||||||
|
|
||||||
|
If you'd like an alternative on Windows that supports functionality similar to `pbcopy`, check out Aidan Ryan's [WinHaste](https://github.com/ajryan/WinHaste) project.
|
||||||
|
|
||||||
## Author
|
## Author
|
||||||
|
|
||||||
John Crepezzi <john.crepezzi@gmail.com>
|
John Crepezzi <john.crepezzi@gmail.com>
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
#!/usr/bin/env ruby
|
#!/usr/bin/env ruby
|
||||||
|
|
||||||
require File.dirname(__FILE__) + '/../lib/haste'
|
require 'pathname'
|
||||||
|
path = Pathname.new(__FILE__)
|
||||||
|
require File.expand_path(File.dirname(path.realpath) + '/../lib/haste')
|
||||||
|
|
||||||
cli = Haste::CLI.new
|
cli = Haste::CLI.new
|
||||||
cli.start
|
cli.start
|
||||||
|
|||||||
23
lib/haste.rb
23
lib/haste.rb
@@ -8,11 +8,16 @@ module Haste
|
|||||||
|
|
||||||
class CLI
|
class CLI
|
||||||
|
|
||||||
attr_reader :input
|
|
||||||
|
|
||||||
# Pull all of the data from STDIN
|
# Pull all of the data from STDIN
|
||||||
def initialize
|
def initialize
|
||||||
@input = STDIN.readlines.join
|
if STDIN.tty?
|
||||||
|
abort 'No input file given' unless ARGV.length == 1
|
||||||
|
abort "#{file}: No such path" unless File.exists?(file = ARGV[0])
|
||||||
|
@input = open(file).read
|
||||||
|
else
|
||||||
|
@input = STDIN.readlines.join
|
||||||
|
end
|
||||||
|
# clean up
|
||||||
@input.strip!
|
@input.strip!
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -20,25 +25,25 @@ module Haste
|
|||||||
def start
|
def start
|
||||||
uri = URI.parse server
|
uri = URI.parse server
|
||||||
http = Net::HTTP.new uri.host, uri.port
|
http = Net::HTTP.new uri.host, uri.port
|
||||||
response = http.post '/documents', input
|
response = http.post '/documents', @input
|
||||||
if response.is_a?(Net::HTTPOK)
|
if response.is_a?(Net::HTTPOK)
|
||||||
data = JSON.parse(response.body)
|
data = JSON.parse(response.body)
|
||||||
method = STDOUT.tty? ? :puts : :print
|
method = STDOUT.tty? ? :puts : :print
|
||||||
STDOUT.send method, "#{server}/#{data['key']}"
|
STDOUT.send method, "#{server}/#{data['key']}"
|
||||||
else
|
else
|
||||||
STDERR.puts "failure uploading: #{response.code}"
|
abort "failure uploading: #{response.code}"
|
||||||
end
|
end
|
||||||
rescue RuntimeError, JSON::ParserError => e
|
rescue JSON::ParserError => e
|
||||||
STDERR.puts "failure uploading: #{response.code}"
|
abort "failure uploading: #{response.code}"
|
||||||
rescue Errno::ECONNREFUSED => e
|
rescue Errno::ECONNREFUSED => e
|
||||||
STDERR.puts "failure connecting: #{e.message}"
|
abort "failure connecting: #{e.message}"
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def server
|
def server
|
||||||
return @server if @server
|
return @server if @server
|
||||||
@server = ENV['HASTE_SERVER'] || Haste::DEFAULT_URL
|
@server = (ENV['HASTE_SERVER'] || Haste::DEFAULT_URL).dup
|
||||||
@server.chop! if server.end_with?('/')
|
@server.chop! if server.end_with?('/')
|
||||||
@server
|
@server
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
module Haste
|
module Haste
|
||||||
|
|
||||||
VERSION = '0.0.5'
|
VERSION = '0.1.3'
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user