kdwatch 0.3.0 → 0.5.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.
- checksums.yaml +4 -4
- data/README.md +13 -9
- data/bin/kdwatch +34 -2
- data/lib/kdwatch/version.rb +1 -1
- data/lib/kdwatch-app.rb +13 -2
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2e2ba541b81a0758e14930c2daeeb13f8795ef86f13db41d2099ba2c863ae6a8
|
4
|
+
data.tar.gz: 225edec007a3005fb9e401888073d3e74fd6d92db622560685d812d0a37527ea
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 7f61fd99900cb3e4b1951863424816438e7e426b84c3cc0e4854f4a64954f26e2ec56f13b08394d4c086fe2d9b919cd4fa66ed4486ef10daebace7d30767c0b1
|
7
|
+
data.tar.gz: 4c0853a737166b50b728d6ecbd29845c908fa5e1fcc4b07ea88bbd762c3b6f71b281a7429acbc07f452e3a1a6e9e18f29d7198b97e6d96edef98bbdaef8aa6ad
|
data/README.md
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# Kdwatch
|
2
2
|
|
3
|
-
|
3
|
+
Auto-formatting, auto-reloading display of formatted [kramdown-rfc][] document in browser
|
4
4
|
|
5
5
|
[kramdown-rfc]: http://rfc.space
|
6
6
|
|
@@ -14,11 +14,11 @@ $ gem install kdwatch
|
|
14
14
|
|
15
15
|
* For some reason, the initial `gem install` takes a couple of minutes,
|
16
16
|
during the first few of which it may seem nothing happens.
|
17
|
-
* If the above `pip3` doesn't work, no problem: in a pinch,
|
18
|
-
use the IETF web service for xml2rfc processing (but that
|
19
|
-
bit slower).
|
20
|
-
* Depending on system configuration, add `sudo`
|
21
|
-
actually needed).
|
17
|
+
* If the above `pip3` (or `pip`) doesn't work, no problem: in a pinch,
|
18
|
+
kdrfc will use the IETF web service for xml2rfc processing (but that
|
19
|
+
may be a bit slower).
|
20
|
+
* Depending on system configuration, add `sudo` on the pip/gem
|
21
|
+
commands (but don't if it isn't actually needed).
|
22
22
|
|
23
23
|
## Usage
|
24
24
|
|
@@ -34,12 +34,16 @@ $ kdwatch
|
|
34
34
|
pop up with the URL to use, which depends on the options given, but
|
35
35
|
defaults to <http://127.0.0.1:7991/>).
|
36
36
|
|
37
|
-
Now, whenever you do an editor save of the markdown file,
|
38
|
-
|
39
|
-
|
37
|
+
Now, whenever you do an editor save of the kramdown-rfc markdown file,
|
38
|
+
kdwatch auto-formats and, after a couple of seconds(*), you see an
|
39
|
+
updated HTML in the browser without pressing buttons or switching windows.
|
40
40
|
|
41
41
|
You will need to keep the `kdwatch` terminal/screen open to see
|
42
42
|
potential error messages, e.g., if you break the markdown in some way.
|
43
|
+
(The author uses an Emacs "Async Shell Command" buffer for that.)
|
44
|
+
|
45
|
+
(*) The latency depends on your computer and a bit on the size of the
|
46
|
+
file, say, around 1.6 s for my Intel Mac, 0.8 s for my M1 Mac.
|
43
47
|
|
44
48
|
### There can only be one (per host/port)
|
45
49
|
|
data/bin/kdwatch
CHANGED
@@ -6,11 +6,24 @@ ENV["KRAMDOWN_PERSISTENT"]="yes"
|
|
6
6
|
|
7
7
|
require 'optparse'
|
8
8
|
require 'ostruct'
|
9
|
+
require 'socket'
|
9
10
|
|
10
11
|
require_relative "../lib/kdwatch/version"
|
11
12
|
|
12
13
|
KDWATCH_PORT = 7991 # currently unregistered...
|
13
14
|
|
15
|
+
def socket_is_free(host, port, uri)
|
16
|
+
begin
|
17
|
+
TCPSocket.new(host, port, connect_timeout: 1)
|
18
|
+
rescue Errno::ECONNREFUSED => e
|
19
|
+
return true
|
20
|
+
rescue => e
|
21
|
+
warn "*** #{uri} -- #{e.inspect}"
|
22
|
+
return nil # break, but don't use
|
23
|
+
end
|
24
|
+
return false
|
25
|
+
end
|
26
|
+
|
14
27
|
options = OpenStruct.new
|
15
28
|
|
16
29
|
op = OptionParser.new do |opts|
|
@@ -30,7 +43,7 @@ BANNER
|
|
30
43
|
opts.on("-r", "--[no-]replace", "Replace existing server")
|
31
44
|
opts.on("-oNAME", "--host=NAME", String, "Server host (127.0.0.1)")
|
32
45
|
opts.on("-i", "--internet", 'Abbr. "on the Internet" (host = "::")')
|
33
|
-
opts.on("-pNUM", "--port=NUM", Integer, "Port number (#{KDWATCH_PORT})")
|
46
|
+
opts.on("-pNUM", "--port=NUM", Integer, "Port number (#{KDWATCH_PORT}...)")
|
34
47
|
opts.on("-[1-6]", "--[1-6]", Integer, "Abbr. port number (#{KDWATCH_PORT/10}x), must be last")
|
35
48
|
end
|
36
49
|
begin
|
@@ -52,7 +65,26 @@ if short_port = options[""]
|
|
52
65
|
warn "** overriding port #{options.port} with #{port}" if options.port
|
53
66
|
options.port = port
|
54
67
|
else
|
55
|
-
options.port
|
68
|
+
unless options.port
|
69
|
+
port = KDWATCH_PORT
|
70
|
+
host = options.host
|
71
|
+
host = "[#{host}]" if host =~ /:/
|
72
|
+
uri = nil
|
73
|
+
found = false
|
74
|
+
100.times do
|
75
|
+
uri = "http://#{host}:#{port}"
|
76
|
+
# warn "Trying URI #{uri}"
|
77
|
+
found = socket_is_free(options.host, port, uri)
|
78
|
+
break unless found == false
|
79
|
+
port += 1
|
80
|
+
end
|
81
|
+
unless found
|
82
|
+
warn "*** Cannot find port number available to serve from!"
|
83
|
+
exit 1
|
84
|
+
end
|
85
|
+
warn "*** Using URI: #{uri}"
|
86
|
+
options.port = port
|
87
|
+
end
|
56
88
|
end
|
57
89
|
|
58
90
|
# p options
|
data/lib/kdwatch/version.rb
CHANGED
data/lib/kdwatch-app.rb
CHANGED
@@ -9,7 +9,7 @@ require "rack-livereload"
|
|
9
9
|
require "guard"
|
10
10
|
require "sinatra"
|
11
11
|
require "kramdown-rfc2629"
|
12
|
-
ENV["KDRFC_PREPEND"] = "time"
|
12
|
+
ENV["KDRFC_PREPEND"] = "time" if system("time", "true", err: "/dev/null")
|
13
13
|
require "kramdown-rfc/kdrfc-processor"
|
14
14
|
require "net/http/persistent"
|
15
15
|
|
@@ -40,7 +40,18 @@ get "/" do
|
|
40
40
|
warn "...done"
|
41
41
|
end
|
42
42
|
end
|
43
|
-
File.
|
43
|
+
dfc = File.stat(dfn).ctime rescue Time.at(0)
|
44
|
+
ret = File.read(dfn)
|
45
|
+
if sfc > dfc # somehow the above went wrong
|
46
|
+
ret.gsub!(<<CSS, <<RED)
|
47
|
+
/* general and mobile first */
|
48
|
+
html {
|
49
|
+
CSS
|
50
|
+
/* general and mobile first */
|
51
|
+
html { border: 5px solid red;
|
52
|
+
RED
|
53
|
+
end
|
54
|
+
ret
|
44
55
|
end
|
45
56
|
|
46
57
|
get "/metadata.min.js" do
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: kdwatch
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.5.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Carsten Bormann
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-05-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -157,7 +157,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
157
157
|
- !ruby/object:Gem::Version
|
158
158
|
version: '0'
|
159
159
|
requirements: []
|
160
|
-
rubygems_version: 3.
|
160
|
+
rubygems_version: 3.3.11
|
161
161
|
signing_key:
|
162
162
|
specification_version: 4
|
163
163
|
summary: 'kdwatch: open auto-reloaded HTML for kramdown-rfc in a browser.'
|