Compare commits

..

3 Commits

Author SHA1 Message Date
gitea actions 29caead1d9 update helium to 0.10.2.1 2026-03-13 12:47:30 +00:00
thomas e16829f19a update zen browser to 1.19.2b (#11)
automated update of zen browser appimage version and hash

## changelog
from `1.19.2a` to `1.19.2b`

upstream release: https://github.com/zen-browser/desktop/releases/tag/1.19.2b

# Zen Stable Release

## Security

[Various security fixes](https://www.mozilla.org/en-US/security/advisories/mfsa2026-19/)

## New Features

- Updated to Firefox 148.0.2

## Fixes

- Fixed some RSS live folders not working with certain feeds. ([#12685](https://github.com/zen-browser/desktop/issues/12685))

- Improved performance for spaces, specially when switching between them. ([#11851](https://github.com/zen-browser/desktop/issues/11851))

- Other minor bug fixes and improvements.

Co-authored-by: gitea actions <actions@localhost>
Reviewed-on: https://gitea.unrail.xyz/thomas/nixos-config/pulls/11
2026-03-13 12:47:17 +00:00
thomas 269276003d preserve markdown formatting in scraped changelog 2026-03-13 12:46:08 +00:00
2 changed files with 129 additions and 32 deletions
+127 -30
View File
@@ -22,7 +22,7 @@ release_tag_template="${release_tag_template//$'\r'/}"
current_version=$($PYTHON_BIN - <<'PY' current_version=$($PYTHON_BIN - <<'PY'
import re import re
import os import os
p=os.environ['FILE'] p=os.environ["FILE"]
s=open(p).read() s=open(p).read()
m=re.search(r'version\s*=\s*"([^"]+)";', s) m=re.search(r'version\s*=\s*"([^"]+)";', s)
print(m.group(1) if m else "") print(m.group(1) if m else "")
@@ -53,11 +53,11 @@ export NEW_HASH="$new_hash"
"$PYTHON_BIN" - <<'PY' "$PYTHON_BIN" - <<'PY'
import os import os
import re import re
p=os.environ['FILE'] p=os.environ["FILE"]
s=open(p).read() s=open(p).read()
s=re.sub(r'version\s*=\s*"[^"]+"', f'version = "{os.environ["LATEST_VERSION"]}"', s, count=1) s=re.sub(r'version\s*=\s*"[^"]+"', f'version = "{os.environ["LATEST_VERSION"]}"', s, count=1)
s=re.sub(r'hash\s*=\s*"[^"]+"', f'hash = "{os.environ["NEW_HASH"]}"', s, count=1) s=re.sub(r'hash\s*=\s*"[^"]+"', f'hash = "{os.environ["NEW_HASH"]}"', s, count=1)
open(p,'w').write(s) open(p,"w").write(s)
PY PY
echo "updated=true" >> "$GITHUB_OUTPUT" echo "updated=true" >> "$GITHUB_OUTPUT"
@@ -76,7 +76,8 @@ release_html=$(curl -fsSL "$release_url" || true)
release_notes="" release_notes=""
if [ -n "$release_html" ]; then if [ -n "$release_html" ]; then
release_notes=$(printf '%s' "$release_html" | "$PYTHON_BIN" -c ' release_notes=$(printf '%s' "$release_html" | "$PYTHON_BIN" -c '
import re, sys import re
import sys
from html.parser import HTMLParser from html.parser import HTMLParser
html = sys.stdin.read() html = sys.stdin.read()
@@ -88,46 +89,142 @@ if not m:
fragment = m.group(1) fragment = m.group(1)
class Extractor(HTMLParser): class MdExtractor(HTMLParser):
def __init__(self): def __init__(self):
super().__init__() super().__init__()
self.out = [] self.out = []
self.in_code = False self.list_depth = 0
self.in_pre = False
self.in_code_inline = False
self.link_stack = []
def _append(self, text):
self.out.append(text)
def _ensure_newline(self):
if not self.out:
return
if not self.out[-1].endswith("\n"):
self.out.append("\n")
def _ensure_blank_line(self):
if not self.out:
return
joined = "".join(self.out)
if joined.endswith("\n\n"):
return
if joined.endswith("\n"):
self.out.append("\n")
else:
self.out.append("\n\n")
def handle_starttag(self, tag, attrs): def handle_starttag(self, tag, attrs):
if tag in ("br",): attrs_d = dict(attrs)
self.out.append("\n")
elif tag in ("p", "div", "h1", "h2", "h3", "h4", "h5", "h6", "li"): if tag in ("h1", "h2", "h3", "h4", "h5", "h6"):
if self.out and not self.out[-1].endswith("\n"): self._ensure_blank_line()
self.out.append("\n") level = int(tag[1])
elif tag in ("pre",): self._append("#" * level + " ")
if self.out and not self.out[-1].endswith("\n"): return
self.out.append("\n")
self.out.append("```\n") if tag in ("p", "div"):
self.in_code = True self._ensure_blank_line()
elif tag in ("code",) and not self.in_code: return
self.out.append("`")
if tag in ("ul", "ol"):
self._ensure_blank_line()
self.list_depth += 1
return
if tag == "li":
self._ensure_newline()
indent = " " * max(self.list_depth - 1, 0)
self._append(f"{indent}- ")
return
if tag == "br":
self._append("\n")
return
if tag == "pre":
self._ensure_blank_line()
self._append("```\n")
self.in_pre = True
return
if tag == "code":
if not self.in_pre:
self._append("`")
self.in_code_inline = True
return
if tag == "a":
href = attrs_d.get("href", "")
self.link_stack.append(href)
self._append("[")
return
if tag in ("strong", "b"):
self._append("**")
return
if tag in ("em", "i"):
self._append("*")
return
def handle_endtag(self, tag): def handle_endtag(self, tag):
if tag in ("p", "div", "li", "h1", "h2", "h3", "h4", "h5", "h6"): if tag in ("h1", "h2", "h3", "h4", "h5", "h6", "p", "div"):
if not self.out or not self.out[-1].endswith("\n"): self._ensure_blank_line()
self.out.append("\n") return
elif tag in ("pre",):
if not self.out or not self.out[-1].endswith("\n"): if tag in ("ul", "ol"):
self.out.append("\n") self.list_depth = max(self.list_depth - 1, 0)
self.out.append("```\n") self._ensure_blank_line()
self.in_code = False return
elif tag in ("code",) and not self.in_code:
self.out.append("`") if tag == "li":
self._ensure_newline()
return
if tag == "pre":
self._ensure_newline()
self._append("```\n\n")
self.in_pre = False
return
if tag == "code":
if not self.in_pre and self.in_code_inline:
self._append("`")
self.in_code_inline = False
return
if tag == "a":
href = self.link_stack.pop() if self.link_stack else ""
if href:
self._append("]("
+ href
+ ")")
else:
self._append("]")
return
if tag in ("strong", "b"):
self._append("**")
return
if tag in ("em", "i"):
self._append("*")
return
def handle_data(self, data): def handle_data(self, data):
if data: if data:
self.out.append(data) self._append(data)
parser = Extractor() parser = MdExtractor()
parser.feed(fragment) parser.feed(fragment)
text = "".join(parser.out) text = "".join(parser.out)
text = re.sub(r"\n{3,}", "\n\n", text) text = re.sub(r"\n{3,}", "\n\n", text)
text = re.sub(r"[ \t]+\n", "\n", text)
print(text.strip()) print(text.strip())
' || true) ' || true)
else else
+2 -2
View File
@@ -2,11 +2,11 @@
perSystem = { pkgs, ... }: { perSystem = { pkgs, ... }: {
packages.helium = pkgs.appimageTools.wrapType2 rec { packages.helium = pkgs.appimageTools.wrapType2 rec {
pname = "helium"; pname = "helium";
version = "0.9.4.1"; version = "0.10.2.1";
src = pkgs.fetchurl { src = pkgs.fetchurl {
url = "https://github.com/imputnet/helium-linux/releases/download/${version}/${pname}-${version}-x86_64.AppImage"; url = "https://github.com/imputnet/helium-linux/releases/download/${version}/${pname}-${version}-x86_64.AppImage";
hash = "sha256-N5gdWuxOrIudJx/4nYo4/SKSxakpTFvL4zzByv6Cnug="; hash = "sha256-Kh6UgdleK+L+G4LNiQL2DkQIwS43cyzX+Jo6K0/fX1M=";
}; };
extraInstallCommands = let extraInstallCommands = let