Draw the rest of the fucking owl

master
knotteye 2020-12-23 10:18:47 -06:00
parent e9a6a6bf2e
commit 1faa875989
8 changed files with 70 additions and 19 deletions

3
.gitignore vendored
View File

@ -1 +1,4 @@
blogtool blogtool
lib
shard.lock
testsite/dist

View File

@ -12,11 +12,19 @@ clean:
run: run:
crystal run src/blogtool.cr crystal run src/blogtool.cr
release: release: dependencies
crystal build --release --no-debug src/blogtool.cr crystal build --release --no-debug src/blogtool.cr
test: dependencies:
cd testsite && crystal run ../src/blogtool.cr shards install
debug:
crystal build src/blogtool.cr
test: debug
cd testsite && ../blogtool
install: install:
install swayfocus $(PREFIX)/bin/ install blogtool $(PREFIX)/bin/
mkdir -p /etc/blogtool
install testsite/base.html /etc/blogtool/

View File

@ -1,6 +1,6 @@
## BLOGTOOL is a stupid simple static site generator ## BLOGTOOL is a non-bloated static site generator.
There are no themes or templates. You write a project structure like this: There are no themes. You write a project structure like this:
``` ```
myblog myblog
| |
@ -10,11 +10,10 @@ myblog
|-> assets |-> assets
| |-> article1.jpg | |-> article1.jpg
| |-> photo.png | |-> photo.png
|-> profile.jpg
|-> about.md |-> about.md
|-> styles.css |-> styles.css
``` ```
with utf-8 encoded articles. Blogtool generates a static site in dist/ with a list of articles for the home page, an about page with a profile picture and bio from profile.jpg and about.md, each page will include styless.css and all assets will be available at /static. with utf-8 encoded articles. Blogtool generates a static site in dist/ with a list of articles for the home page, an about page from about.md, each page will include styless.css and all assets will be available at /static. Dashes (-) will be replaced with spaces in the index.
``` ```
dist dist
| |
@ -22,11 +21,10 @@ dist
|-> static |-> static
| |-> article1.jpg | |-> article1.jpg
| |-> photo.png | |-> photo.png
| |-> profile.jpg
| |-> styles.css | |-> styles.css
|-> article1.html |-> article1.html
|-> article2.html |-> article2.html
|-> about.html |-> about.html
``` ```
Invoke blogtool with `blogtool` after installing dependencies and adding the bin to your path. Run it in your project's root. There are no options. It will not remove old files from dist/. You can build blogtool by running `make && sudo make install`. Invoke blogtool by running `blogtool` in the project directory. There are no options. You can copy /etc/blogtool/base.html to the project root and make changes to overwrite the template.

BIN
blogtool

Binary file not shown.

View File

@ -1,13 +1,56 @@
require "markd" require "markd"
require "dir" require "dir"
require "file"
require "path"
begin begin
Dir.mkdir "dist" Dir.mkdir_p Path["dist/static"]
rescue rescue
if !Dir.exists? Path["dist/static"]
puts "Could not create required folders. Exiting."
exit 1
end
end end
articles = Dir.entries "articles" Base = begin
articles = articles.select { |i| i != "." && i != ".." } if File.file? "base.html"
puts articles File.read "base.html"
elsif File.file? Path[ENV["HOME"]+"/.config/blogtool/base.html"]
File.read Path[ENV["HOME"]+"/.config/blogtool/base.html"]
elsif File.file? Path["/etc/blogtool/base.html"]
File.read Path["/etc/blogtool/base.html"]
else
puts "Can't find base.html"
exit 1
end
end
#print Markd.to_html(text, Markd::Options.new(smart: true, safe: false));
BaseCSS = begin
if File.file? Path[ENV["HOME"]+"/.config/blogtool/styles.css"]
File.read Path[ENV["HOME"]+"/.config/blogtool/styles.css"]
elsif File.file? Path["/etc/blogtool/styles.css"]
File.read Path["/etc/blogtool/styles.css"]
else
""
end
end
def render_file(filename : String | Path)
Base+Markd.to_html(File.read(filename), Markd::Options.new(smart: true, safe: false))+"</body></html>"
end
Dir.entries("articles").select{ |i| i != "." && i != ".." }.each do |article|
if article[article.size-3, article.size] == ".md"
File.write Path.new("dist", article[0,article.size-3]+".html"), render_file("articles/"+article)
else
File.write Path.new("dist", article+".html"), render_file("articles/"+article)
end
end
Dir.entries("assets").select{ |i| i != "." && i != ".." }.each do |asset|
File.copy Path.new("assets", asset), Path.new("dist", "static", asset)
end
File.write Path.new("dist", "static", "styles.css"), BaseCSS+File.read("styles.css")
File.write Path.new("dist", "about.html"), render_file("about.md")

View File

Before

Width:  |  Height:  |  Size: 55 KiB

After

Width:  |  Height:  |  Size: 55 KiB

View File

@ -2,8 +2,7 @@
<head> <head>
</head> </head>
<body> <body>
<h2 id="yeet">yeet</h2> <h2>yeet</h2>
<p><strong>this is</strong> a <em>test</em></p> <p><strong>this is</strong> a <em>test</em></p>
<p><a href="http://google.com">weeeooo</a></p> <p><a href="http://google.com">weeeooo</a></p>
</body> </body></html>
</html>