diff options
| -rw-r--r-- | about/index.html | 3 | ||||
| -rw-r--r-- | about/resources.html | 188 | ||||
| -rw-r--r-- | about/showcase.html | 412 | ||||
| -rw-r--r-- | about/showcase/debroid/image-1.png | 127 | ||||
| -rw-r--r-- | gemfeed/2025-06-22-task-samurai.html | 7 | ||||
| -rw-r--r-- | gemfeed/2025-08-05-local-coding-llm-with-ollama.html | 457 | ||||
| -rw-r--r-- | gemfeed/DRAFT-kubernetes-with-freebsd-part-7.html | 3 | ||||
| -rw-r--r-- | gemfeed/STUNNEL-NFS-SETUP-R1-R2.md | 277 | ||||
| -rw-r--r-- | gemfeed/aitest/cmd/aitest/main.go | 32 | ||||
| -rw-r--r-- | gemfeed/aitest/go.mod | 3 | ||||
| -rw-r--r-- | gemfeed/aitest/internal/count.go | 21 | ||||
| -rw-r--r-- | gemfeed/aitest/internal/version.go | 7 | ||||
| -rw-r--r-- | gemfeed/atom.xml | 650 | ||||
| -rw-r--r-- | gemfeed/index.html | 1 | ||||
| -rw-r--r-- | gemfeed/local-coding-LLM-with-ollama/aider-fix-package.png | bin | 0 -> 178283 bytes | |||
| -rw-r--r-- | gemfeed/local-coding-LLM-with-ollama/helix-lsp-ai.png | bin | 0 -> 59192 bytes | |||
| -rw-r--r-- | gemfeed/local-coding-LLM-with-ollama/ollama-serve.png | bin | 0 -> 260363 bytes | |||
| -rw-r--r-- | index.html | 3 | ||||
| -rw-r--r-- | uptime-stats.html | 76 |
19 files changed, 1396 insertions, 871 deletions
diff --git a/about/index.html b/about/index.html index ae8a9952..541259cb 100644 --- a/about/index.html +++ b/about/index.html @@ -40,7 +40,6 @@ <br /> <a class='textlink' href='https://fosstodon.org/@snonux'>@snonux@fosstodon.org - Me at Mastodon</a><br /> <a class='textlink' href='https://www.linkedin.com/in/paul-buetow-b4857270/'>My LinkedIn profile</a><br /> -<a class='textlink' href='https://gophers.slack.com'>Gophers Slack - Under my real name</a><br /> <br /> <h2 style='display: inline' id='books'>Books</h2><br /> <br /> @@ -49,13 +48,13 @@ <ul> <li>Chaos Engineering - System Resiliency in Practice, Casey Rosenthal and Nora Jones, eBook</li> <li>Die Tiefe der Zeit, Andreas Brandhorst (german), Paperback</li> -<li>Inhibitor Phase, Alastair Reynolds, Audiobook</li> <li>Seeking SRE: Conversations About Running Production Systems at Scale, David N. Blank-Edelman, eBook</li> <li>Yoga Nidra Made Easy, Uma Dinsmore-Tuli, eBook</li> </ul><br /> <h3 style='display: inline' id='unread-books-already-in-my-shelf'>Unread books already in my shelf</h3><br /> <br /> <ul> +<li>Inhibitor Phase, Alastair Reynolds, Audiobook</li> <li>Okular, Alastair Reynolds, eBook</li> <li>97 Things Every Engineering Manager Should Know, Camille Fournier, Audiobook</li> </ul><br /> diff --git a/about/resources.html b/about/resources.html index 37558efb..0afca9ed 100644 --- a/about/resources.html +++ b/about/resources.html @@ -50,107 +50,107 @@ <span>In random order:</span><br /> <br /> <ul> -<li>Effective Java; Joshua Bloch; Addison-Wesley Professional</li> -<li>Learn You a Haskell for Great Good!; Miran Lipovaca; No Starch Press</li> -<li>C++ Programming Language; Bjarne Stroustrup;</li> -<li>Terraform Cookbook; Mikael Krief; Packt Publishing</li> <li>The Practise of System and Network Administration; Thomas A. Limoncelli, Christina J. Hogan, Strata R. Chalup; Addison-Wesley Professional Pro Git; Scott Chacon, Ben Straub; Apress</li> -<li>The Docker Book; James Turnbull; Kindle</li> -<li>Kubernetes Cookbook; Sameer Naik, Sébastien Goasguen, Jonathan Michaux; O'Reilly</li> -<li>DevOps And Site Reliability Engineering Handbook; Stephen Fleming; Audible</li> -<li>Distributed Systems: Principles and Paradigms; Andrew S. Tanenbaum; Pearson</li> -<li>Pro Puppet; James Turnbull, Jeffrey McCune; Apress</li> -<li>21st Century C: C Tips from the New School; Ben Klemens; O'Reilly</li> -<li>97 things every SRE should know; Emil Stolarsky, Jaime Woo; O'Reilly</li> +<li>The Go Programming Language; Alan A. A. Donovan; Addison-Wesley Professional</li> <li>Perl New Features; Joshua McAdams, brian d foy; Perl School</li> +<li>Learn You a Haskell for Great Good!; Miran Lipovaca; No Starch Press</li> <li>Funktionale Programmierung; Peter Pepper; Springer</li> -<li>Modern Perl; Chromatic ; Onyx Neon Press</li> -<li>Java ist auch eine Insel; Christian Ullenboom; </li> -<li>Polished Ruby Programming; Jeremy Evans; Packt Publishing</li> +<li>Raku Recipes; J.J. Merelo; Apress</li> <li>Hands-on Infrastructure Monitoring with Prometheus; Joel Bastos, Pedro Araujo; Packt </li> -<li>Raku Fundamentals; Moritz Lenz; Apress</li> -<li>Concurrency in Go; Katherine Cox-Buday; O'Reilly</li> <li>The Pragmatic Programmer; David Thomas; Addison-Wesley</li> -<li>Learn You Some Erlang for Great Good; Fred Herbert; No Starch Press</li> -<li>The Go Programming Language; Alan A. A. Donovan; Addison-Wesley Professional</li> -<li>DNS and BIND; Cricket Liu; O'Reilly</li> -<li>The Kubernetes Book; Nigel Poulton; Unabridged Audiobook</li> +<li>Java ist auch eine Insel; Christian Ullenboom; </li> +<li>Effective Java; Joshua Bloch; Addison-Wesley Professional</li> +<li>Clusterbau mit Linux-HA; Michael Schwartzkopff; O'Reilly</li> +<li>DevOps And Site Reliability Engineering Handbook; Stephen Fleming; Audible</li> <li>Leanring eBPF; Liz Rice; O'Reilly</li> +<li>The KCNA (Kubernetes and Cloud Native Associate) Book; Nigel Poulton</li> +<li>97 things every SRE should know; Emil Stolarsky, Jaime Woo; O'Reilly</li> +<li>Think Raku (aka Think Perl 6); Laurent Rosenfeld, Allen B. Downey; O'Reilly</li> +<li>Higher Order Perl; Mark Dominus; Morgan Kaufmann</li> <li>Ultimate Go Notebook; Bill Kennedy</li> +<li>Raku Fundamentals; Moritz Lenz; Apress</li> +<li>Learn You Some Erlang for Great Good; Fred Herbert; No Starch Press</li> +<li>Developing Games in Java; David Brackeen and others...; New Riders</li> +<li>Distributed Systems: Principles and Paradigms; Andrew S. Tanenbaum; Pearson</li> +<li>Kubernetes Cookbook; Sameer Naik, Sébastien Goasguen, Jonathan Michaux; O'Reilly</li> +<li>The DevOps Handbook; Gene Kim, Jez Humble, Patrick Debois, John Willis; Audible</li> +<li>Concurrency in Go; Katherine Cox-Buday; O'Reilly</li> +<li>Programming Perl aka "The Camel Book"; Tom Christiansen, brian d foy, Larry Wall & Jon Orwant; O'Reilly</li> +<li>Modern Perl; Chromatic ; Onyx Neon Press</li> +<li>DNS and BIND; Cricket Liu; O'Reilly</li> +<li>Programming Ruby 3.3 (5th Edition); Noel Rappin, with Dave Thomas; The Pragmatic Bookshelf</li> <li>100 Go Mistakes and How to Avoid Them; Teiva Harsanyi; Manning Publications</li> +<li>Polished Ruby Programming; Jeremy Evans; Packt Publishing</li> +<li>Object-Oriented Programming with ANSI-C; Axel-Tobias Schreiner</li> +<li>Systemprogrammierung in Go; Frank Müller; dpunkt</li> <li>Go Brain Teasers - Exercise Your Mind; Miki Tebeka; The Pragmatic Programmers</li> -<li>Higher Order Perl; Mark Dominus; Morgan Kaufmann</li> -<li>Programming Perl aka "The Camel Book"; Tom Christiansen, brian d foy, Larry Wall & Jon Orwant; O'Reilly</li> <li>Amazon Web Services in Action; Michael Wittig and Andreas Wittig; Manning Publications</li> -<li>Object-Oriented Programming with ANSI-C; Axel-Tobias Schreiner</li> -<li>Clusterbau mit Linux-HA; Michael Schwartzkopff; O'Reilly</li> -<li>Data Science at the Command Line; Jeroen Janssens; O'Reilly</li> -<li>The KCNA (Kubernetes and Cloud Native Associate) Book; Nigel Poulton</li> -<li>Raku Recipes; J.J. Merelo; Apress</li> -<li>Tmux 2: Productive Mouse-free Development; Brain P. Hogan; The Pragmatic Programmers </li> -<li>Systems Performance Tuning; Gian-Paolo D. Musumeci and others...; O'Reilly</li> -<li>Programming Ruby 3.3 (5th Edition); Noel Rappin, with Dave Thomas; The Pragmatic Bookshelf</li> +<li>The Kubernetes Book; Nigel Poulton; Unabridged Audiobook</li> <li>Effective awk programming; Arnold Robbins; O'Reilly</li> -<li>Systemprogrammierung in Go; Frank Müller; dpunkt</li> -<li>Think Raku (aka Think Perl 6); Laurent Rosenfeld, Allen B. Downey; O'Reilly</li> -<li>The DevOps Handbook; Gene Kim, Jez Humble, Patrick Debois, John Willis; Audible</li> +<li>The Docker Book; James Turnbull; Kindle</li> <li>Site Reliability Engineering; How Google runs production systems; O'Reilly</li> -<li>Developing Games in Java; David Brackeen and others...; New Riders</li> +<li>Pro Puppet; James Turnbull, Jeffrey McCune; Apress</li> +<li>Tmux 2: Productive Mouse-free Development; Brain P. Hogan; The Pragmatic Programmers </li> +<li>21st Century C: C Tips from the New School; Ben Klemens; O'Reilly</li> +<li>C++ Programming Language; Bjarne Stroustrup;</li> +<li>Data Science at the Command Line; Jeroen Janssens; O'Reilly</li> +<li>Systems Performance Tuning; Gian-Paolo D. Musumeci and others...; O'Reilly</li> +<li>Terraform Cookbook; Mikael Krief; Packt Publishing</li> </ul><br /> <h2 style='display: inline' id='technical-references'>Technical references</h2><br /> <br /> <span>I didn't read them from the beginning to the end, but I am using them to look up things. The books are in random order:</span><br /> <br /> <ul> -<li>BPF Performance Tools - Linux System and Application Observability, Brendan Gregg; Addison Wesley</li> -<li>The Linux Programming Interface; Michael Kerrisk; No Starch Press </li> -<li>Implementing Service Level Objectives; Alex Hidalgo; O'Reilly</li> <li>Groovy Kurz & Gut; Joerg Staudemeier; O'Reilly</li> <li>Relayd and Httpd Mastery; Michael W Lucas</li> <li>Go: Design Patterns for Real-World Projects; Mat Ryer; Packt</li> <li>Understanding the Linux Kernel; Daniel P. Bovet, Marco Cesati; O'Reilly</li> +<li>The Linux Programming Interface; Michael Kerrisk; No Starch Press </li> +<li>Implementing Service Level Objectives; Alex Hidalgo; O'Reilly</li> <li>Algorithms; Robert Sedgewick, Kevin Wayne; Addison Wesley</li> +<li>BPF Performance Tools - Linux System and Application Observability, Brendan Gregg; Addison Wesley</li> </ul><br /> <h2 style='display: inline' id='self-development-and-soft-skills-books'>Self-development and soft-skills books</h2><br /> <br /> <span>In random order:</span><br /> <br /> <ul> -<li>The Joy of Missing Out; Christina Crook; New Society Publishers</li> -<li>So Good They Can't Ignore You; Cal Newport; Business Plus</li> +<li>Meditation for Mortals, Oliver Burkeman, Audiobook</li> +<li>The Complete Software Developer's Career Guide; John Sonmez; Unabridged Audiobook</li> +<li>Slow Productivity; Cal Newport; Penguin Random House</li> +<li>Ultralearning; Scott Young; Thorsons</li> +<li>Influence without Authority; A. Cohen, D. Bradford; Wiley</li> +<li>Consciousness: A Very Short Introduction; Susan Blackmore; Oxford Uiversity Press</li> <li>Coders at Work - Reflections on the craft of programming, Peter Seibel and Mitchell Dorian et al., Audiobook</li> -<li>Eat That Frog; Brian Tracy</li> -<li>Who Moved My Cheese?; Dr. Spencer Johnson; Vermilion</li> -<li>Deep Work; Cal Newport; Piatkus</li> -<li>Digital Minimalism; Cal Newport; Portofolio Penguin</li> +<li>The Obstacle Is The Way; Ryan Holiday; Profile Books Ltd</li> +<li>Eat That Frog!; Brian Tracy; Hodder Paperbacks</li> +<li>Buddah and Einstein walk into a Bar; Guy Joseph Ale, Claire Bloom; Blackstone Publishing</li> +<li>Atomic Habits; James Clear; Random House Business</li> +<li>The Phoenix Project - A Novel About IT, DevOps, and Helping your Business Win; Gene Kim and Kevin Behr; Trade Select</li> <li>The Off Switch; Mark Cropley; Virgin Books (RE-READ 1ST TIME)</li> -<li>The Daily Stoic; Ryan Holiday, Stephen Hanselman; Profile Books</li> -<li>Influence without Authority; A. Cohen, D. Bradford; Wiley</li> -<li>The Bullet Journal Method; Ryder Carroll; Fourth Estate</li> +<li>Ultralearning; Anna Laurent; Self-published via Amazon</li> <li>Soft Skills; John Sommez; Manning Publications</li> -<li>Ultralearning; Scott Young; Thorsons</li> -<li>The Obstacle Is The Way; Ryan Holiday; Profile Books Ltd</li> -<li>101 Essays that change the way you think; Brianna Wiest; Audiobook</li> +<li>So Good They Can't Ignore You; Cal Newport; Business Plus</li> +<li>The Joy of Missing Out; Christina Crook; New Society Publishers</li> +<li>Staff Engineer: Leadership beyond the management track; Will Larson; Audiobook</li> +<li>Digital Minimalism; Cal Newport; Portofolio Penguin</li> +<li>The Daily Stoic; Ryan Holiday, Stephen Hanselman; Profile Books</li> <li>Solve for Happy; Mo Gawdat (RE-READ 1ST TIME)</li> -<li>Search Inside Yourself - The Unexpected path to Achieving Success, Happiness (and World Peace); Chade-Meng Tan, Daniel Goleman, Jon Kabat-Zinn; HarperOne</li> -<li>The Complete Software Developer's Career Guide; John Sonmez; Unabridged Audiobook</li> -<li>The Power of Now; Eckhard Tolle; Yellow Kite</li> +<li>Who Moved My Cheese?; Dr. Spencer Johnson; Vermilion</li> +<li>Eat That Frog; Brian Tracy</li> +<li>The Bullet Journal Method; Ryder Carroll; Fourth Estate</li> <li>Stop starting, start finishing; Arne Roock; Lean-Kanban University </li> <li>The 7 Habits Of Highly Effective People; Stephen R. Covey; Simon & Schuster UK</li> -<li>Eat That Frog!; Brian Tracy; Hodder Paperbacks</li> -<li>Never Split the Difference; Chris Voss, Tahl Raz; Random House Business</li> +<li>The Power of Now; Eckhard Tolle; Yellow Kite</li> <li>The Good Enough Job; Simone Stolzoff; Ebury Edge</li> -<li>Ultralearning; Anna Laurent; Self-published via Amazon</li> -<li>Meditation for Mortals, Oliver Burkeman, Audiobook</li> -<li>Getting Things Done; David Allen</li> -<li>Atomic Habits; James Clear; Random House Business</li> -<li>Staff Engineer: Leadership beyond the management track; Will Larson; Audiobook</li> <li>Time Management for System Administrators; Thomas A. Limoncelli; O'Reilly</li> -<li>The Phoenix Project - A Novel About IT, DevOps, and Helping your Business Win; Gene Kim and Kevin Behr; Trade Select</li> -<li>Buddah and Einstein walk into a Bar; Guy Joseph Ale, Claire Bloom; Blackstone Publishing</li> -<li>Consciousness: A Very Short Introduction; Susan Blackmore; Oxford Uiversity Press</li> <li>Psycho-Cybernetics; Maxwell Maltz; Perigee Books</li> -<li>Slow Productivity; Cal Newport; Penguin Random House</li> +<li>Never Split the Difference; Chris Voss, Tahl Raz; Random House Business</li> +<li>Search Inside Yourself - The Unexpected path to Achieving Success, Happiness (and World Peace); Chade-Meng Tan, Daniel Goleman, Jon Kabat-Zinn; HarperOne</li> +<li>Getting Things Done; David Allen</li> +<li>101 Essays that change the way you think; Brianna Wiest; Audiobook</li> +<li>Deep Work; Cal Newport; Piatkus</li> </ul><br /> <a class='textlink' href='../notes/index.html'>Here are notes of mine for some of the books</a><br /> <br /> @@ -159,22 +159,22 @@ <span>Some of these were in-person with exams; others were online learning lectures only. In random order:</span><br /> <br /> <ul> -<li>Functional programming lecture; Remote University of Hagen</li> -<li>Apache Tomcat Best Practises; 3-day on-site training</li> -<li>Structure and Interpretation of Computer Programs; Harold Abelson and more...; </li> +<li>Red Hat Certified System Administrator; Course + certification (Although I had the option, I decided not to take the next course as it is more effective to self learn what I need)</li> +<li>Protocol buffers; O'Reilly Online</li> <li>AWS Immersion Day; Amazon; 1-day interactive online training </li> +<li>Apache Tomcat Best Practises; 3-day on-site training</li> <li>Ultimate Go Programming; Bill Kennedy; O'Reilly Online</li> -<li>Linux Security and Isolation APIs Training; Michael Kerrisk; 3-day on-site training</li> -<li>MySQL Deep Dive Workshop; 2-day on-site training</li> -<li>Red Hat Certified System Administrator; Course + certification (Although I had the option, I decided not to take the next course as it is more effective to self learn what I need)</li> +<li>Scripting Vim; Damian Conway; O'Reilly Online</li> <li>Cloud Operations on AWS - Learn how to configure, deploy, maintain, and troubleshoot your AWS environments; 3-day online live training with labs; Amazon</li> -<li>Protocol buffers; O'Reilly Online</li> +<li>Functional programming lecture; Remote University of Hagen</li> <li>Algorithms Video Lectures; Robert Sedgewick; O'Reilly Online</li> -<li>The Ultimate Kubernetes Bootcamp; School of Devops; O'Reilly Online</li> -<li>Developing IaC with Terraform (with Live Lessons); O'Reilly Online</li> +<li>MySQL Deep Dive Workshop; 2-day on-site training</li> <li>F5 Loadbalancers Training; 2-day on-site training; F5, Inc. </li> -<li>Scripting Vim; Damian Conway; O'Reilly Online</li> +<li>Developing IaC with Terraform (with Live Lessons); O'Reilly Online</li> +<li>Linux Security and Isolation APIs Training; Michael Kerrisk; 3-day on-site training</li> +<li>Structure and Interpretation of Computer Programs; Harold Abelson and more...; </li> <li>The Well-Grounded Rubyist Video Edition; David. A. Black; O'Reilly Online</li> +<li>The Ultimate Kubernetes Bootcamp; School of Devops; O'Reilly Online</li> </ul><br /> <h2 style='display: inline' id='technical-guides'>Technical guides</h2><br /> <br /> @@ -192,31 +192,31 @@ <span>In random order:</span><br /> <br /> <ul> +<li>BSD Now [BSD]</li> +<li>Deep Questions with Cal Newport</li> <li>The Changelog Podcast(s)</li> <li>Dev Interrupted</li> -<li>Fallthrough [Golang]</li> -<li>Modern Mentor</li> -<li>Deep Questions with Cal Newport</li> -<li>Cup o' Go [Golang]</li> -<li>Fork Around And Find Out</li> -<li>Hidden Brain</li> -<li>Maintainable</li> -<li>Pratical AI</li> <li>The Pragmatic Engineer Podcast</li> <li>Backend Banter</li> +<li>Fallthrough [Golang]</li> +<li>Maintainable</li> <li>The ProdCast (Google SRE Podcast)</li> -<li>BSD Now [BSD]</li> +<li>Fork Around And Find Out</li> +<li>Pratical AI</li> +<li>Hidden Brain</li> +<li>Modern Mentor</li> +<li>Cup o' Go [Golang]</li> </ul><br /> <h3 style='display: inline' id='podcasts-i-liked'>Podcasts I liked</h3><br /> <br /> <span>I liked them but am not listening to them anymore. The podcasts have either "finished" (no more episodes) or I stopped listening to them due to time constraints or a shift in my interests.</span><br /> <br /> <ul> -<li>CRE: Chaosradio Express [german]</li> +<li>FLOSS weekly</li> <li>Go Time (predecessor of fallthrough)</li> -<li>Java Pub House</li> +<li>CRE: Chaosradio Express [german]</li> <li>Modern Mentor</li> -<li>FLOSS weekly</li> +<li>Java Pub House</li> <li>Ship It (predecessor of Fork Around And Find Out)</li> </ul><br /> <h2 style='display: inline' id='newsletters-i-like'>Newsletters I like</h2><br /> @@ -224,28 +224,28 @@ <span>This is a mix of tech and non-tech newsletters I am subscribed to. In random order:</span><br /> <br /> <ul> -<li>VK Newsletter</li> -<li>The Valuable Dev</li> +<li>Register Spill</li> +<li>Applied Go Weekly Newsletter</li> +<li>Changelog News</li> <li>The Pragmatic Engineer</li> -<li>Andreas Brandhorst Newsletter (Sci-Fi author)</li> <li>The Imperfectionist</li> -<li>Golang Weekly</li> +<li>The Valuable Dev</li> +<li>Andreas Brandhorst Newsletter (Sci-Fi author)</li> <li>byteSizeGo</li> -<li>Applied Go Weekly Newsletter</li> -<li>Register Spill</li> +<li>Golang Weekly</li> +<li>VK Newsletter</li> <li>Ruby Weekly</li> <li>Monospace Mentor</li> -<li>Changelog News</li> </ul><br /> <h2 style='display: inline' id='magazines-i-liked'>Magazines I like(d)</h2><br /> <br /> <span>This is a mix of tech I like(d). I may not be a current subscriber, but now and then, I buy an issue. In random order:</span><br /> <br /> <ul> +<li>Linux Magazine</li> <li>freeX (not published anymore)</li> -<li>LWN (online only)</li> <li>Linux User</li> -<li>Linux Magazine</li> +<li>LWN (online only)</li> </ul><br /> <h1 style='display: inline' id='formal-education'>Formal education</h1><br /> <br /> diff --git a/about/showcase.html b/about/showcase.html index 5ca714ca..71fb1201 100644 --- a/about/showcase.html +++ b/about/showcase.html @@ -13,7 +13,7 @@ </p> <h1 style='display: inline' id='project-showcase'>Project Showcase</h1><br /> <br /> -<span>Generated on: 2025-07-22</span><br /> +<span>Generated on: 2025-08-01</span><br /> <br /> <span>This page showcases my side projects, providing an overview of what each project does, its technical implementation, and key metrics. Each project summary includes information about the programming languages used, development activity, and licensing. The projects are ordered by recent activity, with the most actively maintained projects listed first.</span><br /> <br /> @@ -24,12 +24,12 @@ <li>⇢ <a href='#overall-statistics'>Overall Statistics</a></li> <li>⇢ <a href='#projects'>Projects</a></li> <li>⇢ ⇢ <a href='#totalrecall'>totalrecall</a></li> -<li>⇢ ⇢ <a href='#gitsyncer'>gitsyncer</a></li> -<li>⇢ ⇢ <a href='#dtail'>dtail</a></li> <li>⇢ ⇢ <a href='#rexfiles'>rexfiles</a></li> +<li>⇢ ⇢ <a href='#gitsyncer'>gitsyncer</a></li> <li>⇢ ⇢ <a href='#timr'>timr</a></li> <li>⇢ ⇢ <a href='#tasksamurai'>tasksamurai</a></li> <li>⇢ ⇢ <a href='#ior'>ior</a></li> +<li>⇢ ⇢ <a href='#dtail'>dtail</a></li> <li>⇢ ⇢ <a href='#wireguardmeshgenerator'>wireguardmeshgenerator</a></li> <li>⇢ ⇢ <a href='#ds-sim'>ds-sim</a></li> <li>⇢ ⇢ <a href='#sillybench'>sillybench</a></li> @@ -39,11 +39,12 @@ <li>⇢ ⇢ <a href='#gemtexter'>gemtexter</a></li> <li>⇢ ⇢ <a href='#quicklogger'>quicklogger</a></li> <li>⇢ ⇢ <a href='#docker-gpodder-sync-server'>docker-gpodder-sync-server</a></li> +<li>⇢ ⇢ <a href='#docker-anki-sync-server'>docker-anki-sync-server</a></li> <li>⇢ ⇢ <a href='#terraform'>terraform</a></li> <li>⇢ ⇢ <a href='#gogios'>gogios</a></li> <li>⇢ ⇢ <a href='#docker-radicale-server'>docker-radicale-server</a></li> -<li>⇢ ⇢ <a href='#docker-anki-sync-server'>docker-anki-sync-server</a></li> <li>⇢ ⇢ <a href='#gorum'>gorum</a></li> +<li>⇢ ⇢ <a href='#guprecords'>guprecords</a></li> <li>⇢ ⇢ <a href='#randomjournalpage'>randomjournalpage</a></li> <li>⇢ ⇢ <a href='#sway-autorotate'>sway-autorotate</a></li> <li>⇢ ⇢ <a href='#photoalbum'>photoalbum</a></li> @@ -51,7 +52,6 @@ <li>⇢ ⇢ <a href='#geheim'>geheim</a></li> <li>⇢ ⇢ <a href='#foozone'>foo.zone</a></li> <li>⇢ ⇢ <a href='#perl-c-fibonacci'>perl-c-fibonacci</a></li> -<li>⇢ ⇢ <a href='#guprecords'>guprecords</a></li> <li>⇢ ⇢ <a href='#ioriot'>ioriot</a></li> <li>⇢ ⇢ <a href='#staticfarm-apache-handlers'>staticfarm-apache-handlers</a></li> <li>⇢ ⇢ <a href='#dyndns'>dyndns</a></li> @@ -74,21 +74,21 @@ <li>⇢ ⇢ <a href='#perldaemon'>perldaemon</a></li> <li>⇢ ⇢ <a href='#awksite'>awksite</a></li> <li>⇢ ⇢ <a href='#jsmstrade'>jsmstrade</a></li> +<li>⇢ ⇢ <a href='#ychat'>ychat</a></li> <li>⇢ ⇢ <a href='#netcalendar'>netcalendar</a></li> <li>⇢ ⇢ <a href='#hsbot'>hsbot</a></li> -<li>⇢ ⇢ <a href='#ychat'>ychat</a></li> -<li>⇢ ⇢ <a href='#fype'>fype</a></li> <li>⇢ ⇢ <a href='#vs-sim'>vs-sim</a></li> +<li>⇢ ⇢ <a href='#fype'>fype</a></li> </ul><br /> <h2 style='display: inline' id='overall-statistics'>Overall Statistics</h2><br /> <br /> <ul> <li>📦 Total Projects: 56</li> -<li>📊 Total Commits: 10,597</li> -<li>📈 Total Lines of Code: 175,312</li> -<li>📄 Total Lines of Documentation: 236,493</li> -<li>💻 Languages: Go (38.8%), Java (23.1%), C (11.5%), Perl (8.8%), Shell (3.6%), C/C++ (3.0%), Config (1.7%), HTML (1.6%), Ruby (1.6%), HCL (1.6%), Python (0.9%), Make (0.9%), CSS (0.7%), JSON (0.5%), Raku (0.4%), XML (0.4%), Haskell (0.3%), YAML (0.3%), TOML (0.2%)</li> -<li>📚 Documentation: Text (94.5%), Markdown (5.3%), LaTeX (0.2%)</li> +<li>📊 Total Commits: 10,648</li> +<li>📈 Total Lines of Code: 194,087</li> +<li>📄 Total Lines of Documentation: 22,230</li> +<li>💻 Languages: Go (31.8%), Java (20.8%), C (9.9%), C++ (8.8%), Perl (8.2%), C/C++ (6.4%), Shell (3.0%), HTML (1.9%), Config (1.9%), Ruby (1.5%), HCL (1.4%), Python (0.8%), Make (0.8%), CSS (0.7%), Raku (0.5%), YAML (0.4%), JSON (0.4%), XML (0.3%), Haskell (0.3%), TOML (0.2%)</li> +<li>📚 Documentation: Text (50.5%), Markdown (46.9%), LaTeX (2.6%)</li> <li>🎵 Vibe-Coded Projects: 4 out of 56 (7.1%)</li> <li>🤖 AI-Assisted Projects (including vibe-coded): 8 out of 56 (14.3% AI-assisted, 85.7% human-only)</li> <li>🚀 Release Status: 34 released, 22 experimental (60.7% with releases, 39.3% experimental)</li> @@ -104,7 +104,7 @@ <li>📈 Lines of Code: 11782</li> <li>📄 Lines of Documentation: 357</li> <li>📅 Development Period: 2025-07-14 to 2025-07-22</li> -<li>🔥 Recent Activity: 1.8 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 11.2 days (avg. age of last 42 commits)</li> <li>⚖️ License: MIT</li> <li>🏷️ Latest Release: v0.7.3 (2025-07-22)</li> <li>🎵 Vibe-Coded: This project has been vibe coded</li> @@ -123,18 +123,41 @@ <br /> <span>---</span><br /> <br /> +<h3 style='display: inline' id='rexfiles'>rexfiles</h3><br /> +<br /> +<ul> +<li>💻 Languages: Perl (34.1%), Shell (27.8%), YAML (7.9%), TOML (7.6%), Config (7.1%), CSS (7.0%), Ruby (5.2%), Lua (1.5%), Make (0.9%), JSON (0.6%), INI (0.1%)</li> +<li>📚 Documentation: Text (89.8%), Markdown (10.2%)</li> +<li>📊 Commits: 905</li> +<li>📈 Lines of Code: 4651</li> +<li>📄 Lines of Documentation: 925</li> +<li>📅 Development Period: 2021-12-28 to 2025-07-31</li> +<li>🔥 Recent Activity: 12.0 days (avg. age of last 42 commits)</li> +<li>⚖️ License: No license found</li> +<li>🧪 Status: Experimental (no releases yet)</li> +</ul><br /> +<br /> +<span>Based on my analysis of the codebase, **rexfiles** is a comprehensive infrastructure automation and configuration management project built with the Rex framework (a Perl-based alternative to Ansible, Puppet, or Chef). The project provides structured automation for managing multiple aspects of a personal infrastructure, including dotfiles, server configurations, and application deployments.</span><br /> +<br /> +<span>The project consists of three main components: **dotfiles** management for personal development environment configuration (bash, fish shell, helix editor, tmux, etc.), **frontends** for managing production OpenBSD servers with services like DNS (nsd), web servers (httpd), mail (OpenSMTPD), SSL certificates (ACME), and monitoring systems, and **babylon5** containing Docker container startup scripts for self-hosted applications. The implementation leverages Rex's declarative syntax to define tasks for package installation, file management, service configuration, and system state management, with templates for configuration files and support for multiple operating systems (OpenBSD, FreeBSD, Fedora Linux, Termux). This approach provides a KISS (Keep It Simple, Stupid) alternative to more complex configuration management tools while maintaining the ability to manage both local development environments and production infrastructure consistently.</span><br /> +<br /> +<a class='textlink' href='https://codeberg.org/snonux/rexfiles'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/rexfiles'>View on GitHub</a><br /> +<br /> +<span>---</span><br /> +<br /> <h3 style='display: inline' id='gitsyncer'>gitsyncer</h3><br /> <br /> <ul> <li>💻 Languages: Go (90.3%), Shell (8.1%), YAML (1.0%), JSON (0.5%)</li> <li>📚 Documentation: Markdown (100.0%)</li> -<li>📊 Commits: 96</li> -<li>📈 Lines of Code: 9182</li> +<li>📊 Commits: 101</li> +<li>📈 Lines of Code: 9166</li> <li>📄 Lines of Documentation: 2484</li> -<li>📅 Development Period: 2025-06-23 to 2025-07-20</li> -<li>🔥 Recent Activity: 9.1 days (avg. age of last 42 commits)</li> +<li>📅 Development Period: 2025-06-23 to 2025-07-25</li> +<li>🔥 Recent Activity: 17.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: BSD-2-Clause</li> -<li>🏷️ Latest Release: v0.8.4 (2025-07-20)</li> +<li>🏷️ Latest Release: v0.8.6 (2025-07-25)</li> <li>🎵 Vibe-Coded: This project has been vibe coded</li> </ul><br /> <br /> @@ -147,57 +170,6 @@ <br /> <span>---</span><br /> <br /> -<h3 style='display: inline' id='dtail'>dtail</h3><br /> -<br /> -<ul> -<li>💻 Languages: Go (91.0%), Shell (4.1%), JSON (2.1%), C (1.4%), Make (0.9%), C/C++ (0.2%), Config (0.1%)</li> -<li>📚 Documentation: Text (98.3%), Markdown (1.7%)</li> -<li>📊 Commits: 1049</li> -<li>📈 Lines of Code: 27726</li> -<li>📄 Lines of Documentation: 220214</li> -<li>📅 Development Period: 2020-01-09 to 2025-07-04</li> -<li>🔥 Recent Activity: 20.2 days (avg. age of last 42 commits)</li> -<li>⚖️ License: Apache-2.0</li> -<li>🏷️ Latest Release: v4.2.0 (2023-06-21)</li> -<li>🤖 AI-Assisted: This project was partially created with the help of generative AI</li> -</ul><br /> -<br /> -<a href='showcase/dtail/image-1.png'><img alt='dtail screenshot' title='dtail screenshot' src='showcase/dtail/image-1.png' /></a><br /> -<br /> -<span>DTail is a distributed log processing system written in Go that allows DevOps engineers to tail, cat, and grep log files across thousands of servers concurrently. It provides secure access through SSH authentication and respects UNIX file system permissions, making it ideal for enterprise environments where log analysis needs to scale horizontally across large server fleets. The tool supports advanced features like compressed file handling (gzip/zstd) and distributed MapReduce aggregations for complex log analytics.</span><br /> -<br /> -<a href='showcase/dtail/image-2.gif'><img alt='dtail screenshot' title='dtail screenshot' src='showcase/dtail/image-2.gif' /></a><br /> -<br /> -<span>The system uses a client-server architecture where dtail servers run on target machines (listening on port 2222) and clients connect to multiple servers simultaneously. It can also operate in serverless mode for local operations. The implementation leverages SSH for secure communication, includes sophisticated connection throttling and resource management, and provides specialized tools (dcat, dgrep, dmap) for different log processing tasks. The MapReduce functionality supports SQL-like queries with server-side local aggregation and client-side final aggregation, enabling powerful distributed analytics across log data.</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/dtail'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/dtail'>View on GitHub</a><br /> -<br /> -<span>---</span><br /> -<br /> -<h3 style='display: inline' id='rexfiles'>rexfiles</h3><br /> -<br /> -<ul> -<li>💻 Languages: Perl (38.1%), Shell (30.9%), Config (8.0%), CSS (7.8%), TOML (6.9%), Ruby (5.8%), Lua (1.7%), JSON (0.7%), INI (0.1%)</li> -<li>📚 Documentation: Text (97.3%), Markdown (2.7%)</li> -<li>📊 Commits: 883</li> -<li>📈 Lines of Code: 4160</li> -<li>📄 Lines of Documentation: 854</li> -<li>📅 Development Period: 2021-12-28 to 2025-07-22</li> -<li>🔥 Recent Activity: 22.4 days (avg. age of last 42 commits)</li> -<li>⚖️ License: No license found</li> -<li>🧪 Status: Experimental (no releases yet)</li> -</ul><br /> -<br /> -<span>Based on my analysis of the codebase, **rexfiles** is a comprehensive infrastructure automation and configuration management project built with the Rex framework (a Perl-based alternative to Ansible, Puppet, or Chef). The project provides structured automation for managing multiple aspects of a personal infrastructure, including dotfiles, server configurations, and application deployments.</span><br /> -<br /> -<span>The project consists of three main components: **dotfiles** management for personal development environment configuration (bash, fish shell, helix editor, tmux, etc.), **frontends** for managing production OpenBSD servers with services like DNS (nsd), web servers (httpd), mail (OpenSMTPD), SSL certificates (ACME), and monitoring systems, and **babylon5** containing Docker container startup scripts for self-hosted applications. The implementation leverages Rex's declarative syntax to define tasks for package installation, file management, service configuration, and system state management, with templates for configuration files and support for multiple operating systems (OpenBSD, FreeBSD, Fedora Linux, Termux). This approach provides a KISS (Keep It Simple, Stupid) alternative to more complex configuration management tools while maintaining the ability to manage both local development environments and production infrastructure consistently.</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/rexfiles'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/rexfiles'>View on GitHub</a><br /> -<br /> -<span>---</span><br /> -<br /> <h3 style='display: inline' id='timr'>timr</h3><br /> <br /> <ul> @@ -207,7 +179,7 @@ <li>📈 Lines of Code: 873</li> <li>📄 Lines of Documentation: 137</li> <li>📅 Development Period: 2025-06-25 to 2025-07-19</li> -<li>🔥 Recent Activity: 24.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 33.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: BSD-2-Clause</li> <li>🏷️ Latest Release: v0.0.0 (2025-06-29)</li> <li>🎵 Vibe-Coded: This project has been vibe coded</li> @@ -231,7 +203,7 @@ <li>📈 Lines of Code: 6160</li> <li>📄 Lines of Documentation: 162</li> <li>📅 Development Period: 2025-06-19 to 2025-07-12</li> -<li>🔥 Recent Activity: 26.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 35.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: BSD-2-Clause</li> <li>🏷️ Latest Release: v0.9.2 (2025-07-02)</li> <li>🎵 Vibe-Coded: This project has been vibe coded</li> @@ -259,7 +231,7 @@ <li>📈 Lines of Code: 12762</li> <li>📄 Lines of Documentation: 742</li> <li>📅 Development Period: 2024-01-18 to 2025-07-14</li> -<li>🔥 Recent Activity: 64.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 73.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> <li>🤖 AI-Assisted: This project was partially created with the help of generative AI</li> @@ -280,6 +252,34 @@ <br /> <span>---</span><br /> <br /> +<h3 style='display: inline' id='dtail'>dtail</h3><br /> +<br /> +<ul> +<li>💻 Languages: Go (93.9%), JSON (2.8%), C (2.0%), Make (0.5%), C/C++ (0.3%), Config (0.2%), Shell (0.2%), Docker (0.1%)</li> +<li>📚 Documentation: Text (79.4%), Markdown (20.6%)</li> +<li>📊 Commits: 1049</li> +<li>📈 Lines of Code: 20091</li> +<li>📄 Lines of Documentation: 5674</li> +<li>📅 Development Period: 2020-01-09 to 2025-06-20</li> +<li>🔥 Recent Activity: 75.1 days (avg. age of last 42 commits)</li> +<li>⚖️ License: Apache-2.0</li> +<li>🏷️ Latest Release: v4.3.3 (2024-08-23)</li> +<li>🤖 AI-Assisted: This project was partially created with the help of generative AI</li> +</ul><br /> +<br /> +<a href='showcase/dtail/image-1.png'><img alt='dtail screenshot' title='dtail screenshot' src='showcase/dtail/image-1.png' /></a><br /> +<br /> +<span>DTail is a distributed log processing system written in Go that allows DevOps engineers to tail, cat, and grep log files across thousands of servers concurrently. It provides secure access through SSH authentication and respects UNIX file system permissions, making it ideal for enterprise environments where log analysis needs to scale horizontally across large server fleets. The tool supports advanced features like compressed file handling (gzip/zstd) and distributed MapReduce aggregations for complex log analytics.</span><br /> +<br /> +<a href='showcase/dtail/image-2.gif'><img alt='dtail screenshot' title='dtail screenshot' src='showcase/dtail/image-2.gif' /></a><br /> +<br /> +<span>The system uses a client-server architecture where dtail servers run on target machines (listening on port 2222) and clients connect to multiple servers simultaneously. It can also operate in serverless mode for local operations. The implementation leverages SSH for secure communication, includes sophisticated connection throttling and resource management, and provides specialized tools (dcat, dgrep, dmap) for different log processing tasks. The MapReduce functionality supports SQL-like queries with server-side local aggregation and client-side final aggregation, enabling powerful distributed analytics across log data.</span><br /> +<br /> +<a class='textlink' href='https://codeberg.org/snonux/dtail'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/dtail'>View on GitHub</a><br /> +<br /> +<span>---</span><br /> +<br /> <h3 style='display: inline' id='wireguardmeshgenerator'>wireguardmeshgenerator</h3><br /> <br /> <ul> @@ -289,7 +289,7 @@ <li>📈 Lines of Code: 396</li> <li>📄 Lines of Documentation: 24</li> <li>📅 Development Period: 2025-04-18 to 2025-05-11</li> -<li>🔥 Recent Activity: 85.0 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 94.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v1.0.0 (2025-05-11)</li> </ul><br /> @@ -312,7 +312,7 @@ <li>📈 Lines of Code: 25762</li> <li>📄 Lines of Documentation: 3101</li> <li>📅 Development Period: 2008-05-15 to 2025-06-27</li> -<li>🔥 Recent Activity: 98.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 107.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> <li>🤖 AI-Assisted: This project was partially created with the help of generative AI</li> @@ -338,7 +338,7 @@ <li>📈 Lines of Code: 33</li> <li>📄 Lines of Documentation: 3</li> <li>📅 Development Period: 2025-04-03 to 2025-04-03</li> -<li>🔥 Recent Activity: 110.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 120.3 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -361,7 +361,7 @@ <li>📈 Lines of Code: 3967</li> <li>📄 Lines of Documentation: 324</li> <li>📅 Development Period: 2024-05-04 to 2025-07-12</li> -<li>🔥 Recent Activity: 124.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 133.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v1.0.0 (2025-03-04)</li> </ul><br /> @@ -388,7 +388,7 @@ <li>📈 Lines of Code: 1586</li> <li>📄 Lines of Documentation: 154</li> <li>📅 Development Period: 2023-01-02 to 2025-07-12</li> -<li>🔥 Recent Activity: 131.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 141.3 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v0.1.0 (2025-07-12)</li> </ul><br /> @@ -411,7 +411,7 @@ <li>📈 Lines of Code: 1373</li> <li>📄 Lines of Documentation: 48</li> <li>📅 Development Period: 2024-12-05 to 2025-02-28</li> -<li>🔥 Recent Activity: 151.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 161.1 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -434,7 +434,7 @@ <li>📈 Lines of Code: 2268</li> <li>📄 Lines of Documentation: 1180</li> <li>📅 Development Period: 2021-05-21 to 2025-07-09</li> -<li>🔥 Recent Activity: 214.0 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 223.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: GPL-3.0</li> <li>🏷️ Latest Release: 3.0.0 (2024-10-01)</li> </ul><br /> @@ -457,7 +457,7 @@ <li>📈 Lines of Code: 917</li> <li>📄 Lines of Documentation: 33</li> <li>📅 Development Period: 2024-01-20 to 2025-07-06</li> -<li>🔥 Recent Activity: 461.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 471.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: MIT</li> <li>🏷️ Latest Release: v0.0.3 (2025-07-06)</li> </ul><br /> @@ -484,7 +484,7 @@ <li>📈 Lines of Code: 12</li> <li>📄 Lines of Documentation: 3</li> <li>📅 Development Period: 2024-03-24 to 2024-03-24</li> -<li>🔥 Recent Activity: 485.4 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 494.9 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -498,6 +498,29 @@ <br /> <span>---</span><br /> <br /> +<h3 style='display: inline' id='docker-anki-sync-server'>docker-anki-sync-server</h3><br /> +<br /> +<ul> +<li>💻 Languages: Docker (54.5%), Make (45.5%)</li> +<li>📚 Documentation: Markdown (100.0%)</li> +<li>📊 Commits: 4</li> +<li>📈 Lines of Code: 33</li> +<li>📄 Lines of Documentation: 3</li> +<li>📅 Development Period: 2023-08-13 to 2025-07-31</li> +<li>🔥 Recent Activity: 503.9 days (avg. age of last 42 commits)</li> +<li>⚖️ License: MIT</li> +<li>🧪 Status: Experimental (no releases yet)</li> +</ul><br /> +<br /> +<span>This project is a Docker containerization of the Anki sync server, designed to provide a self-hosted synchronization service for Anki flashcard applications. Anki is a popular spaced repetition learning tool, and this project allows users to run their own sync server instead of relying on AnkiWeb's hosted service, giving them full control over their data privacy and synchronization infrastructure.</span><br /> +<br /> +<span>The implementation is built using a Rocky Linux base image with Python 3.9, and it integrates the community-maintained <span class='inlinecode'>anki-sync-server</span> project. The Dockerfile:dockerfile:1-19 sets up the environment by installing dependencies, configuring data paths for collections and authentication databases to persist in <span class='inlinecode'>/data</span>, and running the service under a dedicated user for security. The Makefile:makefile:1-12 provides build automation that clones the upstream anki-sync-server repository and includes AWS ECR deployment capabilities for cloud hosting. This containerized approach makes it easy to deploy and manage an Anki sync server across different environments while maintaining data persistence through volume mounts.</span><br /> +<br /> +<a class='textlink' href='https://codeberg.org/snonux/docker-anki-sync-server'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/docker-anki-sync-server'>View on GitHub</a><br /> +<br /> +<span>---</span><br /> +<br /> <h3 style='display: inline' id='terraform'>terraform</h3><br /> <br /> <ul> @@ -507,7 +530,7 @@ <li>📈 Lines of Code: 2850</li> <li>📄 Lines of Documentation: 52</li> <li>📅 Development Period: 2023-08-27 to 2025-04-05</li> -<li>🔥 Recent Activity: 515.4 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 524.9 days (avg. age of last 42 commits)</li> <li>⚖️ License: MIT</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -530,7 +553,7 @@ <li>📈 Lines of Code: 1096</li> <li>📄 Lines of Documentation: 287</li> <li>📅 Development Period: 2023-04-17 to 2025-06-12</li> -<li>🔥 Recent Activity: 528.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 537.7 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v1.1.0 (2024-05-03)</li> <li>🤖 AI-Assisted: This project was partially created with the help of generative AI</li> @@ -556,7 +579,7 @@ <li>📈 Lines of Code: 32</li> <li>📄 Lines of Documentation: 3</li> <li>📅 Development Period: 2023-12-31 to 2023-12-31</li> -<li>🔥 Recent Activity: 569.0 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 578.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -570,29 +593,6 @@ <br /> <span>---</span><br /> <br /> -<h3 style='display: inline' id='docker-anki-sync-server'>docker-anki-sync-server</h3><br /> -<br /> -<ul> -<li>💻 Languages: Docker (62.1%), Make (37.9%)</li> -<li>📚 Documentation: Markdown (100.0%)</li> -<li>📊 Commits: 3</li> -<li>📈 Lines of Code: 29</li> -<li>📄 Lines of Documentation: 3</li> -<li>📅 Development Period: 2023-08-13 to 2024-01-01</li> -<li>🔥 Recent Activity: 662.2 days (avg. age of last 42 commits)</li> -<li>⚖️ License: MIT</li> -<li>🧪 Status: Experimental (no releases yet)</li> -</ul><br /> -<br /> -<span>This project is a Docker containerization of the Anki sync server, designed to provide a self-hosted synchronization service for Anki flashcard applications. Anki is a popular spaced repetition learning tool, and this project allows users to run their own sync server instead of relying on AnkiWeb's hosted service, giving them full control over their data privacy and synchronization infrastructure.</span><br /> -<br /> -<span>The implementation is built using a Rocky Linux base image with Python 3.9, and it integrates the community-maintained <span class='inlinecode'>anki-sync-server</span> project. The Dockerfile:dockerfile:1-19 sets up the environment by installing dependencies, configuring data paths for collections and authentication databases to persist in <span class='inlinecode'>/data</span>, and running the service under a dedicated user for security. The Makefile:makefile:1-12 provides build automation that clones the upstream anki-sync-server repository and includes AWS ECR deployment capabilities for cloud hosting. This containerized approach makes it easy to deploy and manage an Anki sync server across different environments while maintaining data persistence through volume mounts.</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/docker-anki-sync-server'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/docker-anki-sync-server'>View on GitHub</a><br /> -<br /> -<span>---</span><br /> -<br /> <h3 style='display: inline' id='gorum'>gorum</h3><br /> <br /> <ul> @@ -602,7 +602,7 @@ <li>📈 Lines of Code: 1525</li> <li>📄 Lines of Documentation: 15</li> <li>📅 Development Period: 2023-04-17 to 2023-11-19</li> -<li>🔥 Recent Activity: 714.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 723.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -616,6 +616,29 @@ <br /> <span>---</span><br /> <br /> +<h3 style='display: inline' id='guprecords'>guprecords</h3><br /> +<br /> +<ul> +<li>💻 Languages: Raku (100.0%)</li> +<li>📚 Documentation: Markdown (100.0%)</li> +<li>📊 Commits: 95</li> +<li>📈 Lines of Code: 312</li> +<li>📄 Lines of Documentation: 416</li> +<li>📅 Development Period: 2013-03-22 to 2025-05-18</li> +<li>🔥 Recent Activity: 773.8 days (avg. age of last 42 commits)</li> +<li>⚖️ License: No license found</li> +<li>🏷️ Latest Release: v1.0.0 (2023-04-29)</li> +</ul><br /> +<br /> +<span>GupRecords is a Raku-based system administration tool that analyzes and reports on system uptime statistics across multiple hosts. It processes raw uptime records from various systems and generates formatted reports showing the top-performing hosts or operating systems based on metrics like uptime, boot count, downtime, and calculated meta-scores.</span><br /> +<br /> +<span>The tool is implemented with a clean object-oriented architecture featuring an Aggregator class that parses record files, Host and OS Aggregate classes that store statistics, and Reporter classes that generate formatted tables. It supports multiple analysis categories (host, OS, OS-major, uname) and various sorting criteria including uptime duration, boot frequency, system lifespan, and downtime. The formatted output includes visual indicators for active systems and provides both duration-based and numerical metrics in a structured table format, making it useful for system administrators to quickly identify the most reliable systems in their infrastructure.</span><br /> +<br /> +<a class='textlink' href='https://codeberg.org/snonux/guprecords'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/guprecords'>View on GitHub</a><br /> +<br /> +<span>---</span><br /> +<br /> <h3 style='display: inline' id='randomjournalpage'>randomjournalpage</h3><br /> <br /> <ul> @@ -625,7 +648,7 @@ <li>📈 Lines of Code: 51</li> <li>📄 Lines of Documentation: 26</li> <li>📅 Development Period: 2022-06-02 to 2024-04-20</li> -<li>🔥 Recent Activity: 779.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 788.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -649,7 +672,7 @@ <li>📈 Lines of Code: 41</li> <li>📄 Lines of Documentation: 17</li> <li>📅 Development Period: 2020-01-30 to 2025-04-30</li> -<li>🔥 Recent Activity: 1072.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1082.1 days (avg. age of last 42 commits)</li> <li>⚖️ License: GPL-3.0</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -672,7 +695,7 @@ <li>📈 Lines of Code: 342</li> <li>📄 Lines of Documentation: 39</li> <li>📅 Development Period: 2011-11-19 to 2022-04-02</li> -<li>🔥 Recent Activity: 1292.2 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1301.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.5.0 (2022-02-21)</li> </ul><br /> @@ -696,7 +719,7 @@ <li>📈 Lines of Code: 1728</li> <li>📄 Lines of Documentation: 18</li> <li>📅 Development Period: 2020-07-12 to 2023-04-09</li> -<li>🔥 Recent Activity: 1443.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1452.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -720,7 +743,7 @@ <li>📈 Lines of Code: 671</li> <li>📄 Lines of Documentation: 19</li> <li>📅 Development Period: 2018-05-26 to 2025-01-21</li> -<li>🔥 Recent Activity: 1445.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1454.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -740,11 +763,11 @@ <br /> <ul> <li>📚 Documentation: Markdown (100.0%)</li> -<li>📊 Commits: 2949</li> +<li>📊 Commits: 2972</li> <li>📈 Lines of Code: 0</li> <li>📄 Lines of Documentation: 23</li> <li>📅 Development Period: 2021-05-21 to 2022-04-02</li> -<li>🔥 Recent Activity: 1458.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1468.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -768,7 +791,7 @@ <li>📈 Lines of Code: 51</li> <li>📄 Lines of Documentation: 69</li> <li>📅 Development Period: 2014-03-24 to 2022-04-23</li> -<li>🔥 Recent Activity: 1924.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 1933.7 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -783,28 +806,6 @@ <br /> <span>---</span><br /> <br /> -<h3 style='display: inline' id='guprecords'>guprecords</h3><br /> -<br /> -<ul> -<li>💻 Languages: Raku (100.0%)</li> -<li>📊 Commits: 95</li> -<li>📈 Lines of Code: 195</li> -<li>📅 Development Period: 2013-03-22 to 2023-03-09</li> -<li>🔥 Recent Activity: 2139.4 days (avg. age of last 42 commits)</li> -<li>⚖️ License: No license found</li> -<li>🏷️ Latest Release: v1.0.0 (2023-04-29)</li> -</ul><br /> -<span>⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.</span><br /> -<br /> -<span>GupRecords is a Raku-based system administration tool that analyzes and reports on system uptime statistics across multiple hosts. It processes raw uptime records from various systems and generates formatted reports showing the top-performing hosts or operating systems based on metrics like uptime, boot count, downtime, and calculated meta-scores.</span><br /> -<br /> -<span>The tool is implemented with a clean object-oriented architecture featuring an Aggregator class that parses record files, Host and OS Aggregate classes that store statistics, and Reporter classes that generate formatted tables. It supports multiple analysis categories (host, OS, OS-major, uname) and various sorting criteria including uptime duration, boot frequency, system lifespan, and downtime. The formatted output includes visual indicators for active systems and provides both duration-based and numerical metrics in a structured table format, making it useful for system administrators to quickly identify the most reliable systems in their infrastructure.</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/guprecords'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/guprecords'>View on GitHub</a><br /> -<br /> -<span>---</span><br /> -<br /> <h3 style='display: inline' id='ioriot'>ioriot</h3><br /> <br /> <ul> @@ -814,7 +815,7 @@ <li>📈 Lines of Code: 12420</li> <li>📄 Lines of Documentation: 610</li> <li>📅 Development Period: 2018-03-01 to 2020-01-22</li> -<li>🔥 Recent Activity: 2465.8 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 2475.3 days (avg. age of last 42 commits)</li> <li>⚖️ License: Apache-2.0</li> <li>🏷️ Latest Release: 0.5.1 (2019-01-04)</li> </ul><br /> @@ -840,7 +841,7 @@ <li>📈 Lines of Code: 919</li> <li>📄 Lines of Documentation: 12</li> <li>📅 Development Period: 2015-01-02 to 2021-11-04</li> -<li>🔥 Recent Activity: 2974.5 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 2984.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 1.1.3 (2015-01-02)</li> </ul><br /> @@ -864,7 +865,7 @@ <li>📈 Lines of Code: 18</li> <li>📄 Lines of Documentation: 49</li> <li>📅 Development Period: 2014-03-24 to 2021-11-05</li> -<li>🔥 Recent Activity: 3210.4 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3219.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -888,7 +889,7 @@ <li>📈 Lines of Code: 5360</li> <li>📄 Lines of Documentation: 789</li> <li>📅 Development Period: 2015-01-02 to 2021-11-05</li> -<li>🔥 Recent Activity: 3477.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3486.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 1.0.1 (2015-01-02)</li> </ul><br /> @@ -912,7 +913,7 @@ <li>📈 Lines of Code: 273</li> <li>📄 Lines of Documentation: 32</li> <li>📅 Development Period: 2015-09-29 to 2021-11-05</li> -<li>🔥 Recent Activity: 3481.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3490.7 days (avg. age of last 42 commits)</li> <li>⚖️ License: Apache-2.0</li> <li>🏷️ Latest Release: 0 (2015-10-26)</li> </ul><br /> @@ -936,7 +937,7 @@ <li>📈 Lines of Code: 1839</li> <li>📄 Lines of Documentation: 412</li> <li>📅 Development Period: 2015-01-02 to 2021-11-05</li> -<li>🔥 Recent Activity: 3560.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3570.3 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 1.0.2 (2015-01-02)</li> </ul><br /> @@ -955,12 +956,12 @@ <br /> <ul> <li>💻 Languages: Go (98.0%), Make (2.0%)</li> -<li>📚 Documentation: Text (50.0%), Markdown (50.0%)</li> +<li>📚 Documentation: Markdown (50.0%), Text (50.0%)</li> <li>📊 Commits: 57</li> <li>📈 Lines of Code: 499</li> <li>📄 Lines of Documentation: 8</li> <li>📅 Development Period: 2015-05-24 to 2021-11-03</li> -<li>🔥 Recent Activity: 3571.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3581.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.1 (2015-06-01)</li> </ul><br /> @@ -982,7 +983,7 @@ <li>📊 Commits: 670</li> <li>📈 Lines of Code: 1675</li> <li>📅 Development Period: 2011-03-06 to 2018-12-22</li> -<li>🔥 Recent Activity: 3627.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3636.7 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v1.0.0 (2018-12-22)</li> </ul><br /> @@ -1008,7 +1009,7 @@ <li>📈 Lines of Code: 88</li> <li>📄 Lines of Documentation: 148</li> <li>📅 Development Period: 2015-06-18 to 2015-12-05</li> -<li>🔥 Recent Activity: 3675.4 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3684.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -1034,7 +1035,7 @@ <li>📈 Lines of Code: 1681</li> <li>📄 Lines of Documentation: 539</li> <li>📅 Development Period: 2014-03-10 to 2021-11-03</li> -<li>🔥 Recent Activity: 3953.4 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 3962.8 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 1.0.2 (2014-11-17)</li> </ul><br /> @@ -1058,7 +1059,7 @@ <li>📈 Lines of Code: 65</li> <li>📄 Lines of Documentation: 228</li> <li>📅 Development Period: 2013-03-22 to 2021-11-04</li> -<li>🔥 Recent Activity: 4007.8 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4017.2 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.0.0.0 (2013-03-22)</li> </ul><br /> @@ -1082,7 +1083,7 @@ <li>📈 Lines of Code: 136</li> <li>📄 Lines of Documentation: 96</li> <li>📅 Development Period: 2013-03-22 to 2021-11-05</li> -<li>🔥 Recent Activity: 4020.8 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4030.2 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.2.0 (2014-07-05)</li> </ul><br /> @@ -1106,7 +1107,7 @@ <li>📈 Lines of Code: 134</li> <li>📄 Lines of Documentation: 106</li> <li>📅 Development Period: 2013-03-22 to 2021-11-05</li> -<li>🔥 Recent Activity: 4028.3 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4037.7 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.1.5 (2014-06-22)</li> </ul><br /> @@ -1130,7 +1131,7 @@ <li>📈 Lines of Code: 493</li> <li>📄 Lines of Documentation: 26</li> <li>📅 Development Period: 2009-09-27 to 2021-11-02</li> -<li>🔥 Recent Activity: 4071.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4081.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.9.3 (2014-06-14)</li> </ul><br /> @@ -1154,7 +1155,7 @@ <li>📈 Lines of Code: 286</li> <li>📄 Lines of Documentation: 144</li> <li>📅 Development Period: 2013-03-22 to 2021-11-05</li> -<li>🔥 Recent Activity: 4076.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4086.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.4.3 (2014-06-16)</li> </ul><br /> @@ -1178,7 +1179,7 @@ <li>📈 Lines of Code: 191</li> <li>📄 Lines of Documentation: 8</li> <li>📅 Development Period: 2014-03-24 to 2014-03-24</li> -<li>🔥 Recent Activity: 4137.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4147.3 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -1200,7 +1201,7 @@ <li>📊 Commits: 7</li> <li>📈 Lines of Code: 80</li> <li>📅 Development Period: 2011-07-09 to 2015-01-13</li> -<li>🔥 Recent Activity: 4217.9 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4227.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -1224,7 +1225,7 @@ <li>📈 Lines of Code: 124</li> <li>📄 Lines of Documentation: 75</li> <li>📅 Development Period: 2010-11-05 to 2021-11-05</li> -<li>🔥 Recent Activity: 4258.6 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4268.0 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 1.0.2 (2014-06-22)</li> </ul><br /> @@ -1248,7 +1249,7 @@ <li>📈 Lines of Code: 1828</li> <li>📄 Lines of Documentation: 100</li> <li>📅 Development Period: 2010-11-05 to 2015-05-23</li> -<li>🔥 Recent Activity: 4288.7 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4298.1 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: 0.7.5 (2014-06-22)</li> </ul><br /> @@ -1270,7 +1271,7 @@ <li>📊 Commits: 110</li> <li>📈 Lines of Code: 614</li> <li>📅 Development Period: 2011-02-05 to 2022-04-21</li> -<li>🔥 Recent Activity: 4338.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4347.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v1.4 (2022-04-29)</li> </ul><br /> @@ -1294,7 +1295,7 @@ <li>📈 Lines of Code: 122</li> <li>📄 Lines of Documentation: 10</li> <li>📅 Development Period: 2011-01-27 to 2014-06-22</li> -<li>🔥 Recent Activity: 4669.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4678.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> <li>🏷️ Latest Release: v0.2 (2011-01-27)</li> </ul><br /> @@ -1318,7 +1319,7 @@ <li>📈 Lines of Code: 720</li> <li>📄 Lines of Documentation: 6</li> <li>📅 Development Period: 2008-06-21 to 2021-11-03</li> -<li>🔥 Recent Activity: 4731.8 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 4741.2 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🏷️ Latest Release: v0.3 (2009-02-08)</li> </ul><br /> @@ -1335,6 +1336,32 @@ <br /> <span>---</span><br /> <br /> +<h3 style='display: inline' id='ychat'>ychat</h3><br /> +<br /> +<ul> +<li>💻 Languages: C++ (62.8%), C/C++ (27.1%), HTML (3.1%), Config (2.5%), Perl (1.9%), Shell (1.9%), Make (0.4%), CSS (0.2%)</li> +<li>📚 Documentation: Text (100.0%)</li> +<li>📊 Commits: 67</li> +<li>📈 Lines of Code: 27104</li> +<li>📄 Lines of Documentation: 109</li> +<li>📅 Development Period: 2008-05-15 to 2014-07-01</li> +<li>🔥 Recent Activity: 5342.2 days (avg. age of last 42 commits)</li> +<li>⚖️ License: GPL-2.0</li> +<li>🏷️ Latest Release: yhttpd-0.7.2 (2013-04-06)</li> +</ul><br /> +<span>⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.</span><br /> +<br /> +<span>Based on my analysis of the codebase, here's a concise summary of the yChat project:</span><br /> +<br /> +<span>**yChat** is a web-based chat server written in C++ that functions as a standalone HTTP server without requiring external web server dependencies. It allows users to participate in multi-room chat sessions using standard web browsers, with no special client software needed. The system supports user registration, authentication via session IDs, customizable HTML templates, and multi-language support through XML configuration files.</span><br /> +<br /> +<span>The architecture is built around several key managers: a socket manager for handling HTTP connections, a chat manager for core functionality, an HTML template manager for dynamic content generation, and a modular system supporting dynamically loadable command modules. It uses hash maps for efficient O(1) data retrieval, POSIX threads for concurrent request handling, and includes advanced features like SSL support, MySQL database integration, garbage collection for memory management, and comprehensive logging. The codebase also includes related projects like yhttpd (a lightweight HTTP server) and ycurses (a terminal interface library), making it a comprehensive communication platform designed for performance and extensibility.</span><br /> +<br /> +<a class='textlink' href='https://codeberg.org/snonux/ychat'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/ychat'>View on GitHub</a><br /> +<br /> +<span>---</span><br /> +<br /> <h3 style='display: inline' id='netcalendar'>netcalendar</h3><br /> <br /> <ul> @@ -1344,7 +1371,7 @@ <li>📈 Lines of Code: 17380</li> <li>📄 Lines of Documentation: 947</li> <li>📅 Development Period: 2009-02-07 to 2021-05-01</li> -<li>🔥 Recent Activity: 5362.5 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 5371.9 days (avg. age of last 42 commits)</li> <li>⚖️ License: GPL-2.0</li> <li>🏷️ Latest Release: v0.1 (2009-02-08)</li> </ul><br /> @@ -1370,7 +1397,7 @@ <li>📊 Commits: 80</li> <li>📈 Lines of Code: 601</li> <li>📅 Development Period: 2009-11-22 to 2011-10-17</li> -<li>🔥 Recent Activity: 5458.1 days (avg. age of last 42 commits)</li> +<li>🔥 Recent Activity: 5467.6 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -1385,41 +1412,39 @@ <br /> <span>---</span><br /> <br /> -<h3 style='display: inline' id='ychat'>ychat</h3><br /> +<h3 style='display: inline' id='vs-sim'>vs-sim</h3><br /> <br /> <ul> -<li>📚 Documentation: Text (100.0%)</li> -<li>📊 Commits: 67</li> +<li>📚 Documentation: Markdown (100.0%)</li> +<li>📊 Commits: 411</li> <li>📈 Lines of Code: 0</li> -<li>📄 Lines of Documentation: 9</li> -<li>📅 Development Period: 2008-05-15 to 2013-12-15</li> -<li>🔥 Recent Activity: 5597.9 days (avg. age of last 42 commits)</li> +<li>📄 Lines of Documentation: 7</li> +<li>📅 Development Period: 2008-05-15 to 2015-05-23</li> +<li>🔥 Recent Activity: 5828.5 days (avg. age of last 42 commits)</li> <li>⚖️ License: No license found</li> -<li>🏷️ Latest Release: yhttpd-0.7.2 (2013-04-06)</li> +<li>🏷️ Latest Release: v1.0 (2008-08-24)</li> </ul><br /> <span>⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.</span><br /> <br /> -<span>Based on my analysis of the codebase, here's a concise summary of the yChat project:</span><br /> -<br /> -<span>**yChat** is a web-based chat server written in C++ that functions as a standalone HTTP server without requiring external web server dependencies. It allows users to participate in multi-room chat sessions using standard web browsers, with no special client software needed. The system supports user registration, authentication via session IDs, customizable HTML templates, and multi-language support through XML configuration files.</span><br /> +<span>VS-Sim is an open-source distributed systems simulator written in Java, developed as a diploma thesis at Aachen University of Applied Sciences. It provides a visual environment for simulating and understanding distributed system algorithms including consensus protocols (one-phase/two-phase commit), time synchronization (Berkeley, Lamport, vector clocks), and communication patterns (multicast, broadcast, reliable messaging). The simulator is useful for educational purposes, allowing students and researchers to visualize complex distributed system concepts through interactive simulations.</span><br /> <br /> -<span>The architecture is built around several key managers: a socket manager for handling HTTP connections, a chat manager for core functionality, an HTML template manager for dynamic content generation, and a modular system supporting dynamically loadable command modules. It uses hash maps for efficient O(1) data retrieval, POSIX threads for concurrent request handling, and includes advanced features like SSL support, MySQL database integration, garbage collection for memory management, and comprehensive logging. The codebase also includes related projects like yhttpd (a lightweight HTTP server) and ycurses (a terminal interface library), making it a comprehensive communication platform designed for performance and extensibility.</span><br /> +<span>The implementation features a modular architecture with separate packages for core processes, events, protocols, and visualization. It includes pre-built protocol implementations, a GUI-based simulator with start/pause/reset controls, serialization support for saving simulations, and comprehensive time modeling systems. The codebase demonstrates clean separation of concerns with abstract base classes for extensibility and a plugin-like protocol system for easy addition of new distributed algorithms.</span><br /> <br /> -<a class='textlink' href='https://codeberg.org/snonux/ychat'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/ychat'>View on GitHub</a><br /> +<a class='textlink' href='https://codeberg.org/snonux/vs-sim'>View on Codeberg</a><br /> +<a class='textlink' href='https://github.com/snonux/vs-sim'>View on GitHub</a><br /> <br /> <span>---</span><br /> <br /> <h3 style='display: inline' id='fype'>fype</h3><br /> <br /> <ul> -<li>💻 Languages: C (72.1%), C/C++ (20.7%), HTML (5.7%), Make (1.5%)</li> -<li>📚 Documentation: Text (71.3%), LaTeX (28.7%)</li> +<li>💻 Languages: C (71.3%), C/C++ (20.6%), HTML (6.6%), Make (1.5%)</li> +<li>📚 Documentation: Text (60.2%), LaTeX (39.8%)</li> <li>📊 Commits: 99</li> -<li>📈 Lines of Code: 10196</li> -<li>📄 Lines of Documentation: 1741</li> -<li>📅 Development Period: 2008-05-15 to 2021-11-03</li> -<li>🔥 Recent Activity: 5619.9 days (avg. age of last 42 commits)</li> +<li>📈 Lines of Code: 8906</li> +<li>📄 Lines of Documentation: 1431</li> +<li>📅 Development Period: 2008-05-15 to 2021-04-29</li> +<li>🔥 Recent Activity: 5874.4 days (avg. age of last 42 commits)</li> <li>⚖️ License: Custom License</li> <li>🧪 Status: Experimental (no releases yet)</li> </ul><br /> @@ -1431,29 +1456,6 @@ <br /> <a class='textlink' href='https://codeberg.org/snonux/fype'>View on Codeberg</a><br /> <a class='textlink' href='https://github.com/snonux/fype'>View on GitHub</a><br /> -<br /> -<span>---</span><br /> -<br /> -<h3 style='display: inline' id='vs-sim'>vs-sim</h3><br /> -<br /> -<ul> -<li>📚 Documentation: Markdown (100.0%)</li> -<li>📊 Commits: 411</li> -<li>📈 Lines of Code: 0</li> -<li>📄 Lines of Documentation: 7</li> -<li>📅 Development Period: 2008-05-15 to 2015-05-23</li> -<li>🔥 Recent Activity: 5819.1 days (avg. age of last 42 commits)</li> -<li>⚖️ License: No license found</li> -<li>🏷️ Latest Release: v1.0 (2008-08-24)</li> -</ul><br /> -<span>⚠️ **Notice**: This project appears to be finished, obsolete, or no longer maintained. Last meaningful activity was over 2 years ago. Use at your own risk.</span><br /> -<br /> -<span>VS-Sim is an open-source distributed systems simulator written in Java, developed as a diploma thesis at Aachen University of Applied Sciences. It provides a visual environment for simulating and understanding distributed system algorithms including consensus protocols (one-phase/two-phase commit), time synchronization (Berkeley, Lamport, vector clocks), and communication patterns (multicast, broadcast, reliable messaging). The simulator is useful for educational purposes, allowing students and researchers to visualize complex distributed system concepts through interactive simulations.</span><br /> -<br /> -<span>The implementation features a modular architecture with separate packages for core processes, events, protocols, and visualization. It includes pre-built protocol implementations, a GUI-based simulator with start/pause/reset controls, serialization support for saving simulations, and comprehensive time modeling systems. The codebase demonstrates clean separation of concerns with abstract base classes for extensibility and a plugin-like protocol system for easy addition of new distributed algorithms.</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/vs-sim'>View on Codeberg</a><br /> -<a class='textlink' href='https://github.com/snonux/vs-sim'>View on GitHub</a><br /> <p class="footer"> Generated with <a href="https://codeberg.org/snonux/gemtexter">Gemtexter 3.0.1-develop</a> | served by <a href="https://www.OpenBSD.org">OpenBSD</a>/<a href="https://man.openbsd.org/relayd.8">relayd(8)</a>+<a href="https://man.openbsd.org/httpd.8">httpd(8)</a> | diff --git a/about/showcase/debroid/image-1.png b/about/showcase/debroid/image-1.png index 84cb8bee..25afb173 100644 --- a/about/showcase/debroid/image-1.png +++ b/about/showcase/debroid/image-1.png @@ -17,6 +17,7 @@ + <head> <meta charset="utf-8"> <link rel="dns-prefetch" href="https://github.githubassets.com"> @@ -35,17 +36,17 @@ <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-primitives-dc7ca6859caf.css" /> - <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-03a65c451725.css" /> - <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/global-8bbd7051486c.css" /> - <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/github-db7b386c190b.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-e11b50dc0d94.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/global-208b03e93e68.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/github-709c905d887a.css" /> - <script type="application/json" id="client-env">{"locale":"en","featureFlags":["alternate_user_config_repo","api_insights_show_missing_data_banner","attestations_filtering","attestations_sorting","client_version_header","code_scanning_security_configuration_ternary_state","codespaces_prebuild_region_target_update","contact_requests_implicit_opt_in","contentful_lp_copilot_extensions","contentful_lp_flex_features","contentful_lp_footnotes","copilot_activity_report","copilot_chat_attach_multiple_images","copilot_chat_floating_sidebar_focus_trap","copilot_chat_group_notifications","copilot_chat_navigable_refs","copilot_chat_vision_in_claude","copilot_chat_vision_skip_thread_create","copilot_chat_wholearea_dd","copilot_custom_copilots_feature_preview","copilot_custom_copilots_images","copilot_duplicate_thread","copilot_free_to_paid_telem","copilot_ftp_hyperspace_upgrade_prompt","copilot_ftp_settings_upgrade","copilot_ftp_upgrade_to_pro_from_models","copilot_ftp_your_copilot_settings","copilot_immersive_draft_issue_template_form_ui","copilot_immersive_structured_model_picker","copilot_no_floating_button","copilot_read_shared_conversation","copilot_spaces_input_menu_select","copilot_spark_allow_empty_commit","copilot_spark_single_user_iteration","copilot_spark_use_billing_headers","copilot_spark_write_iteration_history_to_git","copilot_task_oriented_assistive_prompts","copilot_workbench_connection_reload_banner","copilot_workbench_preview_analytics","copilot_workbench_refresh_on_wsod","copilot_workbench_synthetic_generation","custom_copilots_128k_window","custom_copilots_capi_mode","custom_copilots_file_uploads","direct_to_salesforce","dotcom_chat_client_side_skills","failbot_report_error_react_apps_on_page","ghost_pilot_confidence_truncation_25","ghost_pilot_confidence_truncation_40","insert_before_patch","issue_fields_report_usage","issues_catch_non_json_graphql_response","issues_comment_load_user_settings","issues_label_search_url","issues_preserve_tokens_in_urls","issues_react_blur_item_picker_on_close","issues_react_bots_timeline_pagination","issues_react_create_milestone","issues_react_optimistic_markdown","issues_react_prohibit_title_fallback","issues_react_remove_placeholders","issues_template_picker_redirect","lifecycle_label_name_updates","link_contact_sales_swp_marketo","marketing_pages_search_explore_provider","memex_mwl_filter_field_delimiter","nonreporting_relay_graphql_status_codes","primer_react_select_panel_with_modern_action_list","remove_child_patch","sample_network_conn_type","scheduled_reminders_updated_limits","site_homepage_contentful","site_msbuild_hide_integrations","site_msbuild_launch","site_msbuild_webgl_hero","spark_commit_on_default_branch","spark_sync_repository_after_iteration","swp_enterprise_contact_form","use_paginated_repo_picker_cost_center_form","viewscreen_sandbox","workbench_default_sonnet4","workbench_store_readonly"],"copilotApiOverrideUrl":null}</script> + <script type="application/json" id="client-env">{"locale":"en","featureFlags":["alternate_user_config_repo","api_insights_show_missing_data_banner","attestations_filtering","attestations_sorting","client_version_header","code_scanning_security_configuration_ternary_state","codespaces_prebuild_region_target_update","contact_requests_implicit_opt_in","contentful_lp_copilot_extensions","contentful_lp_flex_features","contentful_lp_footnotes","copilot_chat_attach_multiple_images","copilot_chat_group_notifications","copilot_chat_vision_in_claude","copilot_chat_vision_skip_thread_create","copilot_chat_wholearea_dd","copilot_coding_agent_task_creation_banner","copilot_custom_copilots_feature_preview","copilot_custom_copilots_images","copilot_duplicate_thread","copilot_free_to_paid_telem","copilot_ftp_hyperspace_upgrade_prompt","copilot_ftp_settings_upgrade","copilot_ftp_upgrade_to_pro_from_models","copilot_ftp_your_copilot_settings","copilot_immersive_agent_branch_selection","copilot_immersive_draft_issue_template_form_ui","copilot_immersive_structured_model_picker","copilot_markdown_image_allow_list","copilot_no_floating_button","copilot_read_shared_conversation","copilot_spaces_inline_edit_description","copilot_spaces_input_menu_select","copilot_spaces_upsert_reload_in_background","copilot_spark_allow_empty_commit","copilot_spark_single_user_iteration","copilot_spark_use_billing_headers","copilot_spark_write_iteration_history_to_git","copilot_task_oriented_assistive_prompts","copilot_workbench_agent_seed_tool","copilot_workbench_cache","copilot_workbench_connection_reload_banner","copilot_workbench_preview_analytics","copilot_workbench_ratelimit_fallback","copilot_workbench_refresh_on_wsod","copilot_workbench_synthetic_generation","custom_copilots_128k_window","custom_copilots_capi_mode","custom_copilots_file_uploads","direct_to_salesforce","dotcom_chat_client_side_skills","failbot_report_error_react_apps_on_page","ghost_pilot_confidence_truncation_25","ghost_pilot_confidence_truncation_40","hpc_improve_dom_insertion_observer","insert_before_patch","issue_fields_report_usage","issues_catch_non_json_graphql_response","issues_comment_load_user_settings","issues_label_search_url","issues_preserve_tokens_in_urls","issues_react_blur_item_picker_on_close","issues_react_bots_timeline_pagination","issues_react_create_milestone","issues_react_prohibit_title_fallback","issues_react_remove_placeholders","issues_template_picker_redirect","lifecycle_label_name_updates","link_contact_sales_swp_marketo","marketing_fullstory_sampling","marketing_pages_search_explore_provider","memex_mwl_filter_field_delimiter","nonreporting_relay_graphql_status_codes","primer_react_select_panel_with_modern_action_list","remove_child_patch","sample_network_conn_type","scheduled_reminders_updated_limits","site_homepage_contentful","site_msbuild_hide_integrations","site_msbuild_launch","site_msbuild_webgl_hero","spark_commit_on_default_branch","spark_sync_repository_after_iteration","swp_enterprise_contact_form","use_paginated_repo_picker_cost_center_form","viewscreen_sandbox","workbench_default_sonnet4","workbench_store_readonly"],"copilotApiOverrideUrl":null}</script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/high-contrast-cookie-84a1cb087855.js"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/wp-runtime-5b31aca7228e.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/wp-runtime-b3b4e85b2ffe.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover-fn_js-a8c266e5f126.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_stacktrace-parser_dist_s-1d3d52-babac9434833.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_failbot_failbot_ts-992dcf80dabf.js" defer="defer"></script> @@ -53,26 +54,26 @@ <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_primer_behaviors_dist_esm_index_mjs-c44edfed7f0d.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_selector-observer_dist_index_esm_js-cdf2757bd188.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_relative-time-element_dist_index_js-5913bc24f35d.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_auto-complete-element_dist_index_js-node_modules_github_catalyst_-8e9f78-f826b7d5d2dc.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_text-expander-element_dist_index_js-e50fb7a5fe8c.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_auto-complete-element_dist_index_js-node_modules_github_catalyst_-8e9f78-bd3e08e767f2.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_filter-input-element_dist_index_js-node_modules_github_remote-inp-b5f1d7-514a92c925f0.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_markdown-toolbar-element_dist_index_js-6a8c7d9a08fe.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_file-attachment-element_dist_index_js-node_modules_primer_view-co-f03a40-c631b99b0f08.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/github-elements-01097d9e7528.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/element-registry-df2b2924ed77.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/github-elements-6f8fcdbbf55a.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/element-registry-3a794fd52015.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_braintree_browser-detection_dist_browser-detection_js-node_modules_githu-bb80ec-34c4b68b1dd3.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_lit-html_lit-html_js-b93a87060d31.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_morphdom_dist_morphdom-esm_js-300e8e4e0414.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_turbo_dist_turbo_es2017-esm_js-595819d3686f.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-893f9f-5f044d8dcee3.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_quote-selection_dist_index_js-node_modules_github_session-resume_-c39857-54c022ad5a68.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_quote-selection_dist_index_js-node_modules_github_session-resume_-c39857-68019bebf97d.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_updatable-content_updatable-content_ts-19a9ffc8367b.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_task-list_ts-app_assets_modules_github_sso_ts-ui_packages-900dde-f953ddf42948.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_sticky-scroll-into-view_ts-422e3114b79c.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_sticky-scroll-into-view_ts-c9618dd6662a.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_ajax-error_ts-app_assets_modules_github_behaviors_include-d0d0a6-a7da4270c5f4.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_commenting_edit_ts-app_assets_modules_github_behaviors_ht-83c235-567e0f340e27.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/behaviors-c2c56357c82e.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_delegated-events_dist_index_js-node_modules_github_catalyst_lib_index_js-ea8eaa-9039ec39e74d.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/behaviors-625d7495b728.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_delegated-events_dist_index_js-node_modules_github_catalyst_lib_index_js-ea8eaa-e0c270428781.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/notifications-global-ddd47578369b.js" defer="defer"></script> @@ -83,13 +84,13 @@ <meta name="route-pattern" content="/:user_id/:repository/blob/*name(/*path)" data-turbo-transient> <meta name="route-controller" content="blob" data-turbo-transient> <meta name="route-action" content="show" data-turbo-transient> - <meta name="fetch-nonce" content="v2:d47fecb4-3d31-d9d3-086e-62b3ffabb611"> + <meta name="fetch-nonce" content="v2:de4e9904-c9a2-18ed-49e5-4c4adb6aad5d"> <meta name="current-catalog-service-hash" content="f3abb0cc802f3d7b95fc8762b94bdcb13bf39634c40c357301c4aa1d67a256fb"> - <meta name="request-id" content="9572:19C821:597D27:5BD62D:687FE302" data-pjax-transient="true"/><meta name="html-safe-nonce" content="672da898819b39a4ad6316b1abe6bcf1921e7afb15def32c34bfbab92c740bac" data-pjax-transient="true"/><meta name="visitor-payload" content="eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5NTcyOjE5QzgyMTo1OTdEMjc6NUJENjJEOjY4N0ZFMzAyIiwidmlzaXRvcl9pZCI6Ijc5MDIzMzk3NzE2NjQ0MjU3MzAiLCJyZWdpb25fZWRnZSI6ImZyYSIsInJlZ2lvbl9yZW5kZXIiOiJmcmEifQ==" data-pjax-transient="true"/><meta name="visitor-hmac" content="ccbbb0410f2d5aa794542532c916425107ddb821fb9044fb41226e2a9447a4ad" data-pjax-transient="true"/> + <meta name="request-id" content="8484:352618:6082030:6324830:688C54A6" data-pjax-transient="true"/><meta name="html-safe-nonce" content="1f8e70b22bf73c9d9d9534471d8c7dacbb3dad343b9c977ce09e6970d4ff4e03" data-pjax-transient="true"/><meta name="visitor-payload" content="eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4NDg0OjM1MjYxODo2MDgyMDMwOjYzMjQ4MzA6Njg4QzU0QTYiLCJ2aXNpdG9yX2lkIjoiMjE5MjgzNDk2MTA1MTc2Nzk3NCIsInJlZ2lvbl9lZGdlIjoiZnJhIiwicmVnaW9uX3JlbmRlciI6ImZyYSJ9" data-pjax-transient="true"/><meta name="visitor-hmac" content="165e027b5e00928215277aeb4352b50b89e4660c7512784e91c6c0f0247cb1ff" data-pjax-transient="true"/> @@ -165,10 +166,10 @@ <meta name="expected-hostname" content="github.com"> - <meta http-equiv="x-pjax-version" content="51a72dd0b79a7a53272635e6697a5d48b955bb4d1b319bd3fdc078d568c6fa4f" data-turbo-track="reload"> - <meta http-equiv="x-pjax-csp-version" content="352e51c42d5f5727a7c545752bf34d1f83f40219e7036c6959817149a51651bc" data-turbo-track="reload"> - <meta http-equiv="x-pjax-css-version" content="83f9a94c02d28b6b9d27897e1bf0bb06438da8c3b28dcbfd90a1dba29bcec474" data-turbo-track="reload"> - <meta http-equiv="x-pjax-js-version" content="e821eb5729cb97e4acb513fd7f3e0449220e5a8750f2ae7dd8ddccad363fcb24" data-turbo-track="reload"> + <meta http-equiv="x-pjax-version" content="302402b84113e5d9abef774710e5e63ba404b9dbb594b78fffa17faaebe0d9f7" data-turbo-track="reload"> + <meta http-equiv="x-pjax-csp-version" content="8fba9c9418de26103e6176951dd0c38780be21b972f2019085dee08622fdb843" data-turbo-track="reload"> + <meta http-equiv="x-pjax-css-version" content="b705b14fc1de584a5d763630d9070a4b5c9515cdbd9ae3954bd3dfcbebcb97fc" data-turbo-track="reload"> + <meta http-equiv="x-pjax-js-version" content="50e7aa4b54b36b11d3184207c884fff02f4e9d4402971a261dd8e5dbb5e6f123" data-turbo-track="reload"> <meta name="turbo-cache-control" content="no-preview" data-turbo-transient=""> @@ -192,7 +193,7 @@ <meta name="browser-errors-url" content="https://api.github.com/_private/browser/errors"> - <meta name="release" content="fc7aa1bfae18abaa7ba5063b040f48bb05f727ee"> + <meta name="release" content="c703d700a17ae655ff90620f2b72f3b8fc2fd377"> <meta name="ui-target" content="full"> <link rel="mask-icon" href="https://github.githubassets.com/assets/pinned-octocat-093da3e6fa40.svg" color="#000000"> @@ -220,16 +221,7 @@ <span style="width: 0%;" data-view-component="true" class="Progress-item progress-pjax-loader-bar left-0 top-0 color-bg-accent-emphasis"></span> </span> - <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/primer-react-e408f16c768d.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/react-core-c2c42df71553.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/react-lib-8705026b409a.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/octicons-react-8ed765fdb7a0.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_emotion_is-prop-valid_dist_emotion-is-prop-valid_esm_js-node_modules_emo-b1c483-f0fc35efa8f8.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_cookie_index_js-node_modules_primer_live-region-element_dist_esm_index_j-1ca8f6-89ab81577c38.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_ui-commands_ui-commands_ts-b755d908e0b1.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_document-metadata_document-metadata_ts-ui_packages_hydro-analytics_hydro-analytic-f29230-07417997172c.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/keyboard-shortcuts-dialog-675f9f3d03d4.js" defer="defer"></script> -<link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.09723c367c01d454aecd.module.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.7d2aa1048e3c65679a70.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/keyboard-shortcuts-dialog.f8fba3bd67fe74f9227b.module.css" /> <react-partial @@ -252,7 +244,7 @@ <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_gsap_index_js-028cb2a18f5a.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-94fd67-b0625c39513c.js" defer="defer"></script> +<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-94fd67-9a914372b013.js" defer="defer"></script> <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/sessions-5e9442c22f33.js" defer="defer"></script> <header class="HeaderMktg header-logged-out js-details-container js-header Details f4 py-3" role="banner" data-is-top="true" data-color-mode=light data-light-theme=light data-dark-theme=dark> <h2 class="sr-only">Navigation Menu</h2> @@ -292,15 +284,13 @@ </a> <div class="AppHeader-appearanceSettings"> <react-partial-anchor> - <button data-target="react-partial-anchor.anchor" id="icon-button-68ee0f1c-2df0-4ad4-a46b-87cf5547af14" aria-labelledby="tooltip-c36c9362-97a7-4f75-b572-eb9398a347be" type="button" disabled="disabled" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium AppHeader-button HeaderMenu-link border cursor-wait"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-sliders Button-visual"> + <button data-target="react-partial-anchor.anchor" id="icon-button-ff615d96-8f43-4fa6-84f3-3cf5ebb3b9b3" aria-labelledby="tooltip-d7a03659-3c58-437c-b7e3-2b495110fc8c" type="button" disabled="disabled" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium AppHeader-button HeaderMenu-link border cursor-wait"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-sliders Button-visual"> <path d="M15 2.75a.75.75 0 0 1-.75.75h-4a.75.75 0 0 1 0-1.5h4a.75.75 0 0 1 .75.75Zm-8.5.75v1.25a.75.75 0 0 0 1.5 0v-4a.75.75 0 0 0-1.5 0V2H1.75a.75.75 0 0 0 0 1.5H6.5Zm1.25 5.25a.75.75 0 0 0 0-1.5h-6a.75.75 0 0 0 0 1.5h6ZM15 8a.75.75 0 0 1-.75.75H11.5V10a.75.75 0 1 1-1.5 0V6a.75.75 0 0 1 1.5 0v1.25h2.75A.75.75 0 0 1 15 8Zm-9 5.25v-2a.75.75 0 0 0-1.5 0v1.25H1.75a.75.75 0 0 0 0 1.5H4.5v1.25a.75.75 0 0 0 1.5 0v-2Zm9 0a.75.75 0 0 1-.75.75h-6a.75.75 0 0 1 0-1.5h6a.75.75 0 0 1 .75.75Z"></path> </svg> -</button><tool-tip id="tooltip-c36c9362-97a7-4f75-b572-eb9398a347be" for="icon-button-68ee0f1c-2df0-4ad4-a46b-87cf5547af14" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Appearance settings</tool-tip> +</button><tool-tip id="tooltip-d7a03659-3c58-437c-b7e3-2b495110fc8c" for="icon-button-ff615d96-8f43-4fa6-84f3-3cf5ebb3b9b3" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Appearance settings</tool-tip> <template data-target="react-partial-anchor.template"> - <script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_document-metadata_document-metadata_ts-ui_packages_promise-with-resolvers-polyfil-40d47c-2b0274d4149e.js" defer="defer"></script> -<script crossorigin="anonymous" type="application/javascript" src="https://github.githubassets.com/assets/appearance-settings-5343e9f3bfc4.js" defer="defer"></script> -<link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.09723c367c01d454aecd.module.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.7d2aa1048e3c65679a70.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/appearance-settings.76259b61ecc822265749.module.css" /> <react-partial @@ -356,7 +346,24 @@ </a></li> - + <li> + <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{"location":"navbar","action":"github_spark","context":"product","tag":"link","label":"github_spark_link_product_navbar"}" href="https://github.com/features/spark"> + <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-sparkle-fill color-fg-subtle mr-3"> + <path d="M11.296 1.924c.24-.656 1.168-.656 1.408 0l.717 1.958a11.25 11.25 0 0 0 6.697 6.697l1.958.717c.657.24.657 1.168 0 1.408l-1.958.717a11.25 11.25 0 0 0-6.697 6.697l-.717 1.958c-.24.657-1.168.657-1.408 0l-.717-1.958a11.25 11.25 0 0 0-6.697-6.697l-1.958-.717c-.656-.24-.656-1.168 0-1.408l1.958-.717a11.25 11.25 0 0 0 6.697-6.697l.717-1.958Z"></path> +</svg> + <div> + <div class="color-fg-default h4"> + GitHub Spark + <span class="HeaderMenu-label"> + New + </span> + </div> + Build and deploy intelligent apps + </div> + + +</a></li> + <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{"location":"navbar","action":"github_models","context":"product","tag":"link","label":"github_models_link_product_navbar"}" href="https://github.com/features/models"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-ai-model color-fg-subtle mr-3"> @@ -405,8 +412,16 @@ </a></li> + + </ul> + </div> + </div> + <div class="HeaderMenu-column pl-lg-4 px-lg-4 pb-3 pb-lg-0"> + <div class="border-bottom border-lg-bottom-0 pb-3"> + + <ul class="list-style-none f5" > <li> - <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{"location":"navbar","action":"codespaces","context":"product","tag":"link","label":"codespaces_link_product_navbar"}" href="https://github.com/features/codespaces"> + <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{"location":"navbar","action":"codespaces","context":"product","tag":"link","label":"codespaces_link_product_navbar"}" href="https://github.com/features/codespaces"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-codespaces color-fg-subtle mr-3"> <path d="M3.5 3.75C3.5 2.784 4.284 2 5.25 2h13.5c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 18.75 13H5.25a1.75 1.75 0 0 1-1.75-1.75Zm-2 12c0-.966.784-1.75 1.75-1.75h17.5c.966 0 1.75.784 1.75 1.75v4a1.75 1.75 0 0 1-1.75 1.75H3.25a1.75 1.75 0 0 1-1.75-1.75ZM5.25 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h13.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Zm-2 12a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h17.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25Z"></path><path d="M10 17.75a.75.75 0 0 1 .75-.75h6.5a.75.75 0 0 1 0 1.5h-6.5a.75.75 0 0 1-.75-.75Zm-4 0a.75.75 0 0 1 .75-.75h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1-.75-.75Z"></path> </svg> @@ -420,14 +435,6 @@ </a></li> - </ul> - </div> - </div> - <div class="HeaderMenu-column pl-lg-4 px-lg-4 pb-3 pb-lg-0"> - <div class="border-bottom border-lg-bottom-0 pb-3"> - - <ul class="list-style-none f5" > - <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{"location":"navbar","action":"issues","context":"product","tag":"link","label":"issues_link_product_navbar"}" href="https://github.com/features/issues"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-issue-opened color-fg-subtle mr-3"> @@ -969,7 +976,7 @@ -<qbsearch-input class="search-input" data-scope="owner:buetow" data-custom-scopes-path="/search/custom_scopes" data-delete-custom-scopes-csrf="htO0EFCsT1ezFU9jdcbraa3IIL-mKk5w0_IYitTClsnqPpaPl2UmCdVkzFwAUJOj3vc4YJHzwalxSiksjXCl_g" data-max-custom-scopes="10" data-header-redesign-enabled="false" data-initial-value="" data-blackbird-suggestions-path="/search/suggestions" data-jump-to-suggestions-path="/_graphql/GetSuggestedNavigationDestinations" data-current-repository="" data-current-org="" data-current-owner="" data-logged-in="false" data-copilot-chat-enabled="false" data-nl-search-enabled="false" data-retain-scroll-position="true"> +<qbsearch-input class="search-input" data-scope="owner:buetow" data-custom-scopes-path="/search/custom_scopes" data-delete-custom-scopes-csrf="3vdp5AwXhHP8euQWIXPODT8TjSTzRFFVCa5UXPCYSzl1e70ptJopDS-8YSvuu8-txy9m0uXv7jViDSiYl2BxsA" data-max-custom-scopes="10" data-header-redesign-enabled="false" data-initial-value="" data-blackbird-suggestions-path="/search/suggestions" data-jump-to-suggestions-path="/_graphql/GetSuggestedNavigationDestinations" data-current-repository="" data-current-org="" data-current-owner="" data-logged-in="false" data-copilot-chat-enabled="false" data-nl-search-enabled="false" data-retain-scroll-position="true"> <div class="search-input-container search-with-dialog position-relative d-flex flex-row flex-items-center mr-4 rounded" data-action="click:qbsearch-input#searchInputContainerClicked" @@ -1033,7 +1040,7 @@ ></div> <div class="QueryBuilder-InputWrapper"> <div aria-hidden="true" class="QueryBuilder-Sizer" data-target="query-builder.sizer"></div> - <input id="query-builder-test" name="query-builder-test" value="" autocomplete="off" type="text" role="combobox" spellcheck="false" aria-expanded="false" aria-describedby="validation-1b8eeef5-d421-45ea-83b9-3641f5f2cb84" data-target="query-builder.input" data-action=" + <input id="query-builder-test" name="query-builder-test" value="" autocomplete="off" type="text" role="combobox" spellcheck="false" aria-expanded="false" aria-describedby="validation-c25643dd-b285-46b0-804d-dda7866b2c6c" data-target="query-builder.input" data-action=" input:query-builder#inputChange blur:query-builder#inputBlur keydown:query-builder#inputKeydown @@ -1271,7 +1278,7 @@ tabindex="-1" ></ul> </div> - <div class="FormControl-inlineValidation" id="validation-1b8eeef5-d421-45ea-83b9-3641f5f2cb84" hidden="hidden"> + <div class="FormControl-inlineValidation" id="validation-c25643dd-b285-46b0-804d-dda7866b2c6c" hidden="hidden"> <span class="FormControl-inlineValidation--visual"> <svg aria-hidden="true" height="12" viewBox="0 0 12 12" version="1.1" width="12" data-view-component="true" class="octicon octicon-alert-fill"> <path d="M4.855.708c.5-.896 1.79-.896 2.29 0l4.675 8.351a1.312 1.312 0 0 1-1.146 1.954H1.33A1.313 1.313 0 0 1 .183 9.058ZM7 7V3H5v4Zm-1 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2Z"></path> @@ -1312,7 +1319,7 @@ </div> <scrollable-region data-labelled-by="feedback-dialog-title"> - <div data-view-component="true" class="Overlay-body"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="code-search-feedback-form" data-turbo="false" action="/search/feedback" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="2nOPRlSKWb7Uywo604rRclop3W6pQF80v0um/wZ8CgVYE344z3bFSpLTwKqVsDN6EmW+HLUIsmc/RABNY/MreA==" /> + <div data-view-component="true" class="Overlay-body"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="code-search-feedback-form" data-turbo="false" action="/search/feedback" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="VGYd57JwduszahntPTNgl3S7zUg4n7YHXHpG22/9ohefbIpqI3l8mnFfoEM/tjhwBaXYLCKYLysiob3O3T0QVA==" /> <p>We read every piece of feedback, and take your input very seriously.</p> <textarea name="feedback" class="form-control width-full mb-2" style="height: 120px" id="feedback"></textarea> <input name="include_email" id="include_email" aria-label="Include my email address so I can be contacted" class="form-control mr-2" type="checkbox"> @@ -1350,7 +1357,7 @@ <div data-view-component="true" class="Overlay-body"> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <div hidden class="create-custom-scope-form" data-target="custom-scopes.createCustomScopeForm"> - <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="custom-scopes-dialog-form" data-turbo="false" action="/search/custom_scopes" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="cqOzvjJdsX2tzqv/jaxBYDjkSXFSGZVIGFjjk+CE4DoeOgr9SOzEdonOEDHTfX29foO3+8BRHE7Q+xoCO5I8sw==" /> + <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="custom-scopes-dialog-form" data-turbo="false" action="/search/custom_scopes" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="1aSrfKKdXhmwsd5Fp/bfESK+lwQTwJS1HoOunkUnBCH1B3kN9a44cY0rlvCZq0JgvAlboPCLP8KIt+hvHySesg==" /> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <input type="hidden" id="custom_scope_id" name="custom_scope_id" data-target="custom-scopes.customScopesIdField"> @@ -1368,7 +1375,7 @@ placeholder="github-ruby" required maxlength="50"> - <input type="hidden" data-csrf="true" value="Qqprh7thBvA4MDdU9MQ53jPxWZDJtJutR8XzG3FbJh+y8DlWmftUylwAX3JkKq2/bSfqdH0OCKRHZ8ngXvDDTg==" /> + <input type="hidden" data-csrf="true" value="HR72iGX8002Q+dGEXlPpLWv4uC8YfUl2zyPtRFyEK27tt212YkOk7mh6VbzWJFPLHTJ22JbZ42p0H4wlbxQ+sQ==" /> </auto-check> </div> @@ -1423,7 +1430,7 @@ <h4 data-view-component="true" class="color-fg-default mb-2"> Sign in to GitHub </h4> -<!-- '"` --><!-- </textarea></xmp> --></option></form><form data-turbo="false" action="/session" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="hvkt4uCFwPX+/klRkwYvoeYJnON9NcVagnapFs/r9Kz5qagD+3LdmPfaMxCPTuXAfG7YlymJtOFBmeSwTDzwsw==" /> <input type="hidden" name="add_account" id="add_account" autocomplete="off" class="form-control" /> +<!-- '"` --><!-- </textarea></xmp> --></option></form><form data-turbo="false" action="/session" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="yGeNfNTdei3Eof8qPEq9igR/pxjp/sXRTT51DAhiCz3y7AkNrTB0CUcOsg6GTxXKJMGdDP/YC5gaaGxqKJR5Rw==" /> <input type="hidden" name="add_account" id="add_account" autocomplete="off" class="form-control" /> <label for="login_field"> Username or email address @@ -1445,9 +1452,9 @@ <input type="hidden" name="allow_signup" id="allow_signup" autocomplete="off" class="form-control" /> <input type="hidden" name="client_id" id="client_id" autocomplete="off" class="form-control" /> <input type="hidden" name="integration" id="integration" autocomplete="off" class="form-control" /> -<input class="form-control" type="text" name="required_field_3058" hidden="hidden" /> -<input class="form-control" type="hidden" name="timestamp" value="1753211650707" /> -<input class="form-control" type="hidden" name="timestamp_secret" value="32543e91ad4866bb6cef3d37bcece03f68325d0ca0573d6c0d2540f89e656219" /> +<input class="form-control" type="text" name="required_field_c5cf" hidden="hidden" /> +<input class="form-control" type="hidden" name="timestamp" value="1754027174607" /> +<input class="form-control" type="hidden" name="timestamp_secret" value="ebef3b46b794465db476dbad91f29a7d917664925a433a265226ba7b65831795" /> <input type="submit" name="commit" value="Sign in" class="btn btn-primary btn-block js-sign-in-button" data-disable-with="Signing in…" data-signin-label="Sign in" data-sso-label="Sign in with your identity provider" development="false" disable-emu-sso="false" /> @@ -1474,13 +1481,13 @@ <div class="AppHeader-appearanceSettings"> <react-partial-anchor> - <button data-target="react-partial-anchor.anchor" id="icon-button-df504043-dbe9-43a8-b5c7-c7bde2ae4ca7" aria-labelledby="tooltip-2d42de60-5baa-4ec2-80c0-b94fbb3c6a24" type="button" disabled="disabled" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium AppHeader-button HeaderMenu-link border cursor-wait"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-sliders Button-visual"> + <button data-target="react-partial-anchor.anchor" id="icon-button-bbc6ccab-8317-4646-b954-98124c753273" aria-labelledby="tooltip-fd389bf7-c05f-46ac-a839-7fd1425c852b" type="button" disabled="disabled" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium AppHeader-button HeaderMenu-link border cursor-wait"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-sliders Button-visual"> <path d="M15 2.75a.75.75 0 0 1-.75.75h-4a.75.75 0 0 1 0-1.5h4a.75.75 0 0 1 .75.75Zm-8.5.75v1.25a.75.75 0 0 0 1.5 0v-4a.75.75 0 0 0-1.5 0V2H1.75a.75.75 0 0 0 0 1.5H6.5Zm1.25 5.25a.75.75 0 0 0 0-1.5h-6a.75.75 0 0 0 0 1.5h6ZM15 8a.75.75 0 0 1-.75.75H11.5V10a.75.75 0 1 1-1.5 0V6a.75.75 0 0 1 1.5 0v1.25h2.75A.75.75 0 0 1 15 8Zm-9 5.25v-2a.75.75 0 0 0-1.5 0v1.25H1.75a.75.75 0 0 0 0 1.5H4.5v1.25a.75.75 0 0 0 1.5 0v-2Zm9 0a.75.75 0 0 1-.75.75h-6a.75.75 0 0 1 0-1.5h6a.75.75 0 0 1 .75.75Z"></path> </svg> -</button><tool-tip id="tooltip-2d42de60-5baa-4ec2-80c0-b94fbb3c6a24" for="icon-button-df504043-dbe9-43a8-b5c7-c7bde2ae4ca7" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Appearance settings</tool-tip> +</button><tool-tip id="tooltip-fd389bf7-c05f-46ac-a839-7fd1425c852b" for="icon-button-bbc6ccab-8317-4646-b954-98124c753273" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Appearance settings</tool-tip> <template data-target="react-partial-anchor.template"> - <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.09723c367c01d454aecd.module.css" /> + <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.7d2aa1048e3c65679a70.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/appearance-settings.76259b61ecc822265749.module.css" /> <react-partial @@ -1514,10 +1521,10 @@ <span class="js-stale-session-flash-signed-out" hidden>You signed out in another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <span class="js-stale-session-flash-switched" hidden>You switched accounts on another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> - <button id="icon-button-316344e2-cd2d-4883-927a-2a28f025a90c" aria-labelledby="tooltip-af3c5362-9a79-4d32-9753-ab3ed5f49e30" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium flash-close js-flash-close"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x Button-visual"> + <button id="icon-button-626d60b9-d620-419f-86b9-82df929111c5" aria-labelledby="tooltip-272cce60-85a1-48c7-bdb0-a9a9e4acd378" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium flash-close js-flash-close"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x Button-visual"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> -</button><tool-tip id="tooltip-af3c5362-9a79-4d32-9753-ab3ed5f49e30" for="icon-button-316344e2-cd2d-4883-927a-2a28f025a90c" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Dismiss alert</tool-tip> +</button><tool-tip id="tooltip-272cce60-85a1-48c7-bdb0-a9a9e4acd378" for="icon-button-626d60b9-d620-419f-86b9-82df929111c5" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Dismiss alert</tool-tip> diff --git a/gemfeed/2025-06-22-task-samurai.html b/gemfeed/2025-06-22-task-samurai.html index ffba945a..c6a9f151 100644 --- a/gemfeed/2025-06-22-task-samurai.html +++ b/gemfeed/2025-06-22-task-samurai.html @@ -131,7 +131,7 @@ </ul><br /> <h2 style='display: inline' id='conclusion'>Conclusion</h2><br /> <br /> -<span>Building Task Samurai with agentic coding was a wild ride—rapid feature growth, countless fast fixes, and more merge commits I'd expected. Keep the iterations short (or maybe in my next experiment, much larger, with better and more complete design before generating a single line of code), keep tests and documentation concise, and review and refine for final polish at the end. Even with the bumps along the way, shipping a polished terminal UI in days instead of weeks is a testament to the power of agentic development.</span><br /> +<span>Building Task Samurai with agentic coding was a wild ride—rapid feature growth, countless fast fixes, and more merge commits I'd expected. Keep the iterations short (or maybe in my next experiment, much larger, with better and more complete design before generating a single line of code), keep tests and documentation concise, and review and refine for final polish at the end. Even with the bumps along the way, shipping a terminal UI in days instead of weeks is a neat little showcase vibe coding.</span><br /> <br /> <span>Am I an agentic coding expert now? I don't think so. There are still many things to learn, and the landscape is constantly evolving.</span><br /> <br /> @@ -143,6 +143,11 @@ <br /> <span>E-Mail your comments to <span class='inlinecode'>paul@nospam.buetow.org</span> :-)</span><br /> <br /> +<span>Other related posts are:</span><br /> +<br /> +<a class='textlink' href='./2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 Local LLM for Coding with Ollama</a><br /> +<a class='textlink' href='./2025-06-22-task-samurai.html'>2025-06-22 Task Samurai: An agentic coding learning experiment (You are currently reading this)</a><br /> +<br /> <a class='textlink' href='../'>Back to the main site</a><br /> <p class="footer"> Generated with <a href="https://codeberg.org/snonux/gemtexter">Gemtexter 3.0.1-develop</a> | diff --git a/gemfeed/2025-08-05-local-coding-llm-with-ollama.html b/gemfeed/2025-08-05-local-coding-llm-with-ollama.html new file mode 100644 index 00000000..dc60153d --- /dev/null +++ b/gemfeed/2025-08-05-local-coding-llm-with-ollama.html @@ -0,0 +1,457 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> +<head> +<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +<title>Local LLM for Coding with Ollama</title> +<link rel="shortcut icon" type="image/gif" href="/favicon.ico" /> +<link rel="stylesheet" href="../style.css" /> +<link rel="stylesheet" href="style-override.css" /> +</head> +<body> +<p class="header"> +<a href="https://foo.zone">Home</a> | <a href="https://codeberg.org/snonux/foo.zone/src/branch/content-md/gemfeed/2025-08-05-local-coding-llm-with-ollama.md">Markdown</a> | <a href="gemini://foo.zone/gemfeed/2025-08-05-local-coding-llm-with-ollama.gmi">Gemini</a> +</p> +<h1 style='display: inline' id='local-llm-for-coding-with-ollama'>Local LLM for Coding with Ollama</h1><br /> +<br /> +<span class='quote'>Published at 2025-08-04T16:43:39+03:00</span><br /> +<br /> +<pre> + [::] + _| |_ + / o o \ | + | ∆ | <-- Ollama / \ + | \___/ | / \ + \_______/ LLM --> / 30B \ + | | / Qwen3 \ + /| |\ / Coder \ + /_| |_\_________________/ quantised \ +</pre> +<br /> +<span>With all the AI buzz around coding assistants, and being a bit concerned about being dependent on third-party cloud providers here, I decided to explore the capabilities of local large language models (LLMs) using Ollama. </span><br /> +<br /> +<span>Ollama is a powerful tool that brings local AI capabilities directly to your local hardware. By running AI models locally, you can enjoy the benefits of intelligent assistance without relying on cloud services. This document outlines my initial setup and experiences with Ollama, with a focus on coding tasks and agentic coding.</span><br /> +<br /> +<a class='textlink' href='https://ollama.com/'>https://ollama.com/</a><br /> +<br /> +<h2 style='display: inline' id='why-local-llms'>Why Local LLMs?</h2><br /> +<br /> +<span>Using local AI models through Ollama offers several advantages:</span><br /> +<br /> +<ul> +<li>Data Privacy: Keep your code and data completely private by processing everything locally.</li> +<li>Cost-Effective: Reduce reliance on expensive cloud API calls.</li> +<li>Reliability: Works seamlessly even with spotty internet or offline.</li> +<li>Speed: Avoid network latency and enjoy instant responses while coding. Although I mostly found Ollama slower than commercial LLM providers. However, that may change with the evolution of models and hardware.</li> +</ul><br /> +<h2 style='display: inline' id='hardware-considerations'>Hardware Considerations</h2><br /> +<br /> +<span>Running large language models locally is currently limited by consumer hardware capabilities:</span><br /> +<br /> +<ul> +<li>GPU Memory: Most consumer-grade GPUs (even in 2025) top out at 16–24GB of VRAM, making it challenging to run larger models like the 30B (30 billion) parameter LLMs (they go up to the 100 billion and more).</li> +<li>RAM Constraints: On my MacBook Pro with M3 CPU and 36GB RAM, I chose a 14B model (<span class='inlinecode'>qwen2.5-coder:14b-instruct</span>) as it represents a practical balance between capability and resource requirements.</li> +</ul><br /> +<span>For reference, here are some key points about running large LLMs locally:</span><br /> +<br /> +<ul> +<li>Models larger than 30B: I don't even think about running them locally. One (e.g. from Qwen, Deepseek or Kimi K2) with several hundred billion parameters could match the "performance" of commercial LLMs (Claude Sonnet 4, etc). Still, for personal use, the hardware demands are just too high (or temporarily "rent" it via the public cloud?).</li> +<li>30B models: Require at least 48GB of GPU VRAM for full inference without quantisation. Currently only feasible on high-end professional GPUs (or an Apple-silicone Mac with enough unified RAM).</li> +<li>14B models: Can run with 16-24GB GPU memory (VRAM), suitable for consumer-grade hardware (or use a quantised larger model)</li> +<li>7B-13B models: Best fit for mainstream consumer hardware, requiring minimal VRAM and running smoothly on mid-range GPUs, but with limited capabilities compared to larger models and more hallucinations.</li> +</ul><br /> +<span>The model I'll be mainly using in this blog post (<span class='inlinecode'>qwen2.5-coder:14b-instruct</span>) is particularly interesting as:</span><br /> +<br /> +<ul> +<li><span class='inlinecode'>instruct</span>: Indicates this is the instruction-tuned variant of QWE, optimised for diverse tasks including coding</li> +<li><span class='inlinecode'>coder</span>: Tells me that this model was trained on a mix of code and text data, making it especially effective for programming assistance</li> +</ul><br /> +<a class='textlink' href='https://huggingface.co/Qwen/Qwen2.5-Coder-14B-Instruct'>https://huggingface.co/Qwen/Qwen2.5-Coder-14B-Instruct</a><br /> +<br /> +<span>For general thinking tasks, I found <span class='inlinecode'>deepseek-r1:14b</span> to be useful. For instance, I utilised <span class='inlinecode'>deepseek-r1:14b</span> to format this blog post and correct some English errors, demonstrating its effectiveness in natural language processing tasks. Additionally, it has proven invaluable for adding context and enhancing clarity in technical explanations, all while running locally on the MacBook Pro. Admittedly, it was a lot slower than "just using ChatGPT", but still within minutes. </span><br /> +<br /> +<a class='textlink' href='https://ollama.com/library/deepseek-r1:14b'>https://ollama.com/library/deepseek-r1:14b</a><br /> +<br /> +<span>A quantised (as mentioned above) LLM which has been converted from high-precision connection (typically 16- or 32-bit floating point) representations to lower-precision formats, such as 8-bit integers. This reduces the overall memory footprint of the model, making it significantly smaller and enabling it to run more efficiently on hardware with limited resources or to allow higher throughput on GPUs and CPUs. The benefits of quantisation include reduced storage and faster inference times due to simpler computations and better memory bandwidth utilisation. However, quantisation can introduce a drop in model accuracy because the lower numerical precision means the model cannot represent parameter values as precisely. In some cases, it may lead to instability or unexpected outputs in specific tasks or edge cases.</span><br /> +<br /> +<h2 style='display: inline' id='basic-setup-and-manual-code-prompting'>Basic Setup and Manual Code Prompting</h2><br /> +<br /> +<h3 style='display: inline' id='installing-ollama-and-a-model'>Installing Ollama and a Model</h3><br /> +<br /> +<span>To install Ollama, IIperformed these steps (this assumes that you have already installed Homebrew on your macOS system):</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>brew install ollama +rehash +ollama serve +</pre> +<br /> +<span>Which started up the Ollama server with something like this (the screenshots shows already some requests made):</span><br /> +<br /> +<a href='./local-coding-LLM-with-ollama/ollama-serve.png'><img alt='Ollama serving' title='Ollama serving' src='./local-coding-LLM-with-ollama/ollama-serve.png' /></a><br /> +<br /> +<span>And then, in a new terminal, I pulled the model with:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>ollama pull qwen2.<font color="#000000">5</font>-coder:14b-instruct +</pre> +<br /> +<span>Now, I was ready to go! It wasn't so difficult. Now, let's see how I used this model for coding tasks.</span><br /> +<br /> +<h3 style='display: inline' id='example-usage'>Example Usage</h3><br /> +<br /> +<span>I run the following command to get a Go function for calculating Fibonacci numbers:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>time echo <font color="#808080">"Write a function in golang to print out the Nth fibonacci number, \</font> +<font color="#808080"> only the function without the boilerplate"</font> | ollama run qwen2.<font color="#000000">5</font>-coder:14b-instruct + +Output: + +func fibonacci(n int) int { + <b><u><font color="#000000">if</font></u></b> n <= <font color="#000000">1</font> { + <b><u><font color="#000000">return</font></u></b> n + } + a, b := <font color="#000000">0</font>, <font color="#000000">1</font> + <b><u><font color="#000000">for</font></u></b> i := <font color="#000000">2</font>; i <= n; i++ { + a, b = b, a+b + } + <b><u><font color="#000000">return</font></u></b> b +} + +Execution Metrics: + +Executed <b><u><font color="#000000">in</font></u></b> <font color="#000000">4.90</font> secs fish external + usr time <font color="#000000">15.54</font> millis <font color="#000000">0.31</font> millis <font color="#000000">15.24</font> millis + sys time <font color="#000000">19.68</font> millis <font color="#000000">1.02</font> millis <font color="#000000">18.66</font> millis +</pre> +<br /> +<span class='quote'>Note, after having written this blog post, I tried the same with the newer model <span class='inlinecode'>qwen3-coder:30b-a3b-q4_K_M</span> (which "just" came out, and it's a quantised 30B model), and it was much faster:</span><br /> +<br /> +<pre> +Executed in 1.83 secs fish external + usr time 17.82 millis 4.40 millis 13.42 millis + sys time 17.07 millis 1.57 millis 15.50 millis +</pre> +<br /> +<a class='textlink' href='https://ollama.com/library/qwen3-coder:30b-a3b-q4_K_M'>https://ollama.com/library/qwen3-coder:30b-a3b-q4_K_M</a><br /> +<br /> +<h2 style='display: inline' id='agentic-coding-with-aider'>Agentic Coding with Aider</h2><br /> +<br /> +<h3 style='display: inline' id='installation'>Installation</h3><br /> +<br /> +<span>Aider is a tool that enables agentic coding by leveraging AI models (also local ones, as in our case). While setting up OpenAI Codex and OpenCode with Ollama proved challenging (those tools either didn't know how to work with the "tools" (the capability to execute external commands or to edit files for example) or didn't connect at all to Ollama for some reason), Aider worked smoothly.</span><br /> +<br /> +<span>To get started, the only thing I had to do was to install it via Homebrew, initialise a Git repository, and then start Aider with the Ollama model <span class='inlinecode'>ollama_chat/qwen2.5-coder:14b-instruct</span>:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>brew install aider +mkdir ~/git/aitest && cd ~/git/aitest && git init +aider --model ollama_chat/qwen<font color="#000000">2.5</font>-coder:14b-instruct +</pre> +<br /> +<a class='textlink' href='https://aider.chat'>https://aider.chat</a><br /> +<a class='textlink' href='https://opencode.ai'>https://opencode.ai</a><br /> +<a class='textlink' href='https://github.com/openai/codex'>https://github.com/openai/codex</a><br /> +<br /> +<h3 style='display: inline' id='agentic-coding-prompt'>Agentic coding prompt</h3><br /> +<br /> +<span>This is the prompt I gave:</span><br /> +<br /> +<pre> +Create a Go project with these files: + +* `cmd/aitest/main.go`: CLI entry point +* `internal/version.go`: Version information (0.0.0), should be printed when the + program was started with `-version` flag +* `internal/count.go`: File counting functionality, the program should print out + the number of files in a given subdirectory (the directory is provided as a + command line flag with `-dir`), if none flag is given, no counting should be + done +* `README.md`: Installation and usage instructions +</pre> +<br /> +<span>It then generated something, but did not work out of the box, as it had some issues with the imports and package names. So I had to do some follow-up prompts to fix those issues with something like this:</span><br /> +<br /> +<pre> +* Update import paths to match module name, github.com/yourname/aitest should be + aitest in main.go +* The package names of internal/count.go and internal/version.go should be + internal, and not count and version. +</pre> +<br /> +<a href='./local-coding-LLM-with-ollama/aider-fix-package.png'><img alt='Aider fixing the packages' title='Aider fixing the packages' src='./local-coding-LLM-with-ollama/aider-fix-package.png' /></a><br /> +<br /> +<h3 style='display: inline' id='compilation--execution'>Compilation & Execution</h3><br /> +<br /> +<span>Once done so, the project was ready and I could compile and run it:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>go build cmd/aitest/main.go +./main --help +./main -v +<font color="#000000">0.0</font>.<font color="#000000">0</font> +./main -dir . +Number of files <b><u><font color="#000000">in</font></u></b> directory .: <font color="#000000">4</font> +</pre> +<br /> +<h3 style='display: inline' id='the-code'>The code</h3><br /> +<br /> +<span>The code it generated was simple, but functional. The <span class='inlinecode'>./cmd/aitest/main.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> main + +<b><u><font color="#000000">import</font></u></b> ( + <font color="#808080">"flag"</font> + <font color="#808080">"fmt"</font> + <font color="#808080">"os"</font> + + <font color="#808080">"aitest/internal"</font> +) + +<b><u><font color="#000000">func</font></u></b> main() { + <b><u><font color="#000000">var</font></u></b> versionFlag <b><font color="#000000">bool</font></b> + flag.BoolVar(&versionFlag, <font color="#808080">"v"</font>, false, <font color="#808080">"print version"</font>) + dir := flag.String(<font color="#808080">"dir"</font>, <font color="#808080">""</font>, <font color="#808080">"directory to count files in"</font>) + flag.Parse() + + <b><u><font color="#000000">if</font></u></b> versionFlag { + fmt.Println(internal.GetVersion()) + <b><u><font color="#000000">return</font></u></b> + } + + <b><u><font color="#000000">if</font></u></b> *dir != <font color="#808080">""</font> { + fileCount, err := internal.CountFiles(*dir) + <b><u><font color="#000000">if</font></u></b> err != nil { + fmt.Fprintf(os.Stderr, <font color="#808080">"Error counting files: %v\n"</font>, err) + os.Exit(<font color="#000000">1</font>) + } + fmt.Printf(<font color="#808080">"Number of files in directory %s: %d\n"</font>, *dir, fileCount) + } <b><u><font color="#000000">else</font></u></b> { + fmt.Println(<font color="#808080">"No directory specified. No count given."</font>) + } +} +</pre> +<br /> +<span>The <span class='inlinecode'>./internal/version.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> internal + +<b><u><font color="#000000">var</font></u></b> Version = <font color="#808080">"0.0.0"</font> + +<b><u><font color="#000000">func</font></u></b> GetVersion() <b><font color="#000000">string</font></b> { + <b><u><font color="#000000">return</font></u></b> Version +} +</pre> +<br /> +<span>The <span class='inlinecode'>./internal/count.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> internal + +<b><u><font color="#000000">import</font></u></b> ( + <font color="#808080">"os"</font> +) + +<b><u><font color="#000000">func</font></u></b> CountFiles(dir <b><font color="#000000">string</font></b>) (int, error) { + files, err := os.ReadDir(dir) + <b><u><font color="#000000">if</font></u></b> err != nil { + <b><u><font color="#000000">return</font></u></b> <font color="#000000">0</font>, err + } + + count := <font color="#000000">0</font> + <b><u><font color="#000000">for</font></u></b> _, file := <b><u><font color="#000000">range</font></u></b> files { + <b><u><font color="#000000">if</font></u></b> !file.IsDir() { + count++ + } + } + + <b><u><font color="#000000">return</font></u></b> count, nil +} +</pre> +<br /> +<span>Etc...</span><br /> +<br /> +<span>The code is quite straightforward, especially for generating boilerplate code this will be useful for many use cases!</span><br /> +<br /> +<h2 style='display: inline' id='in-editor-code-completion'>In-Editor Code Completion</h2><br /> +<br /> +<span>To leverage Ollama for real-time code completion in my editor, I have integrated it with Helix, my preferred text editor. Helix supports the LSP (Language Server Protocol), which enables advanced code completion features. The <span class='inlinecode'>lsp-ai</span> is an LSP server that can interface with Ollama models for code completion tasks.</span><br /> +<br /> +<a class='textlink' href='https://github.com/SilasMarvin/lsp-ai'>https://github.com/SilasMarvin/lsp-ai</a><br /> +<br /> +<h3 style='display: inline' id='installation-of-lsp-ai'>Installation of <span class='inlinecode'>lsp-ai</span></h3><br /> +<br /> +<span>I installed <span class='inlinecode'>lsp-ai</span> via Rust's Cargo package manager. (If you don't have Rust installed, you can install it via Homebrew as well.):</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>cargo install lsp-ai +</pre> +<br /> +<h3 style='display: inline' id='helix-configuration'>Helix Configuration</h3><br /> +<br /> +<span>I edited <span class='inlinecode'>~/.config/helix/languages.toml</span> to include:</span><br /> +<br /> +<pre> +<<language]] +name = "go" +auto-format= true +diagnostic-severity = "hint" +formatter = { command = "goimports" } +language-servers = [ "gopls", "golangci-lint-lsp", "lsp-ai", "gpt" ] +</pre> +<br /> +<span>Note that there is also a <span class='inlinecode'>gpt</span> language server configured, which is for GitHub Copilot, but it is out of scope of this blog post. Let's also configure <span class='inlinecode'>lsp-ai</span> settings in the same file:</span><br /> +<br /> +<pre> +[language-server.lsp-ai] +command = "lsp-ai" + +[language-server.lsp-ai.config.memory] +file_store = { } + +[language-server.lsp-ai.config.models.model1] +type = "ollama" +model = "qwen2.5-coder" + +[language-server.lsp-ai.config.models.model2] +type = "ollama" +model = "mistral-nemo:latest" + +[language-server.lsp-ai.config.models.model3] +type = "ollama" +model = "deepseek-r1:14b" + +[language-server.lsp-ai.config.completion] +model = "model1" + +[language-server.lsp-ai.config.completion.parameters] +max_tokens = 64 +max_context = 8096 + +## Configure the messages per your needs +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "system" +content = "Instructions:\n- You are an AI programming assistant.\n- Given a +piece of code with the cursor location marked by \"<CURSOR>\", replace +\"<CURSOR>\" with the correct code or comment.\n- First, think step-by-step.\n +- Describe your plan for what to build in pseudocode, written out in great +detail.\n- Then output the code replacing the \"<CURSOR>\"\n- Ensure that your +completion fits within the language context of the provided code snippet (e.g., +Go, Ruby, Bash, Java, Puppet DSL).\n\nRules:\n- Only respond with code or +comments.\n- Only replace \"<CURSOR>\"; do not include any previously written +code.\n- Never include \"<CURSOR>\" in your response\n- If the cursor is within +a comment, complete the comment meaningfully.\n- Handle ambiguous cases by +providing the most contextually appropriate completion.\n- Be consistent with +your responses." + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func greet(name) {\n print(f\"Hello, {<CURSOR>}\")\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "name" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func sum(a, b) {\n return a + <CURSOR>\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "b" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func multiply(a, b int ) int {\n a * <CURSOR>\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "b" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "// <CURSOR>\nfunc add(a, b) {\n return a + b\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "Adds two numbers" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "// This function checks if a number is even\n<CURSOR>" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "func is_even(n) {\n return n % 2 == 0\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "{CODE}" +</pre> +<br /> +<span>As you can see, I have also added other models, such as Mistral Nemo and DeepSeek R1, so that I can switch between them in Helix. Other than that, the completion parameters are interesting. They define how the LLM should interact with the text in the text editor based on the given examples.</span><br /> +<br /> +<h3 style='display: inline' id='code-completion-in-action'>Code completion in action</h3><br /> +<br /> +<span>The screenshot shows how Ollama's <span class='inlinecode'>qwen2.5-coder</span> model provides code completion suggestions within the Helix editor. The LSP auto-completion is triggered by typing <span class='inlinecode'><CURSOR></span> in the code snippet, and Ollama responds with relevant completions based on the context.</span><br /> +<br /> +<a href='./local-coding-LLM-with-ollama/helix-lsp-ai.png'><img alt='Completing the fib-function' title='Completing the fib-function' src='./local-coding-LLM-with-ollama/helix-lsp-ai.png' /></a><br /> +<br /> +<span>In the LSP auto-completion, the one prefixed with <span class='inlinecode'>ai - </span> was generated by <span class='inlinecode'>qwen2.5-coder</span>, the other ones are from other LSP servers (GitHub Copilot, Go linter, Go language server, etc.).</span><br /> +<br /> +<span>I found GitHub Copilot to be still faster than <span class='inlinecode'>qwen2.5-coder:14b</span>, but the local LLM one is actually workable for me already. And, as mentioned earlier, things will likely improve in the future regarding local LLMs. So I am excited about the future of local LLMs and coding tools like Ollama and Helix.</span><br /> +<br /> +<span>After trying <span class='inlinecode'>qwen3-coder:30b-a3b-q4_K_M</span> (following the publication of this blog post), I found it to be significantly faster and more capable than the previous model, making it a promising option for local coding tasks. Experimentation reveals that even current local setups are surprisingly effective for routine coding tasks, offering a glimpse into the future of on-machine AI assistance.</span><br /> +<br /> +<h2 style='display: inline' id='conclusion'>Conclusion</h2><br /> +<br /> +<span>Will there ever be a time we can run larger models (60B, 100B, ...and larger) on consumer hardware, or even on our phones? We are not quite there yet, but I am optimistic that we will see significant improvements in the next few years. As hardware capabilities improve and/or become cheaper, and more efficient models are developed, the landscape of local AI coding assistants will continue to evolve. </span><br /> +<br /> +<span>For now, even the models listed in this blog post are very promising already, and they run on consumer-grade hardware (at least in the realm of the initial tests I've performed... the ones in this blog post are overly simplistic, though! But they were good for getting started with Ollama and initial demonstration)! I will continue experimenting with Ollama and other local LLMs to see how they can enhance my coding experience. I may cancel my Copilot subscription, which I currently use only for in-editor auto-completion, at some point.</span><br /> +<br /> +<span>However, truth be told, I don't think the setup described in this blog post currently matches the performance of commercial models like Claude Code (Sonnet 4, Opus 4), Gemini 2.5 Pro, and others. Maybe we could get close if we had the high-end hardware needed to run the largest Qwen Coder model available. But, as mentioned already, that is out of reach for occasional coders like me. Furthermore, I want to continue coding manually to some degree, as otherwise I will start to forget how to write for-loops, which can be awkward... However, do we always need the best model when AI can help generate boilerplate or repetitive tasks even with smaller models?</span><br /> +<br /> +<span>E-Mail your comments to <span class='inlinecode'>paul@nospam.buetow.org</span> :-)</span><br /> +<br /> +<span>Other related posts are:</span><br /> +<br /> +<a class='textlink' href='./2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 Local LLM for Coding with Ollama (You are currently reading this)</a><br /> +<a class='textlink' href='./2025-06-22-task-samurai.html'>2025-06-22 Task Samurai: An agentic coding learning experiment</a><br /> +<br /> +<a class='textlink' href='../'>Back to the main site</a><br /> +<p class="footer"> +Generated with <a href="https://codeberg.org/snonux/gemtexter">Gemtexter 3.0.1-develop</a> | +served by <a href="https://www.OpenBSD.org">OpenBSD</a>/<a href="https://man.openbsd.org/relayd.8">relayd(8)</a>+<a href="https://man.openbsd.org/httpd.8">httpd(8)</a> | +<a href="https://foo.zone/site-mirrors.html">Site Mirrors</a> +</p> +</body> +</html> diff --git a/gemfeed/DRAFT-kubernetes-with-freebsd-part-7.html b/gemfeed/DRAFT-kubernetes-with-freebsd-part-7.html index 79b35bb2..1e6c5a50 100644 --- a/gemfeed/DRAFT-kubernetes-with-freebsd-part-7.html +++ b/gemfeed/DRAFT-kubernetes-with-freebsd-part-7.html @@ -613,6 +613,9 @@ http://www.gnu.org/software/src-highlite --> <span>Shutting down <span class='inlinecode'>f0</span> and let NFS failing over for the Apache content.</span><br /> <br /> <br /> +<span>TODO: openbsd relayd config</span><br /> +<span>TODO: registry howto</span><br /> +<span>TODO: anki-droid deployment</span><br /> <span>TODO: include k9s screenshot</span><br /> <span>TODO: include a diagram again?</span><br /> <span>TODO: increase replica of traefik to 2, persist config surviving reboots</span><br /> diff --git a/gemfeed/STUNNEL-NFS-SETUP-R1-R2.md b/gemfeed/STUNNEL-NFS-SETUP-R1-R2.md deleted file mode 100644 index 3c2ff77f..00000000 --- a/gemfeed/STUNNEL-NFS-SETUP-R1-R2.md +++ /dev/null @@ -1,277 +0,0 @@ -# Stunnel and NFS Configuration for r1 and r2 - -This document provides step-by-step instructions for configuring stunnel and NFS mounts on r1 and r2 Rocky Linux systems to connect to the f3s storage cluster. - -## Prerequisites - -- Root access on r1 and r2 -- Network connectivity to f0 (for copying the certificate) -- Network connectivity to the CARP VIP (192.168.1.138) - -## Overview - -The configuration provides: -- Encrypted NFS traffic using stunnel -- Automatic failover via CARP VIP (192.168.1.138) -- Persistent mounts across reboots -- Access to /data/nfs/k3svolumes for Kubernetes storage - -## Configuration Steps - -### Step 1: Install stunnel - -```bash -dnf install -y stunnel -``` - -### Step 2: Copy the stunnel certificate from f0 - -First, create the directory: -```bash -mkdir -p /etc/stunnel -``` - -Then copy the certificate from f0. On f0, run: -```bash -scp /usr/local/etc/stunnel/stunnel.pem root@r1:/etc/stunnel/ -scp /usr/local/etc/stunnel/stunnel.pem root@r2:/etc/stunnel/ -``` - -### Step 3: Create stunnel client configuration - -Create `/etc/stunnel/stunnel.conf`: -```bash -cat > /etc/stunnel/stunnel.conf <<'EOF' -cert = /etc/stunnel/stunnel.pem -client = yes - -[nfs-ha] -accept = 127.0.0.1:2323 -connect = 192.168.1.138:2323 -EOF -``` - -### Step 4: Create systemd service for stunnel - -Create `/etc/systemd/system/stunnel.service`: -```bash -cat > /etc/systemd/system/stunnel.service <<'EOF' -[Unit] -Description=SSL tunnel for network daemons -After=network.target - -[Service] -Type=forking -ExecStart=/usr/bin/stunnel /etc/stunnel/stunnel.conf -ExecStop=/usr/bin/killall stunnel -RemainAfterExit=yes - -[Install] -WantedBy=multi-user.target -EOF -``` - -### Step 5: Enable and start stunnel - -```bash -systemctl daemon-reload -systemctl enable stunnel -systemctl start stunnel -systemctl status stunnel -``` - -### Step 6: Create NFS mount point - -```bash -mkdir -p /data/nfs/k3svolumes -``` - -### Step 7: Test mount NFS through stunnel - -```bash -mount -t nfs4 -o port=2323 127.0.0.1:/data/nfs/k3svolumes /data/nfs/k3svolumes -``` - -### Step 8: Verify the mount - -```bash -mount | grep k3svolumes -df -h /data/nfs/k3svolumes -ls -la /data/nfs/k3svolumes/ -``` - -### Step 9: Configure persistent mount - -First unmount the test mount: -```bash -umount /data/nfs/k3svolumes -``` - -Add to `/etc/fstab`: -```bash -echo "127.0.0.1:/data/nfs/k3svolumes /data/nfs/k3svolumes nfs4 port=2323,_netdev 0 0" >> /etc/fstab -``` - -Mount using fstab: -```bash -mount /data/nfs/k3svolumes -``` - -## Automated Installation - -A script is available to automate all these steps: - -```bash -# Download and run the configuration script -curl -O https://raw.githubusercontent.com/.../configure-stunnel-nfs-r1-r2.sh -chmod +x configure-stunnel-nfs-r1-r2.sh -./configure-stunnel-nfs-r1-r2.sh -``` - -## Verification Commands - -After configuration, verify everything is working: - -```bash -# Check stunnel service -systemctl status stunnel - -# Check NFS mount -mount | grep k3svolumes -df -h /data/nfs/k3svolumes - -# Test write access -echo "Test from $(hostname) at $(date)" > /data/nfs/k3svolumes/test-$(hostname).txt -cat /data/nfs/k3svolumes/test-$(hostname).txt - -# Check stunnel connection -ss -tlnp | grep 2323 -``` - -## Troubleshooting - -### Stunnel won't start - -Check the logs: -```bash -journalctl -u stunnel -n 50 -``` - -Common issues: -- Certificate file missing or wrong permissions -- Port 2323 already in use -- Configuration syntax error - -### NFS mount fails - -Check connectivity: -```bash -# Test if stunnel is listening -telnet 127.0.0.1 2323 - -# Check if CARP VIP is reachable -ping -c 3 192.168.1.138 - -# Try mounting with verbose output -mount -v -t nfs4 -o port=2323 127.0.0.1:/data/nfs/k3svolumes /data/nfs/k3svolumes -``` - -### Mount not persistent after reboot - -Verify fstab entry: -```bash -grep k3svolumes /etc/fstab -``` - -Test fstab mount: -```bash -mount -a -``` - -Check for systemd mount errors: -```bash -systemctl --failed -journalctl -b | grep mount -``` - -### Permission denied errors - -The NFS export on f0/f1 maps root, so permission issues are rare. If they occur: -```bash -# Check export configuration on NFS server -showmount -e 192.168.1.138 - -# Verify your IP is allowed in the exports -# r0: 192.168.1.120 -# r1: 192.168.1.121 -# r2: 192.168.1.122 -``` - -## Security Considerations - -- All NFS traffic is encrypted through stunnel -- The certificate provides both authentication and encryption -- Access is restricted by IP address on the NFS server -- Root access is mapped (maproot=root) for Kubernetes operations - -## Integration with Kubernetes - -Once configured, Kubernetes can use this mount for persistent storage: - -```yaml -apiVersion: v1 -kind: PersistentVolume -metadata: - name: nfs-pv -spec: - capacity: - storage: 10Gi - accessModes: - - ReadWriteMany - nfs: - server: 127.0.0.1 # Local stunnel - path: /data/nfs/k3svolumes - mountOptions: - - port=2323 - - nfsvers=4 -``` - -## Maintenance - -### Restarting services - -```bash -# Restart stunnel -systemctl restart stunnel - -# Remount NFS -umount /data/nfs/k3svolumes -mount /data/nfs/k3svolumes -``` - -### Updating certificates - -When certificates expire (after 10 years): -1. Generate new certificate on f0 -2. Copy to all clients (r0, r1, r2) -3. Restart stunnel on all hosts - -### Monitoring - -Add to your monitoring system: -- stunnel service status -- NFS mount presence -- Disk space on /data/nfs/k3svolumes -- Network connectivity to 192.168.1.138:2323 - -## Summary - -After completing these steps on both r1 and r2: - -1. **Stunnel** provides encrypted tunnel to NFS server -2. **NFS** mounts through stunnel on port 2323 -3. **CARP VIP** (192.168.1.138) ensures automatic failover -4. **Persistent mount** via /etc/fstab survives reboots -5. **Kubernetes** can use /data/nfs/k3svolumes for persistent volumes - -The same configuration works on r0, r1, and r2 with no modifications needed.
\ No newline at end of file diff --git a/gemfeed/aitest/cmd/aitest/main.go b/gemfeed/aitest/cmd/aitest/main.go new file mode 100644 index 00000000..130cfe0d --- /dev/null +++ b/gemfeed/aitest/cmd/aitest/main.go @@ -0,0 +1,32 @@ +package main + +import ( + "flag" + "fmt" + "os" + + "aitest/internal" +) + +func main() { + var versionFlag bool + flag.BoolVar(&versionFlag, "v", false, "print version") + dir := flag.String("dir", "", "directory to count files in") + flag.Parse() + + if versionFlag { + fmt.Println(internal.GetVersion()) + return + } + + if *dir != "" { + fileCount, err := internal.CountFiles(*dir) + if err != nil { + fmt.Fprintf(os.Stderr, "Error counting files: %v\n", err) + os.Exit(1) + } + fmt.Printf("Number of files in directory %s: %d\n", *dir, fileCount) + } else { + fmt.Println("No directory specified. No count given.") + } +} diff --git a/gemfeed/aitest/go.mod b/gemfeed/aitest/go.mod new file mode 100644 index 00000000..8fac64ee --- /dev/null +++ b/gemfeed/aitest/go.mod @@ -0,0 +1,3 @@ +module aitest + +go 1.24 diff --git a/gemfeed/aitest/internal/count.go b/gemfeed/aitest/internal/count.go new file mode 100644 index 00000000..544ace17 --- /dev/null +++ b/gemfeed/aitest/internal/count.go @@ -0,0 +1,21 @@ +package internal + +import ( + "os" +) + +func CountFiles(dir string) (int, error) { + files, err := os.ReadDir(dir) + if err != nil { + return 0, err + } + + count := 0 + for _, file := range files { + if !file.IsDir() { + count++ + } + } + + return count, nil +} diff --git a/gemfeed/aitest/internal/version.go b/gemfeed/aitest/internal/version.go new file mode 100644 index 00000000..84fa6601 --- /dev/null +++ b/gemfeed/aitest/internal/version.go @@ -0,0 +1,7 @@ +package internal + +var Version = "0.0.0" + +func GetVersion() string { + return Version +} diff --git a/gemfeed/atom.xml b/gemfeed/atom.xml index 86fbc6ea..45fff1f1 100644 --- a/gemfeed/atom.xml +++ b/gemfeed/atom.xml @@ -1,12 +1,462 @@ <?xml version="1.0" encoding="utf-8"?> <feed xmlns="http://www.w3.org/2005/Atom"> - <updated>2025-07-28T15:09:21+03:00</updated> + <updated>2025-08-04T16:43:39+03:00</updated> <title>foo.zone feed</title> <subtitle>To be in the .zone!</subtitle> <link href="https://foo.zone/gemfeed/atom.xml" rel="self" /> <link href="https://foo.zone/" /> <id>https://foo.zone/</id> <entry> + <title>Local LLM for Coding with Ollama</title> + <link href="https://foo.zone/gemfeed/2025-08-05-local-coding-llm-with-ollama.html" /> + <id>https://foo.zone/gemfeed/2025-08-05-local-coding-llm-with-ollama.html</id> + <updated>2025-08-04T16:43:39+03:00</updated> + <author> + <name>Paul Buetow aka snonux</name> + <email>paul@dev.buetow.org</email> + </author> + <summary>With all the AI buzz around coding assistants, and being a bit concerned about being dependent on third-party cloud providers here, I decided to explore the capabilities of local large language models (LLMs) using Ollama. </summary> + <content type="xhtml"> + <div xmlns="http://www.w3.org/1999/xhtml"> + <h1 style='display: inline' id='local-llm-for-coding-with-ollama'>Local LLM for Coding with Ollama</h1><br /> +<br /> +<pre> + [::] + _| |_ + / o o \ | + | ∆ | <-- Ollama / \ + | \___/ | / \ + \_______/ LLM --> / 30B \ + | | / Qwen3 \ + /| |\ / Coder \ + /_| |_\_________________/ quantised \ +</pre> +<br /> +<span>With all the AI buzz around coding assistants, and being a bit concerned about being dependent on third-party cloud providers here, I decided to explore the capabilities of local large language models (LLMs) using Ollama. </span><br /> +<br /> +<span>Ollama is a powerful tool that brings local AI capabilities directly to your local hardware. By running AI models locally, you can enjoy the benefits of intelligent assistance without relying on cloud services. This document outlines my initial setup and experiences with Ollama, with a focus on coding tasks and agentic coding.</span><br /> +<br /> +<a class='textlink' href='https://ollama.com/'>https://ollama.com/</a><br /> +<br /> +<h2 style='display: inline' id='why-local-llms'>Why Local LLMs?</h2><br /> +<br /> +<span>Using local AI models through Ollama offers several advantages:</span><br /> +<br /> +<ul> +<li>Data Privacy: Keep your code and data completely private by processing everything locally.</li> +<li>Cost-Effective: Reduce reliance on expensive cloud API calls.</li> +<li>Reliability: Works seamlessly even with spotty internet or offline.</li> +<li>Speed: Avoid network latency and enjoy instant responses while coding. Although I mostly found Ollama slower than commercial LLM providers. However, that may change with the evolution of models and hardware.</li> +</ul><br /> +<h2 style='display: inline' id='hardware-considerations'>Hardware Considerations</h2><br /> +<br /> +<span>Running large language models locally is currently limited by consumer hardware capabilities:</span><br /> +<br /> +<ul> +<li>GPU Memory: Most consumer-grade GPUs (even in 2025) top out at 16–24GB of VRAM, making it challenging to run larger models like the 30B (30 billion) parameter LLMs (they go up to the 100 billion and more).</li> +<li>RAM Constraints: On my MacBook Pro with M3 CPU and 36GB RAM, I chose a 14B model (<span class='inlinecode'>qwen2.5-coder:14b-instruct</span>) as it represents a practical balance between capability and resource requirements.</li> +</ul><br /> +<span>For reference, here are some key points about running large LLMs locally:</span><br /> +<br /> +<ul> +<li>Models larger than 30B: I don't even think about running them locally. One (e.g. from Qwen, Deepseek or Kimi K2) with several hundred billion parameters could match the "performance" of commercial LLMs (Claude Sonnet 4, etc). Still, for personal use, the hardware demands are just too high (or temporarily "rent" it via the public cloud?).</li> +<li>30B models: Require at least 48GB of GPU VRAM for full inference without quantisation. Currently only feasible on high-end professional GPUs (or an Apple-silicone Mac with enough unified RAM).</li> +<li>14B models: Can run with 16-24GB GPU memory (VRAM), suitable for consumer-grade hardware (or use a quantised larger model)</li> +<li>7B-13B models: Best fit for mainstream consumer hardware, requiring minimal VRAM and running smoothly on mid-range GPUs, but with limited capabilities compared to larger models and more hallucinations.</li> +</ul><br /> +<span>The model I'll be mainly using in this blog post (<span class='inlinecode'>qwen2.5-coder:14b-instruct</span>) is particularly interesting as:</span><br /> +<br /> +<ul> +<li><span class='inlinecode'>instruct</span>: Indicates this is the instruction-tuned variant of QWE, optimised for diverse tasks including coding</li> +<li><span class='inlinecode'>coder</span>: Tells me that this model was trained on a mix of code and text data, making it especially effective for programming assistance</li> +</ul><br /> +<a class='textlink' href='https://huggingface.co/Qwen/Qwen2.5-Coder-14B-Instruct'>https://huggingface.co/Qwen/Qwen2.5-Coder-14B-Instruct</a><br /> +<br /> +<span>For general thinking tasks, I found <span class='inlinecode'>deepseek-r1:14b</span> to be useful. For instance, I utilised <span class='inlinecode'>deepseek-r1:14b</span> to format this blog post and correct some English errors, demonstrating its effectiveness in natural language processing tasks. Additionally, it has proven invaluable for adding context and enhancing clarity in technical explanations, all while running locally on the MacBook Pro. Admittedly, it was a lot slower than "just using ChatGPT", but still within minutes. </span><br /> +<br /> +<a class='textlink' href='https://ollama.com/library/deepseek-r1:14b'>https://ollama.com/library/deepseek-r1:14b</a><br /> +<br /> +<span>A quantised (as mentioned above) LLM which has been converted from high-precision connection (typically 16- or 32-bit floating point) representations to lower-precision formats, such as 8-bit integers. This reduces the overall memory footprint of the model, making it significantly smaller and enabling it to run more efficiently on hardware with limited resources or to allow higher throughput on GPUs and CPUs. The benefits of quantisation include reduced storage and faster inference times due to simpler computations and better memory bandwidth utilisation. However, quantisation can introduce a drop in model accuracy because the lower numerical precision means the model cannot represent parameter values as precisely. In some cases, it may lead to instability or unexpected outputs in specific tasks or edge cases.</span><br /> +<br /> +<h2 style='display: inline' id='basic-setup-and-manual-code-prompting'>Basic Setup and Manual Code Prompting</h2><br /> +<br /> +<h3 style='display: inline' id='installing-ollama-and-a-model'>Installing Ollama and a Model</h3><br /> +<br /> +<span>To install Ollama, IIperformed these steps (this assumes that you have already installed Homebrew on your macOS system):</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>brew install ollama +rehash +ollama serve +</pre> +<br /> +<span>Which started up the Ollama server with something like this (the screenshots shows already some requests made):</span><br /> +<br /> +<a href='./local-coding-LLM-with-ollama/ollama-serve.png'><img alt='Ollama serving' title='Ollama serving' src='./local-coding-LLM-with-ollama/ollama-serve.png' /></a><br /> +<br /> +<span>And then, in a new terminal, I pulled the model with:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>ollama pull qwen2.<font color="#000000">5</font>-coder:14b-instruct +</pre> +<br /> +<span>Now, I was ready to go! It wasn't so difficult. Now, let's see how I used this model for coding tasks.</span><br /> +<br /> +<h3 style='display: inline' id='example-usage'>Example Usage</h3><br /> +<br /> +<span>I run the following command to get a Go function for calculating Fibonacci numbers:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>time echo <font color="#808080">"Write a function in golang to print out the Nth fibonacci number, \</font> +<font color="#808080"> only the function without the boilerplate"</font> | ollama run qwen2.<font color="#000000">5</font>-coder:14b-instruct + +Output: + +func fibonacci(n int) int { + <b><u><font color="#000000">if</font></u></b> n <= <font color="#000000">1</font> { + <b><u><font color="#000000">return</font></u></b> n + } + a, b := <font color="#000000">0</font>, <font color="#000000">1</font> + <b><u><font color="#000000">for</font></u></b> i := <font color="#000000">2</font>; i <= n; i++ { + a, b = b, a+b + } + <b><u><font color="#000000">return</font></u></b> b +} + +Execution Metrics: + +Executed <b><u><font color="#000000">in</font></u></b> <font color="#000000">4.90</font> secs fish external + usr time <font color="#000000">15.54</font> millis <font color="#000000">0.31</font> millis <font color="#000000">15.24</font> millis + sys time <font color="#000000">19.68</font> millis <font color="#000000">1.02</font> millis <font color="#000000">18.66</font> millis +</pre> +<br /> +<span class='quote'>Note, after having written this blog post, I tried the same with the newer model <span class='inlinecode'>qwen3-coder:30b-a3b-q4_K_M</span> (which "just" came out, and it's a quantised 30B model), and it was much faster:</span><br /> +<br /> +<pre> +Executed in 1.83 secs fish external + usr time 17.82 millis 4.40 millis 13.42 millis + sys time 17.07 millis 1.57 millis 15.50 millis +</pre> +<br /> +<a class='textlink' href='https://ollama.com/library/qwen3-coder:30b-a3b-q4_K_M'>https://ollama.com/library/qwen3-coder:30b-a3b-q4_K_M</a><br /> +<br /> +<h2 style='display: inline' id='agentic-coding-with-aider'>Agentic Coding with Aider</h2><br /> +<br /> +<h3 style='display: inline' id='installation'>Installation</h3><br /> +<br /> +<span>Aider is a tool that enables agentic coding by leveraging AI models (also local ones, as in our case). While setting up OpenAI Codex and OpenCode with Ollama proved challenging (those tools either didn't know how to work with the "tools" (the capability to execute external commands or to edit files for example) or didn't connect at all to Ollama for some reason), Aider worked smoothly.</span><br /> +<br /> +<span>To get started, the only thing I had to do was to install it via Homebrew, initialise a Git repository, and then start Aider with the Ollama model <span class='inlinecode'>ollama_chat/qwen2.5-coder:14b-instruct</span>:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>brew install aider +mkdir ~/git/aitest && cd ~/git/aitest && git init +aider --model ollama_chat/qwen<font color="#000000">2.5</font>-coder:14b-instruct +</pre> +<br /> +<a class='textlink' href='https://aider.chat'>https://aider.chat</a><br /> +<a class='textlink' href='https://opencode.ai'>https://opencode.ai</a><br /> +<a class='textlink' href='https://github.com/openai/codex'>https://github.com/openai/codex</a><br /> +<br /> +<h3 style='display: inline' id='agentic-coding-prompt'>Agentic coding prompt</h3><br /> +<br /> +<span>This is the prompt I gave:</span><br /> +<br /> +<pre> +Create a Go project with these files: + +* `cmd/aitest/main.go`: CLI entry point +* `internal/version.go`: Version information (0.0.0), should be printed when the + program was started with `-version` flag +* `internal/count.go`: File counting functionality, the program should print out + the number of files in a given subdirectory (the directory is provided as a + command line flag with `-dir`), if none flag is given, no counting should be + done +* `README.md`: Installation and usage instructions +</pre> +<br /> +<span>It then generated something, but did not work out of the box, as it had some issues with the imports and package names. So I had to do some follow-up prompts to fix those issues with something like this:</span><br /> +<br /> +<pre> +* Update import paths to match module name, github.com/yourname/aitest should be + aitest in main.go +* The package names of internal/count.go and internal/version.go should be + internal, and not count and version. +</pre> +<br /> +<a href='./local-coding-LLM-with-ollama/aider-fix-package.png'><img alt='Aider fixing the packages' title='Aider fixing the packages' src='./local-coding-LLM-with-ollama/aider-fix-package.png' /></a><br /> +<br /> +<h3 style='display: inline' id='compilation--execution'>Compilation & Execution</h3><br /> +<br /> +<span>Once done so, the project was ready and I could compile and run it:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>go build cmd/aitest/main.go +./main --help +./main -v +<font color="#000000">0.0</font>.<font color="#000000">0</font> +./main -dir . +Number of files <b><u><font color="#000000">in</font></u></b> directory .: <font color="#000000">4</font> +</pre> +<br /> +<h3 style='display: inline' id='the-code'>The code</h3><br /> +<br /> +<span>The code it generated was simple, but functional. The <span class='inlinecode'>./cmd/aitest/main.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> main + +<b><u><font color="#000000">import</font></u></b> ( + <font color="#808080">"flag"</font> + <font color="#808080">"fmt"</font> + <font color="#808080">"os"</font> + + <font color="#808080">"aitest/internal"</font> +) + +<b><u><font color="#000000">func</font></u></b> main() { + <b><u><font color="#000000">var</font></u></b> versionFlag <b><font color="#000000">bool</font></b> + flag.BoolVar(&versionFlag, <font color="#808080">"v"</font>, false, <font color="#808080">"print version"</font>) + dir := flag.String(<font color="#808080">"dir"</font>, <font color="#808080">""</font>, <font color="#808080">"directory to count files in"</font>) + flag.Parse() + + <b><u><font color="#000000">if</font></u></b> versionFlag { + fmt.Println(internal.GetVersion()) + <b><u><font color="#000000">return</font></u></b> + } + + <b><u><font color="#000000">if</font></u></b> *dir != <font color="#808080">""</font> { + fileCount, err := internal.CountFiles(*dir) + <b><u><font color="#000000">if</font></u></b> err != nil { + fmt.Fprintf(os.Stderr, <font color="#808080">"Error counting files: %v\n"</font>, err) + os.Exit(<font color="#000000">1</font>) + } + fmt.Printf(<font color="#808080">"Number of files in directory %s: %d\n"</font>, *dir, fileCount) + } <b><u><font color="#000000">else</font></u></b> { + fmt.Println(<font color="#808080">"No directory specified. No count given."</font>) + } +} +</pre> +<br /> +<span>The <span class='inlinecode'>./internal/version.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> internal + +<b><u><font color="#000000">var</font></u></b> Version = <font color="#808080">"0.0.0"</font> + +<b><u><font color="#000000">func</font></u></b> GetVersion() <b><font color="#000000">string</font></b> { + <b><u><font color="#000000">return</font></u></b> Version +} +</pre> +<br /> +<span>The <span class='inlinecode'>./internal/count.go</span> file:</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre><b><u><font color="#000000">package</font></u></b> internal + +<b><u><font color="#000000">import</font></u></b> ( + <font color="#808080">"os"</font> +) + +<b><u><font color="#000000">func</font></u></b> CountFiles(dir <b><font color="#000000">string</font></b>) (int, error) { + files, err := os.ReadDir(dir) + <b><u><font color="#000000">if</font></u></b> err != nil { + <b><u><font color="#000000">return</font></u></b> <font color="#000000">0</font>, err + } + + count := <font color="#000000">0</font> + <b><u><font color="#000000">for</font></u></b> _, file := <b><u><font color="#000000">range</font></u></b> files { + <b><u><font color="#000000">if</font></u></b> !file.IsDir() { + count++ + } + } + + <b><u><font color="#000000">return</font></u></b> count, nil +} +</pre> +<br /> +<span>Etc...</span><br /> +<br /> +<span>The code is quite straightforward, especially for generating boilerplate code this will be useful for many use cases!</span><br /> +<br /> +<h2 style='display: inline' id='in-editor-code-completion'>In-Editor Code Completion</h2><br /> +<br /> +<span>To leverage Ollama for real-time code completion in my editor, I have integrated it with Helix, my preferred text editor. Helix supports the LSP (Language Server Protocol), which enables advanced code completion features. The <span class='inlinecode'>lsp-ai</span> is an LSP server that can interface with Ollama models for code completion tasks.</span><br /> +<br /> +<a class='textlink' href='https://github.com/SilasMarvin/lsp-ai'>https://github.com/SilasMarvin/lsp-ai</a><br /> +<br /> +<h3 style='display: inline' id='installation-of-lsp-ai'>Installation of <span class='inlinecode'>lsp-ai</span></h3><br /> +<br /> +<span>I installed <span class='inlinecode'>lsp-ai</span> via Rust's Cargo package manager. (If you don't have Rust installed, you can install it via Homebrew as well.):</span><br /> +<br /> +<!-- Generator: GNU source-highlight 3.1.9 +by Lorenzo Bettini +http://www.lorenzobettini.it +http://www.gnu.org/software/src-highlite --> +<pre>cargo install lsp-ai +</pre> +<br /> +<h3 style='display: inline' id='helix-configuration'>Helix Configuration</h3><br /> +<br /> +<span>I edited <span class='inlinecode'>~/.config/helix/languages.toml</span> to include:</span><br /> +<br /> +<pre> +<<language]] +name = "go" +auto-format= true +diagnostic-severity = "hint" +formatter = { command = "goimports" } +language-servers = [ "gopls", "golangci-lint-lsp", "lsp-ai", "gpt" ] +</pre> +<br /> +<span>Note that there is also a <span class='inlinecode'>gpt</span> language server configured, which is for GitHub Copilot, but it is out of scope of this blog post. Let's also configure <span class='inlinecode'>lsp-ai</span> settings in the same file:</span><br /> +<br /> +<pre> +[language-server.lsp-ai] +command = "lsp-ai" + +[language-server.lsp-ai.config.memory] +file_store = { } + +[language-server.lsp-ai.config.models.model1] +type = "ollama" +model = "qwen2.5-coder" + +[language-server.lsp-ai.config.models.model2] +type = "ollama" +model = "mistral-nemo:latest" + +[language-server.lsp-ai.config.models.model3] +type = "ollama" +model = "deepseek-r1:14b" + +[language-server.lsp-ai.config.completion] +model = "model1" + +[language-server.lsp-ai.config.completion.parameters] +max_tokens = 64 +max_context = 8096 + +## Configure the messages per your needs +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "system" +content = "Instructions:\n- You are an AI programming assistant.\n- Given a +piece of code with the cursor location marked by \"<CURSOR>\", replace +\"<CURSOR>\" with the correct code or comment.\n- First, think step-by-step.\n +- Describe your plan for what to build in pseudocode, written out in great +detail.\n- Then output the code replacing the \"<CURSOR>\"\n- Ensure that your +completion fits within the language context of the provided code snippet (e.g., +Go, Ruby, Bash, Java, Puppet DSL).\n\nRules:\n- Only respond with code or +comments.\n- Only replace \"<CURSOR>\"; do not include any previously written +code.\n- Never include \"<CURSOR>\" in your response\n- If the cursor is within +a comment, complete the comment meaningfully.\n- Handle ambiguous cases by +providing the most contextually appropriate completion.\n- Be consistent with +your responses." + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func greet(name) {\n print(f\"Hello, {<CURSOR>}\")\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "name" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func sum(a, b) {\n return a + <CURSOR>\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "b" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "func multiply(a, b int ) int {\n a * <CURSOR>\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "b" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "// <CURSOR>\nfunc add(a, b) {\n return a + b\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "Adds two numbers" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "// This function checks if a number is even\n<CURSOR>" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "assistant" +content = "func is_even(n) {\n return n % 2 == 0\n}" + +<<language-server.lsp-ai.config.completion.parameters.messages]] +role = "user" +content = "{CODE}" +</pre> +<br /> +<span>As you can see, I have also added other models, such as Mistral Nemo and DeepSeek R1, so that I can switch between them in Helix. Other than that, the completion parameters are interesting. They define how the LLM should interact with the text in the text editor based on the given examples.</span><br /> +<br /> +<h3 style='display: inline' id='code-completion-in-action'>Code completion in action</h3><br /> +<br /> +<span>The screenshot shows how Ollama's <span class='inlinecode'>qwen2.5-coder</span> model provides code completion suggestions within the Helix editor. The LSP auto-completion is triggered by typing <span class='inlinecode'><CURSOR></span> in the code snippet, and Ollama responds with relevant completions based on the context.</span><br /> +<br /> +<a href='./local-coding-LLM-with-ollama/helix-lsp-ai.png'><img alt='Completing the fib-function' title='Completing the fib-function' src='./local-coding-LLM-with-ollama/helix-lsp-ai.png' /></a><br /> +<br /> +<span>In the LSP auto-completion, the one prefixed with <span class='inlinecode'>ai - </span> was generated by <span class='inlinecode'>qwen2.5-coder</span>, the other ones are from other LSP servers (GitHub Copilot, Go linter, Go language server, etc.).</span><br /> +<br /> +<span>I found GitHub Copilot to be still faster than <span class='inlinecode'>qwen2.5-coder:14b</span>, but the local LLM one is actually workable for me already. And, as mentioned earlier, things will likely improve in the future regarding local LLMs. So I am excited about the future of local LLMs and coding tools like Ollama and Helix.</span><br /> +<br /> +<span>After trying <span class='inlinecode'>qwen3-coder:30b-a3b-q4_K_M</span> (following the publication of this blog post), I found it to be significantly faster and more capable than the previous model, making it a promising option for local coding tasks. Experimentation reveals that even current local setups are surprisingly effective for routine coding tasks, offering a glimpse into the future of on-machine AI assistance.</span><br /> +<br /> +<h2 style='display: inline' id='conclusion'>Conclusion</h2><br /> +<br /> +<span>Will there ever be a time we can run larger models (60B, 100B, ...and larger) on consumer hardware, or even on our phones? We are not quite there yet, but I am optimistic that we will see significant improvements in the next few years. As hardware capabilities improve and/or become cheaper, and more efficient models are developed, the landscape of local AI coding assistants will continue to evolve. </span><br /> +<br /> +<span>For now, even the models listed in this blog post are very promising already, and they run on consumer-grade hardware (at least in the realm of the initial tests I've performed... the ones in this blog post are overly simplistic, though! But they were good for getting started with Ollama and initial demonstration)! I will continue experimenting with Ollama and other local LLMs to see how they can enhance my coding experience. I may cancel my Copilot subscription, which I currently use only for in-editor auto-completion, at some point.</span><br /> +<br /> +<span>However, truth be told, I don't think the setup described in this blog post currently matches the performance of commercial models like Claude Code (Sonnet 4, Opus 4), Gemini 2.5 Pro, and others. Maybe we could get close if we had the high-end hardware needed to run the largest Qwen Coder model available. But, as mentioned already, that is out of reach for occasional coders like me. Furthermore, I want to continue coding manually to some degree, as otherwise I will start to forget how to write for-loops, which can be awkward... However, do we always need the best model when AI can help generate boilerplate or repetitive tasks even with smaller models?</span><br /> +<br /> +<span>E-Mail your comments to <span class='inlinecode'>paul@nospam.buetow.org</span> :-)</span><br /> +<br /> +<span>Other related posts are:</span><br /> +<br /> +<a class='textlink' href='./2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 Local LLM for Coding with Ollama (You are currently reading this)</a><br /> +<a class='textlink' href='./2025-06-22-task-samurai.html'>2025-06-22 Task Samurai: An agentic coding learning experiment</a><br /> +<br /> +<a class='textlink' href='../'>Back to the main site</a><br /> + </div> + </content> + </entry> + <entry> <title>f3s: Kubernetes with FreeBSD - Part 6: Storage</title> <link href="https://foo.zone/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.html" /> <id>https://foo.zone/gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.html</id> @@ -2736,7 +3186,7 @@ Jul <font color="#000000">06</font> <font color="#000000">10</font>:<font color= </ul><br /> <h2 style='display: inline' id='conclusion'>Conclusion</h2><br /> <br /> -<span>Building Task Samurai with agentic coding was a wild ride—rapid feature growth, countless fast fixes, and more merge commits I'd expected. Keep the iterations short (or maybe in my next experiment, much larger, with better and more complete design before generating a single line of code), keep tests and documentation concise, and review and refine for final polish at the end. Even with the bumps along the way, shipping a polished terminal UI in days instead of weeks is a testament to the power of agentic development.</span><br /> +<span>Building Task Samurai with agentic coding was a wild ride—rapid feature growth, countless fast fixes, and more merge commits I'd expected. Keep the iterations short (or maybe in my next experiment, much larger, with better and more complete design before generating a single line of code), keep tests and documentation concise, and review and refine for final polish at the end. Even with the bumps along the way, shipping a terminal UI in days instead of weeks is a neat little showcase vibe coding.</span><br /> <br /> <span>Am I an agentic coding expert now? I don't think so. There are still many things to learn, and the landscape is constantly evolving.</span><br /> <br /> @@ -2748,6 +3198,11 @@ Jul <font color="#000000">06</font> <font color="#000000">10</font>:<font color= <br /> <span>E-Mail your comments to <span class='inlinecode'>paul@nospam.buetow.org</span> :-)</span><br /> <br /> +<span>Other related posts are:</span><br /> +<br /> +<a class='textlink' href='./2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 Local LLM for Coding with Ollama</a><br /> +<a class='textlink' href='./2025-06-22-task-samurai.html'>2025-06-22 Task Samurai: An agentic coding learning experiment (You are currently reading this)</a><br /> +<br /> <a class='textlink' href='../'>Back to the main site</a><br /> </div> </content> @@ -12566,195 +13021,4 @@ http://www.gnu.org/software/src-highlite --> </div> </content> </entry> - <entry> - <title>Unveiling `guprecords.raku`: Global Uptime Records with Raku</title> - <link href="https://foo.zone/gemfeed/2023-05-01-unveiling-guprecords:-uptime-records-with-raku.html" /> - <id>https://foo.zone/gemfeed/2023-05-01-unveiling-guprecords:-uptime-records-with-raku.html</id> - <updated>2023-04-30T13:10:26+03:00</updated> - <author> - <name>Paul Buetow aka snonux</name> - <email>paul@dev.buetow.org</email> - </author> - <summary>For fun, I am tracking the uptime of various personal machines (servers, laptops, workstations...). I have been doing this for over ten years now, so I have a lot of statistics collected.</summary> - <content type="xhtml"> - <div xmlns="http://www.w3.org/1999/xhtml"> - <h1 style='display: inline' id='unveiling-guprecordsraku-global-uptime-records-with-raku'>Unveiling <span class='inlinecode'>guprecords.raku</span>: Global Uptime Records with Raku</h1><br /> -<br /> -<span class='quote'>Published at 2023-04-30T13:10:26+03:00</span><br /> -<br /> -<pre> -+-----+-----------------+-----------------------------+ -| Pos | Host | Lifespan | -+-----+-----------------+-----------------------------+ -| 1. | dionysus | 8 years, 6 months, 17 days | -| 2. | uranus | 7 years, 2 months, 16 days | -| 3. | alphacentauri | 6 years, 9 months, 13 days | -| 4. | *vulcan | 4 years, 5 months, 6 days | -| 5. | sun | 3 years, 10 months, 2 days | -| 6. | uugrn | 3 years, 5 months, 5 days | -| 7. | deltavega | 3 years, 1 months, 21 days | -| 8. | pluto | 2 years, 10 months, 30 days | -| 9. | tauceti | 2 years, 3 months, 22 days | -| 10. | callisto | 2 years, 3 months, 13 days | -+-----+-----------------+-----------------------------+ -</pre> -<br /> -<h2 style='display: inline' id='table-of-contents'>Table of Contents</h2><br /> -<br /> -<ul> -<li><a href='#unveiling-guprecordsraku-global-uptime-records-with-raku'>Unveiling <span class='inlinecode'>guprecords.raku</span>: Global Uptime Records with Raku</a></li> -<li>⇢ <a href='#introduction'>Introduction</a></li> -<li>⇢ <a href='#how-guprecords-works'>How Guprecords works</a></li> -<li>⇢ <a href='#example'>Example</a></li> -<li>⇢ <a href='#conclusion'>Conclusion</a></li> -</ul><br /> -<h2 style='display: inline' id='introduction'>Introduction</h2><br /> -<br /> -<span>For fun, I am tracking the uptime of various personal machines (servers, laptops, workstations...). I have been doing this for over ten years now, so I have a lot of statistics collected.</span><br /> -<br /> -<span>As a result of this, I am introducing <span class='inlinecode'>guprecords.raku</span>, a handy Raku script that helps me combine uptime statistics from multiple servers into one comprehensive report. In this blog post, I'll explore what Guprecords is and some examples of its application. I will also add some notes on Raku.</span><br /> -<br /> -<span>Guprecords, or global uptime records, is a Raku script designed to generate a consolidated uptime report from multiple hosts:</span><br /> -<br /> -<a class='textlink' href='https://codeberg.org/snonux/guprecords'>https://codeberg.org/snonux/guprecords</a><br /> -<a class='textlink' href='https://raku.org'>The Raku Programming Language</a><br /> -<br /> -<span>A previous version of Guprecords was actually written in Perl, the older and more established language from which Raku was developed. One of the primary motivations for rewriting Guprecords in Raku was to learn the language and explore its features. Raku is a more modern and powerful language compared to Perl, and working on a real-world project like Guprecords provided a practical and engaging way to learn the language.</span><br /> -<br /> -<span>Over the last years, I have been reading the following books and resources about Raku:</span><br /> -<br /> -<ul> -<li>Raku Guide (at raku.guide)</li> -<li>Think Perl 6</li> -<li>Raku Fundamentals</li> -<li>Raku Recipes</li> -</ul><br /> -<span>And I have been following the Raku newsletter, and sometimes I have been lurking around in the IRC channels, too. Watching Raku coding challenges on YouTube was pretty fun, too. However, nothing beats actually using Raku to learn the language. After reading all of these resources, I may have a good idea about the features and paradigms, but I am by far not an expert.</span><br /> -<br /> -<h2 style='display: inline' id='how-guprecords-works'>How Guprecords works</h2><br /> -<br /> -<span>Guprecords works in three stages:</span><br /> -<br /> -<ul> -<li>1. Generating uptime statistics using <span class='inlinecode'>uptimed</span>: First, I need to install and run <span class='inlinecode'>uptimed</span> on each host to generate uptime statistics. This tool is available for most common Linux and *BSD distributions and macOS via Homebrew.</li> -<li>2. Collecting uptime records to a central location: The next step involves collecting the raw uptime statistics files generated by <span class='inlinecode'>uptimed</span> on each host. It's a good idea to store all record files in a central git repository. The records file contains information about the total uptime since boot, boot time, and the operating system and kernel version. Guprecords itself does not do the collection part, but have a look at the <span class='inlinecode'>README.md</span> in the git repository for some guidance.</li> -<li>3. Generating global uptime stats: Finally, run the <span class='inlinecode'>guprecords.raku</span> script with the appropriate flags to create a global uptime report. For example, I can use the following command:</li> -</ul><br /> -<!-- Generator: GNU source-highlight 3.1.9 -by Lorenzo Bettini -http://www.lorenzobettini.it -http://www.gnu.org/software/src-highlite --> -<pre>$ raku guprecords.raku --stats=dir=$HOME/git/uprecords/stats --all -</pre> -<br /> -<span>This command will generate a comprehensive uptime report from the collected statistics, making it easy to review and enjoy the data.</span><br /> -<br /> -<span>Guprecords supports the following features:</span><br /> -<br /> -<ul> -<li>Supports multiple categories: Host, Kernel, KernelMajor, and KernelName</li> -<li>Supports multiple metrics: Boots, Uptime, Score, Downtime, and Lifespan</li> -<li>Output formats available: Plaintext, Markdown, and Gemtext</li> -<li>Provides top entries based on the specified limit</li> -</ul><br /> -<h2 style='display: inline' id='example'>Example</h2><br /> -<br /> -<span>You have already seen an example at the very top of this post, where the hosts were grouped by their total lifespans (uptime+downtime). Here's an example of what the global uptime report (grouped by total host uptimes) might look like:</span><br /> -<br /> -<pre> -Top 20 Uptime's by Host - -+-----+-----------------+-----------------------------+ -| Pos | Host | Uptime | -+-----+-----------------+-----------------------------+ -| 1. | *vulcan | 4 years, 5 months, 6 days | -| 2. | uranus | 3 years, 11 months, 21 days | -| 3. | sun | 3 years, 9 months, 26 days | -| 4. | uugrn | 3 years, 5 months, 5 days | -| 5. | deltavega | 3 years, 1 months, 21 days | -| 6. | pluto | 2 years, 10 months, 29 days | -| 7. | tauceti | 2 years, 3 months, 19 days | -| 8. | tauceti-f | 1 years, 9 months, 18 days | -| 9. | *ultramega15289 | 1 years, 8 months, 17 days | -| 10. | *earth | 1 years, 5 months, 22 days | -| 11. | *blowfish | 1 years, 4 months, 20 days | -| 12. | ultramega8477 | 1 years, 3 months, 25 days | -| 13. | host0 | 1 years, 3 months, 9 days | -| 14. | tauceti-e | 1 years, 2 months, 20 days | -| 15. | makemake | 1 years, 1 months, 6 days | -| 16. | callisto | 0 years, 10 months, 31 days | -| 17. | alphacentauri | 0 years, 10 months, 28 days | -| 18. | london | 0 years, 9 months, 16 days | -| 19. | twofish | 0 years, 8 months, 31 days | -| 20. | *fishfinger | 0 years, 8 months, 17 days | -+-----+-----------------+-----------------------------+ -</pre> -<br /> -<span>This table ranks the top 20 hosts based on their total uptime, with the host having the highest uptime at the top. The hosts marked with <span class='inlinecode'>*</span> are still active, means stats were collected within the last couple of months. </span><br /> -<br /> -<span>My up to date stats can be seen here:</span><br /> -<br /> -<a class='textlink' href='../uptime-stats.html'>My machine uptime stats</a><br /> -<br /> -<span>Just recently, I decommissioned <span class='inlinecode'>vulcan</span> (the number one stop from above), which used to be my CentOS 7 (initially CentOS 6) VM hosting my personal NextCloud and Wallabag (which I modernised just recently with a brand new shiny Rocky Linux 9 VM). This was the last <span class='inlinecode'>uptimed</span> output before shutting it down (it always makes me feel sentimental decommissioning one of my machines <span class='inlinecode'>:'-(</span>):</span><br /> -<br /> -<pre> - # Uptime | System Boot up -----------------------------+--------------------------------------------------- - 1 545 days, 17:58:15 | Linux 3.10.0-1160.15.2.e Sun Jul 25 19:32:25 2021 - 2 279 days, 10:12:14 | Linux 3.10.0-957.21.3.el Sun Jun 30 12:43:41 2019 - 3 161 days, 06:08:43 | Linux 3.10.0-1160.15.2.e Sun Feb 14 11:05:38 2021 - 4 107 days, 01:26:35 | Linux 3.10.0-957.1.3.el7 Thu Dec 20 09:29:13 2018 - 5 96 days, 21:13:49 | Linux 3.10.0-1127.13.1.e Sat Jul 25 17:56:22 2020 --> 6 89 days, 23:05:32 | Linux 3.10.0-1160.81.1.e Sun Jan 22 12:39:36 2023 - 7 63 days, 18:30:45 | Linux 3.10.0-957.10.1.el Sat Apr 27 18:12:43 2019 - 8 63 days, 06:53:33 | Linux 3.10.0-1127.8.2.el Sat May 23 10:41:08 2020 - 9 48 days, 11:44:49 | Linux 3.10.0-1062.18.1.e Sat Apr 4 22:56:07 2020 - 10 42 days, 08:00:13 | Linux 3.10.0-1127.19.1.e Sat Nov 7 11:47:33 2020 - 11 36 days, 22:57:19 | Linux 3.10.0-1160.6.1.el Sat Dec 19 19:47:57 2020 - 12 21 days, 06:16:28 | Linux 3.10.0-957.10.1.el Sat Apr 6 11:56:01 2019 - 13 12 days, 20:11:53 | Linux 3.10.0-1160.11.1.e Mon Jan 25 18:45:27 2021 - 14 7 days, 21:29:18 | Linux 3.10.0-1127.13.1.e Fri Oct 30 14:18:04 2020 - 15 6 days, 20:07:18 | Linux 3.10.0-1160.15.2.e Sun Feb 7 14:57:35 2021 - 16 1 day , 21:46:41 | Linux 3.10.0-957.1.3.el7 Tue Dec 18 11:42:19 2018 - 17 0 days, 01:25:57 | Linux 3.10.0-957.1.3.el7 Tue Dec 18 10:16:08 2018 - 18 0 days, 00:42:34 | Linux 3.10.0-1160.15.2.e Sun Jul 25 18:49:38 2021 - 19 0 days, 00:08:32 | Linux 3.10.0-1160.81.1.e Sun Jan 22 12:30:52 2023 -----------------------------+--------------------------------------------------- -1up in 6 days, 22:08:18 | at Sat Apr 29 10:53:25 2023 -no1 in 455 days, 18:52:44 | at Sun Jul 21 07:37:51 2024 - up 1586 days, 00:20:28 | since Tue Dec 18 10:16:08 2018 - down 0 days, 01:08:32 | since Tue Dec 18 10:16:08 2018 - %up 99.997 | since Tue Dec 18 10:16:08 2018 -</pre> -<br /> -<h2 style='display: inline' id='conclusion'>Conclusion</h2><br /> -<br /> -<span>Guprecords is a small, yet powerful tool for analyzing uptime statistics. While developing Guprecords, I have come to truly appreciate and love Raku's expressiveness. The language is designed to be both powerful and flexible, allowing developers to express their intentions and logic more clearly and concisely.</span><br /> -<br /> -<span>Raku's expressive syntax, support for multiple programming paradigms, and unique features, such as grammars and lazy evaluation, make it a joy to work with. </span><br /> -<br /> -<span>Working on Guprecords in Raku has been an enjoyable experience, and I've found that Raku's expressiveness has significantly contributed to the overall quality and effectiveness of the script. The language's ability to elegantly express complex logic and data manipulation tasks makes it an excellent choice for developing tools like these, where expressiveness and productiveness are of the utmost importance.</span><br /> -<br /> -<span>So far, I have only scratched the surface of what Raku can do. I hope to find more time to become a regular Rakoon (a Raku Programmer). I have many Ideas for other small tools like Guprecords, but the challenge is finding the time. I'd love to explore Raku Grammars and also I would love to explore writing concurrent code in Raku (I also love Go (Golang), btw!). Ideas for future Raku personal projects include:</span><br /> -<br /> -<ul> -<li>A log file analyzer, for generating anonymized <span class='inlinecode'>foo.zone</span> visitor stats for both, the Web and Gemini.</li> -<li>A social media sharing scheduler a la <span class='inlinecode'>buffer.com</span>. I am using Buffer at the moment to share posts on Mastadon, Twitter, Telegram and LinkedIn, but it is proprietary and also it's not really reliable.</li> -<li>Rewrite the static photo album generator of <span class='inlinecode'>irregular.ninja</span> in Raku (from Bash).</li> -</ul><br /> -<span>E-Mail your comments to hi@foo.zone :-)</span><br /> -<br /> -<span>Other related posts are:</span><br /> -<br /> -<a class='textlink' href='./2023-05-01-unveiling-guprecords:-uptime-records-with-raku.html'>2023-05-01 Unveiling <span class='inlinecode'>guprecords.raku</span>: Global Uptime Records with Raku (You are currently reading this)</a><br /> -<a class='textlink' href='./2022-06-15-sweating-the-small-stuff.html'>2022-06-15 Sweating the small stuff - Tiny projects of mine</a><br /> -<a class='textlink' href='./2022-05-27-perl-is-still-a-great-choice.html'>2022-05-27 Perl is still a great choice</a><br /> -<a class='textlink' href='./2011-05-07-perl-daemon-service-framework.html'>2011-05-07 Perl Daemon (Service Framework)</a><br /> -<a class='textlink' href='./2008-06-26-perl-poetry.html'>2008-06-26 Perl Poetry</a><br /> -<br /> -<a class='textlink' href='../'>Back to the main site</a><br /> - </div> - </content> - </entry> </feed> diff --git a/gemfeed/index.html b/gemfeed/index.html index e8198020..bf35dc3c 100644 --- a/gemfeed/index.html +++ b/gemfeed/index.html @@ -15,6 +15,7 @@ <br /> <h2 style='display: inline' id='to-be-in-the-zone'>To be in the .zone!</h2><br /> <br /> +<a class='textlink' href='./2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 - Local LLM for Coding with Ollama</a><br /> <a class='textlink' href='./2025-07-14-f3s-kubernetes-with-freebsd-part-6.html'>2025-07-14 - f3s: Kubernetes with FreeBSD - Part 6: Storage</a><br /> <a class='textlink' href='./2025-07-01-posts-from-january-to-june-2025.html'>2025-07-01 - Posts from January to June 2025</a><br /> <a class='textlink' href='./2025-06-22-task-samurai.html'>2025-06-22 - Task Samurai: An agentic coding learning experiment</a><br /> diff --git a/gemfeed/local-coding-LLM-with-ollama/aider-fix-package.png b/gemfeed/local-coding-LLM-with-ollama/aider-fix-package.png Binary files differnew file mode 100644 index 00000000..58050aee --- /dev/null +++ b/gemfeed/local-coding-LLM-with-ollama/aider-fix-package.png diff --git a/gemfeed/local-coding-LLM-with-ollama/helix-lsp-ai.png b/gemfeed/local-coding-LLM-with-ollama/helix-lsp-ai.png Binary files differnew file mode 100644 index 00000000..24f3d936 --- /dev/null +++ b/gemfeed/local-coding-LLM-with-ollama/helix-lsp-ai.png diff --git a/gemfeed/local-coding-LLM-with-ollama/ollama-serve.png b/gemfeed/local-coding-LLM-with-ollama/ollama-serve.png Binary files differnew file mode 100644 index 00000000..01545bed --- /dev/null +++ b/gemfeed/local-coding-LLM-with-ollama/ollama-serve.png @@ -13,7 +13,7 @@ </p> <h1 style='display: inline' id='hello'>Hello!</h1><br /> <br /> -<span class='quote'>This site was generated at 2025-07-28T15:31:03+03:00 by <span class='inlinecode'>Gemtexter</span></span><br /> +<span class='quote'>This site was generated at 2025-08-04T16:43:39+03:00 by <span class='inlinecode'>Gemtexter</span></span><br /> <br /> <span>Welcome to the foo.zone!</span><br /> <br /> @@ -43,6 +43,7 @@ <br /> <h3 style='display: inline' id='posts'>Posts</h3><br /> <br /> +<a class='textlink' href='./gemfeed/2025-08-05-local-coding-llm-with-ollama.html'>2025-08-05 - Local LLM for Coding with Ollama</a><br /> <a class='textlink' href='./gemfeed/2025-07-14-f3s-kubernetes-with-freebsd-part-6.html'>2025-07-14 - f3s: Kubernetes with FreeBSD - Part 6: Storage</a><br /> <a class='textlink' href='./gemfeed/2025-07-01-posts-from-january-to-june-2025.html'>2025-07-01 - Posts from January to June 2025</a><br /> <a class='textlink' href='./gemfeed/2025-06-22-task-samurai.html'>2025-06-22 - Task Samurai: An agentic coding learning experiment</a><br /> diff --git a/uptime-stats.html b/uptime-stats.html index ed4c618c..028a6b84 100644 --- a/uptime-stats.html +++ b/uptime-stats.html @@ -13,7 +13,7 @@ </p> <h1 style='display: inline' id='my-machine-uptime-stats'>My machine uptime stats</h1><br /> <br /> -<span class='quote'>This site was last updated at 2025-07-28T15:31:03+03:00</span><br /> +<span class='quote'>This site was last updated at 2025-08-04T16:43:39+03:00</span><br /> <br /> <span>The following stats were collected via <span class='inlinecode'>uptimed</span> on all of my personal computers over many years and the output was generated by <span class='inlinecode'>guprecords</span>, the global uptime records stats analyser of mine.</span><br /> <br /> @@ -36,24 +36,24 @@ +-----+----------------+-------+------------------------------+ | 1. | alphacentauri | 671 | FreeBSD 11.4-RELEASE-p7 | | 2. | mars | 207 | Linux 3.2.0-4-amd64 | -| 3. | *earth | 194 | Linux 6.15.6-200.fc42.x86_64 | +| 3. | *earth | 197 | Linux 6.15.7-200.fc42.x86_64 | | 4. | callisto | 153 | Linux 4.0.4-303.fc22.x86_64 | | 5. | dionysus | 136 | FreeBSD 13.0-RELEASE-p11 | | 6. | tauceti-e | 120 | Linux 3.2.0-4-amd64 | -| 7. | *makemake | 76 | Linux 6.9.9-200.fc40.x86_64 | +| 7. | makemake | 76 | Linux 6.9.9-200.fc40.x86_64 | | 8. | *uranus | 59 | NetBSD 10.1 | | 9. | pluto | 51 | Linux 3.2.0-4-amd64 | | 10. | mega15289 | 50 | Darwin 23.4.0 | | 11. | *mega-m3-pro | 50 | Darwin 24.5.0 | | 12. | *t450 | 43 | FreeBSD 14.2-RELEASE | | 13. | *fishfinger | 43 | OpenBSD 7.6 | -| 14. | mega8477 | 40 | Darwin 13.4.0 | -| 15. | phobos | 40 | Linux 3.4.0-CM-g1dd7cdf | +| 14. | phobos | 40 | Linux 3.4.0-CM-g1dd7cdf | +| 15. | mega8477 | 40 | Darwin 13.4.0 | | 16. | *blowfish | 38 | OpenBSD 7.6 | | 17. | sun | 33 | FreeBSD 10.3-RELEASE-p24 | | 18. | f2 | 25 | FreeBSD 14.2-RELEASE-p1 | -| 19. | moon | 20 | FreeBSD 14.0-RELEASE-p3 | -| 20. | f1 | 20 | FreeBSD 14.2-RELEASE-p1 | +| 19. | f1 | 20 | FreeBSD 14.2-RELEASE-p1 | +| 20. | moon | 20 | FreeBSD 14.0-RELEASE-p3 | +-----+----------------+-------+------------------------------+ </pre> <br /> @@ -68,7 +68,7 @@ | 1. | vulcan | 4 years, 5 months, 6 days | Linux 3.10.0-1160.81.1.el7.x86_64 | | 2. | sun | 3 years, 9 months, 26 days | FreeBSD 10.3-RELEASE-p24 | | 3. | *uranus | 3 years, 9 months, 5 days | NetBSD 10.1 | -| 4. | *earth | 3 years, 7 months, 14 days | Linux 6.15.6-200.fc42.x86_64 | +| 4. | *earth | 3 years, 7 months, 22 days | Linux 6.15.7-200.fc42.x86_64 | | 5. | *blowfish | 3 years, 5 months, 16 days | OpenBSD 7.6 | | 6. | uugrn | 3 years, 5 months, 5 days | FreeBSD 11.2-RELEASE-p4 | | 7. | deltavega | 3 years, 1 months, 21 days | Linux 3.10.0-1160.11.1.el7.x86_64 | @@ -80,9 +80,9 @@ | 13. | *t450 | 1 years, 4 months, 28 days | FreeBSD 14.2-RELEASE | | 14. | mega8477 | 1 years, 3 months, 25 days | Darwin 13.4.0 | | 15. | host0 | 1 years, 3 months, 9 days | FreeBSD 6.2-RELEASE-p5 | -| 16. | *makemake | 1 years, 3 months, 5 days | Linux 6.9.9-200.fc40.x86_64 | -| 17. | tauceti-e | 1 years, 2 months, 20 days | Linux 3.2.0-4-amd64 | -| 18. | *mega-m3-pro | 1 years, 2 months, 16 days | Darwin 24.5.0 | +| 16. | makemake | 1 years, 3 months, 5 days | Linux 6.9.9-200.fc40.x86_64 | +| 17. | *mega-m3-pro | 1 years, 2 months, 25 days | Darwin 24.5.0 | +| 18. | tauceti-e | 1 years, 2 months, 20 days | Linux 3.2.0-4-amd64 | | 19. | callisto | 0 years, 10 months, 31 days | Linux 4.0.4-303.fc22.x86_64 | | 20. | alphacentauri | 0 years, 10 months, 28 days | FreeBSD 11.4-RELEASE-p7 | +-----+----------------+-----------------------------+-----------------------------------+ @@ -98,7 +98,7 @@ +-----+----------------+-------+-----------------------------------+ | 1. | *uranus | 342 | NetBSD 10.1 | | 2. | vulcan | 275 | Linux 3.10.0-1160.81.1.el7.x86_64 | -| 3. | *earth | 249 | Linux 6.15.6-200.fc42.x86_64 | +| 3. | *earth | 250 | Linux 6.15.7-200.fc42.x86_64 | | 4. | sun | 238 | FreeBSD 10.3-RELEASE-p24 | | 5. | *blowfish | 218 | OpenBSD 7.6 | | 6. | uugrn | 211 | FreeBSD 11.2-RELEASE-p4 | @@ -109,13 +109,13 @@ | 11. | dionysus | 156 | FreeBSD 13.0-RELEASE-p11 | | 12. | mega15289 | 147 | Darwin 23.4.0 | | 13. | tauceti | 141 | Linux 3.2.0-4-amd64 | -| 14. | *makemake | 131 | Linux 6.9.9-200.fc40.x86_64 | +| 14. | makemake | 128 | Linux 6.9.9-200.fc40.x86_64 | | 15. | tauceti-f | 108 | Linux 3.2.0-3-amd64 | | 16. | *t450 | 106 | FreeBSD 14.2-RELEASE | | 17. | tauceti-e | 96 | Linux 3.2.0-4-amd64 | | 18. | callisto | 86 | Linux 4.0.4-303.fc22.x86_64 | | 19. | mega8477 | 80 | Darwin 13.4.0 | -| 20. | *mega-m3-pro | 78 | Darwin 24.5.0 | +| 20. | *mega-m3-pro | 79 | Darwin 24.5.0 | +-----+----------------+-------+-----------------------------------+ </pre> <br /> @@ -130,7 +130,7 @@ | 1. | dionysus | 8 years, 3 months, 16 days | FreeBSD 13.0-RELEASE-p11 | | 2. | *uranus | 6 years, 7 months, 31 days | NetBSD 10.1 | | 3. | alphacentauri | 5 years, 11 months, 18 days | FreeBSD 11.4-RELEASE-p7 | -| 4. | *makemake | 3 years, 2 months, 2 days | Linux 6.9.9-200.fc40.x86_64 | +| 4. | makemake | 3 years, 2 months, 2 days | Linux 6.9.9-200.fc40.x86_64 | | 5. | moon | 2 years, 1 months, 1 days | FreeBSD 14.0-RELEASE-p3 | | 6. | callisto | 1 years, 5 months, 15 days | Linux 4.0.4-303.fc22.x86_64 | | 7. | mega15289 | 1 years, 4 months, 24 days | Darwin 23.4.0 | @@ -138,7 +138,7 @@ | 9. | mars | 1 years, 2 months, 10 days | Linux 3.2.0-4-amd64 | | 10. | tauceti-e | 0 years, 12 months, 9 days | Linux 3.2.0-4-amd64 | | 11. | sirius | 0 years, 8 months, 20 days | Linux 2.6.32-042stab111.12 | -| 12. | *earth | 0 years, 6 months, 20 days | Linux 6.15.6-200.fc42.x86_64 | +| 12. | *earth | 0 years, 6 months, 20 days | Linux 6.15.7-200.fc42.x86_64 | | 13. | deimos | 0 years, 5 months, 15 days | Linux 4.4.5-300.fc23.x86_64 | | 14. | f0 | 0 years, 4 months, 20 days | FreeBSD 14.2-RELEASE-p1 | | 15. | f2 | 0 years, 4 months, 19 days | FreeBSD 14.2-RELEASE-p1 | @@ -162,8 +162,8 @@ | 2. | dionysus | 8 years, 6 months, 17 days | FreeBSD 13.0-RELEASE-p11 | | 3. | alphacentauri | 6 years, 9 months, 13 days | FreeBSD 11.4-RELEASE-p7 | | 4. | vulcan | 4 years, 5 months, 6 days | Linux 3.10.0-1160.81.1.el7.x86_64 | -| 5. | *makemake | 4 years, 4 months, 7 days | Linux 6.9.9-200.fc40.x86_64 | -| 6. | *earth | 3 years, 12 months, 31 days | Linux 6.15.6-200.fc42.x86_64 | +| 5. | makemake | 4 years, 4 months, 7 days | Linux 6.9.9-200.fc40.x86_64 | +| 6. | *earth | 4 years, 1 months, 8 days | Linux 6.15.7-200.fc42.x86_64 | | 7. | sun | 3 years, 10 months, 2 days | FreeBSD 10.3-RELEASE-p24 | | 8. | *blowfish | 3 years, 5 months, 17 days | OpenBSD 7.6 | | 9. | uugrn | 3 years, 5 months, 5 days | FreeBSD 11.2-RELEASE-p4 | @@ -191,7 +191,7 @@ +-----+----------------+-------+ | 1. | FreeBSD 10... | 551 | | 2. | Linux 3... | 550 | -| 3. | *Linux 6... | 174 | +| 3. | *Linux 6... | 177 | | 4. | Linux 5... | 162 | | 5. | Linux 4... | 161 | | 6. | FreeBSD 11... | 153 | @@ -224,7 +224,7 @@ | 2. | *OpenBSD 7... | 6 years, 9 months, 24 days | | 3. | FreeBSD 10... | 5 years, 9 months, 9 days | | 4. | Linux 5... | 4 years, 10 months, 21 days | -| 5. | *Linux 6... | 2 years, 10 months, 11 days | +| 5. | *Linux 6... | 2 years, 10 months, 19 days | | 6. | Linux 4... | 2 years, 7 months, 22 days | | 7. | FreeBSD 11... | 2 years, 4 months, 28 days | | 8. | Linux 2... | 1 years, 11 months, 21 days | @@ -235,8 +235,8 @@ | 13. | OpenBSD 4... | 0 years, 8 months, 12 days | | 14. | Darwin 21... | 0 years, 8 months, 2 days | | 15. | Darwin 18... | 0 years, 7 months, 5 days | -| 16. | Darwin 22... | 0 years, 6 months, 22 days | -| 17. | *Darwin 24... | 0 years, 6 months, 19 days | +| 16. | *Darwin 24... | 0 years, 6 months, 28 days | +| 17. | Darwin 22... | 0 years, 6 months, 22 days | | 18. | Darwin 15... | 0 years, 6 months, 15 days | | 19. | FreeBSD 5... | 0 years, 5 months, 18 days | | 20. | FreeBSD 13... | 0 years, 4 months, 2 days | @@ -255,7 +255,7 @@ | 2. | *OpenBSD 7... | 435 | | 3. | FreeBSD 10... | 406 | | 4. | Linux 5... | 317 | -| 5. | *Linux 6... | 192 | +| 5. | *Linux 6... | 194 | | 6. | Linux 4... | 175 | | 7. | FreeBSD 11... | 159 | | 8. | Linux 2... | 121 | @@ -265,12 +265,12 @@ | 12. | Darwin 23... | 56 | | 13. | OpenBSD 4... | 39 | | 14. | Darwin 21... | 38 | -| 15. | *Darwin 24... | 33 | +| 15. | *Darwin 24... | 35 | | 16. | Darwin 18... | 32 | | 17. | Darwin 22... | 30 | | 18. | Darwin 15... | 29 | -| 19. | FreeBSD 13... | 25 | -| 20. | FreeBSD 5... | 25 | +| 19. | FreeBSD 5... | 25 | +| 20. | FreeBSD 13... | 25 | +-----+----------------+-------+ </pre> <br /> @@ -282,7 +282,7 @@ +-----+------------+-------+ | Pos | KernelName | Boots | +-----+------------+-------+ -| 1. | *Linux | 1069 | +| 1. | *Linux | 1072 | | 2. | *FreeBSD | 944 | | 3. | *Darwin | 155 | | 4. | *OpenBSD | 101 | @@ -295,15 +295,15 @@ <span>Uptime is the total uptime of a host over the entire lifespan.</span><br /> <br /> <pre> -+-----+------------+-----------------------------+ -| Pos | KernelName | Uptime | -+-----+------------+-----------------------------+ -| 1. | *Linux | 27 years, 11 months, 2 days | -| 2. | *FreeBSD | 11 years, 5 months, 3 days | -| 3. | *OpenBSD | 7 years, 5 months, 5 days | -| 4. | *Darwin | 4 years, 10 months, 7 days | -| 5. | *NetBSD | 0 years, 1 months, 1 days | -+-----+------------+-----------------------------+ ++-----+------------+------------------------------+ +| Pos | KernelName | Uptime | ++-----+------------+------------------------------+ +| 1. | *Linux | 27 years, 11 months, 10 days | +| 2. | *FreeBSD | 11 years, 5 months, 3 days | +| 3. | *OpenBSD | 7 years, 5 months, 5 days | +| 4. | *Darwin | 4 years, 10 months, 16 days | +| 5. | *NetBSD | 0 years, 1 months, 1 days | ++-----+------------+------------------------------+ </pre> <br /> <h2 style='display: inline' id='top-20-score-s-by-kernelname'>Top 20 Score's by KernelName</h2><br /> @@ -314,10 +314,10 @@ +-----+------------+-------+ | Pos | KernelName | Score | +-----+------------+-------+ -| 1. | *Linux | 1851 | +| 1. | *Linux | 1853 | | 2. | *FreeBSD | 799 | | 3. | *OpenBSD | 474 | -| 4. | *Darwin | 316 | +| 4. | *Darwin | 318 | | 5. | *NetBSD | 2 | +-----+------------+-------+ </pre> |
