Compare commits
8 Commits
dev/global
...
develop
Author | SHA1 | Date | |
---|---|---|---|
|
2f3c52f5f2 | ||
|
d630fb0f70 | ||
|
ce35091852 | ||
|
d9b85c8475 | ||
|
9a020285ad | ||
|
e639df35a7 | ||
|
89e50a6310 | ||
|
28122c3c31 |
@ -46,13 +46,14 @@ IMG_EXTENSIONS = set([
|
|||||||
"gif",
|
"gif",
|
||||||
])
|
])
|
||||||
SKIPPED_TAGS = set(['attach'])
|
SKIPPED_TAGS = set(['attach'])
|
||||||
|
DEFAULT_SUBPATH = "public"
|
||||||
|
|
||||||
WATCH = True
|
WATCH = True
|
||||||
if os.getenv('WATCH_AND_REBUILD', '1') == '0':
|
if os.getenv('WATCH_AND_REBUILD', '1') == '0':
|
||||||
WATCH = False
|
WATCH = False
|
||||||
|
|
||||||
MIN_HIDDEN_HEADLINE_LEVEL = 2
|
MIN_HIDDEN_HEADLINE_LEVEL = 2
|
||||||
INDEX_ID = "ea48ec1d-f9d4-4fb7-b39a-faa7b6e2ba95"
|
INDEX_ID = os.getenv("INDEX_ID", "ea48ec1d-f9d4-4fb7-b39a-faa7b6e2ba95")
|
||||||
SITE_NAME = "Código para llevar"
|
SITE_NAME = "Código para llevar"
|
||||||
|
|
||||||
MONITORED_EVENT_TYPES = (
|
MONITORED_EVENT_TYPES = (
|
||||||
@ -120,7 +121,7 @@ def load_all(top_dir_relative):
|
|||||||
logging.info("Collected {} files".format(len(docs)))
|
logging.info("Collected {} files".format(len(docs)))
|
||||||
return docs
|
return docs
|
||||||
|
|
||||||
def regen_all(src_top, dest_top, *, docs=None, db=None):
|
def regen_all(src_top, dest_top, subpath, *, docs=None, db=None):
|
||||||
files_generated = 0
|
files_generated = 0
|
||||||
cur = db.cursor()
|
cur = db.cursor()
|
||||||
cleaned_db = False
|
cleaned_db = False
|
||||||
@ -150,7 +151,7 @@ def regen_all(src_top, dest_top, *, docs=None, db=None):
|
|||||||
changed = False
|
changed = False
|
||||||
headlines = list(doc.getAllHeadlines())
|
headlines = list(doc.getAllHeadlines())
|
||||||
related = None
|
related = None
|
||||||
if not relpath.startswith("public/"):
|
if not relpath.startswith(subpath + "/"):
|
||||||
# print("Skip:", relpath)
|
# print("Skip:", relpath)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
@ -349,7 +350,7 @@ def regen_all(src_top, dest_top, *, docs=None, db=None):
|
|||||||
dirs_exist_ok=True)
|
dirs_exist_ok=True)
|
||||||
|
|
||||||
|
|
||||||
def main(src_top, dest_top):
|
def main(src_top, dest_top, subpath):
|
||||||
notifier = inotify.adapters.InotifyTrees([src_top, STATIC_PATH])
|
notifier = inotify.adapters.InotifyTrees([src_top, STATIC_PATH])
|
||||||
|
|
||||||
## Initial load
|
## Initial load
|
||||||
@ -357,7 +358,7 @@ def main(src_top, dest_top):
|
|||||||
|
|
||||||
os.makedirs(dest_top, exist_ok=True)
|
os.makedirs(dest_top, exist_ok=True)
|
||||||
db = create_db(os.path.join(dest_top, 'db.sqlite3'))
|
db = create_db(os.path.join(dest_top, 'db.sqlite3'))
|
||||||
docs = regen_all(src_top, dest_top, db=db)
|
docs = regen_all(src_top, dest_top, subpath=subpath, db=db)
|
||||||
|
|
||||||
if not WATCH:
|
if not WATCH:
|
||||||
logging.info("Build completed in {:.2f}s".format(time.time() - t0))
|
logging.info("Build completed in {:.2f}s".format(time.time() - t0))
|
||||||
@ -375,7 +376,7 @@ def main(src_top, dest_top):
|
|||||||
print("CHANGED: {}".format(filepath))
|
print("CHANGED: {}".format(filepath))
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
try:
|
try:
|
||||||
docs = regen_all(src_top, dest_top, docs=docs, db=db)
|
docs = regen_all(src_top, dest_top, subpath=subpath, docs=docs, db=db)
|
||||||
except:
|
except:
|
||||||
logging.error(traceback.format_exc())
|
logging.error(traceback.format_exc())
|
||||||
logging.error("Loading new templates failed 😿")
|
logging.error("Loading new templates failed 😿")
|
||||||
@ -825,9 +826,13 @@ def save_changes(doc):
|
|||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
if len(sys.argv) != 3:
|
if len(sys.argv) not in (3, 4):
|
||||||
print("Usage: {} SOURCE_TOP DEST_TOP".format(sys.argv[0]))
|
print("Usage: {} SOURCE_TOP DEST_TOP <SUBPATH>".format(sys.argv[0]))
|
||||||
exit(0)
|
exit(0)
|
||||||
|
|
||||||
logging.basicConfig(level=logging.INFO, format="%(levelname)-8s %(message)s")
|
logging.basicConfig(level=logging.INFO, format="%(levelname)-8s %(message)s")
|
||||||
exit(main(sys.argv[1], sys.argv[2]))
|
subpath = DEFAULT_SUBPATH
|
||||||
|
|
||||||
|
if len(sys.argv) == 4:
|
||||||
|
subpath = sys.argv[3]
|
||||||
|
exit(main(sys.argv[1], sys.argv[2], subpath=subpath))
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
/* Dark mode. */
|
||||||
|
@media (prefers-color-scheme: dark) {
|
||||||
pre { line-height: 125%; }
|
pre { line-height: 125%; }
|
||||||
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
||||||
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
||||||
@ -80,3 +82,4 @@ span.linenos.special { color: #000000; background-color: #ffffc0; padding-left:
|
|||||||
.vi { color: #f8f8f2 } /* Name.Variable.Instance */
|
.vi { color: #f8f8f2 } /* Name.Variable.Instance */
|
||||||
.vm { color: #f8f8f2 } /* Name.Variable.Magic */
|
.vm { color: #f8f8f2 } /* Name.Variable.Magic */
|
||||||
.il { color: #ae81ff } /* Literal.Number.Integer.Long */
|
.il { color: #ae81ff } /* Literal.Number.Integer.Long */
|
||||||
|
}
|
||||||
|
@ -6,11 +6,13 @@
|
|||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<style>
|
<style>
|
||||||
body {
|
body {
|
||||||
|
background-color: white;
|
||||||
font-family: sans-serif;
|
font-family: sans-serif;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
width: fit-content;
|
width: fit-content;
|
||||||
max-width: 100ex;
|
max-width: 100ex;
|
||||||
padding: 0 1ex;
|
padding: 0 1ex;
|
||||||
|
color: black;
|
||||||
}
|
}
|
||||||
.header h1 {
|
.header h1 {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
@ -45,7 +47,7 @@
|
|||||||
border-right: 1px solid #000;
|
border-right: 1px solid #000;
|
||||||
}
|
}
|
||||||
@media (prefers-color-scheme: dark) {
|
@media (prefers-color-scheme: dark) {
|
||||||
html {
|
body {
|
||||||
background-color: #1d1f21;
|
background-color: #1d1f21;
|
||||||
color: #fafafe;
|
color: #fafafe;
|
||||||
}
|
}
|
||||||
@ -72,6 +74,12 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="links">
|
<div class="links">
|
||||||
|
<a href="/notes">
|
||||||
|
<section>
|
||||||
|
<h2>Notes</h2>
|
||||||
|
<p>Some publicly-visible notes from a sort of knowledge graph that I use as information dump.</p>
|
||||||
|
</section>
|
||||||
|
</a>
|
||||||
<section>
|
<section>
|
||||||
<h2><a href="/blog">Blog</a></h2>
|
<h2><a href="/blog">Blog</a></h2>
|
||||||
<p>
|
<p>
|
||||||
@ -100,12 +108,24 @@
|
|||||||
</ul>
|
</ul>
|
||||||
</p>
|
</p>
|
||||||
</section>
|
</section>
|
||||||
<a href="/notes">
|
|
||||||
<section>
|
<section>
|
||||||
<h2>Notes</h2>
|
<h2>Talks / Slides</h2>
|
||||||
<p>Some publicly-visible notes from a sort of knowledge graph that I use as information dump.</p>
|
<p>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
Malleable Software
|
||||||
|
(<a href="/slides/hackliza2024/software-maleable/software-maleable.odp">galician, </a>
|
||||||
|
for <a href="https://hackliza.gal">Hackliza</a>
|
||||||
|
<a href="/slides/hackliza2024/software-maleable/software-maleable.pdf">[PDF]</a>
|
||||||
|
<a href="/slides/hackliza2024/software-maleable/software-maleable.odp">[ODP]</a>)
|
||||||
|
(<a href="/slides/eslibre2024/software-maleable.odp">spanish,</a>
|
||||||
|
for <a href="https://eslib.re/2024/">esLibre 2024</a>
|
||||||
|
<a href="/slides/eslibre2024/software-maleable.pdf">[PDF]</a>
|
||||||
|
<a href="/slides/eslibre2024/software-maleable.odp">[ODP]</a>).
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</p>
|
||||||
</section>
|
</section>
|
||||||
</a>
|
|
||||||
<!-- section>
|
<!-- section>
|
||||||
<h2>Projects</h2>
|
<h2>Projects</h2>
|
||||||
<p>
|
<p>
|
||||||
@ -116,7 +136,7 @@
|
|||||||
<section id="social">
|
<section id="social">
|
||||||
<h2>Find me</h2>
|
<h2>Find me</h2>
|
||||||
<p>
|
<p>
|
||||||
<a href="https://social.codigoparallevar.com/@kenkeiras">Mastodon</a>
|
<a href="https://social.codigoparallevar.com/@kenkeiras">ActivityPub</a>
|
||||||
<a href="https://github.com/kenkeiras">GitHub</a>
|
<a href="https://github.com/kenkeiras">GitHub</a>
|
||||||
<a href="https://gitlab.com/kenkeiras">GitLab</a>
|
<a href="https://gitlab.com/kenkeiras">GitLab</a>
|
||||||
<a href="https://programaker.com/users/kenkeiras">PrograMaker</a>
|
<a href="https://programaker.com/users/kenkeiras">PrograMaker</a>
|
||||||
|
@ -10,6 +10,8 @@ body {
|
|||||||
max-width: 80ex;
|
max-width: 80ex;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
padding: 0.5ex 1ex;
|
padding: 0.5ex 1ex;
|
||||||
|
background-color: white;
|
||||||
|
color: black;
|
||||||
}
|
}
|
||||||
|
|
||||||
body.blog {
|
body.blog {
|
||||||
@ -332,6 +334,11 @@ h1.title .state.todo-True {
|
|||||||
h1.title .state.todo-False {
|
h1.title .state.todo-False {
|
||||||
background-color: rgba(0,255,0,0.25);
|
background-color: rgba(0,255,0,0.25);
|
||||||
}
|
}
|
||||||
|
h1.title .state.todo-True.state-SOMETIME {
|
||||||
|
background-color: #ddd;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
h1.title .tags {
|
h1.title .tags {
|
||||||
float: right;
|
float: right;
|
||||||
@ -368,6 +375,7 @@ a.internal::after {
|
|||||||
}
|
}
|
||||||
a.external::after {
|
a.external::after {
|
||||||
content: ' ↗';
|
content: ' ↗';
|
||||||
|
vertical-align: top;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Markup */
|
/* Markup */
|
||||||
@ -580,7 +588,7 @@ tr.__table-separator {
|
|||||||
|
|
||||||
/* Dark mode. */
|
/* Dark mode. */
|
||||||
@media (prefers-color-scheme: dark) {
|
@media (prefers-color-scheme: dark) {
|
||||||
html {
|
html, body {
|
||||||
background-color: #1d1f21;
|
background-color: #1d1f21;
|
||||||
color: #fafafe;
|
color: #fafafe;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user