Hi! I'm announcing my first proper piece of Gemini software: twinwiki! The general idea is that a single line of input[1] works for very few text editing interfaces, yet most of us know one: sed. Mostly people use a very small subset of sed. Here I've implemented a slightly larger subset and I feel you could actually edit pages quite well if the browser showed line numbers. To get a feel, please try out this test instance: gemini://hannuhartikainen.fi/twinwiki Feel free to create new pages and edit the existing ones. All page changes can be reverted. Pages cannot be deleted. I.e. if you're able to break something, it's my fault. The basic wiki features exist: you can edit, create pages, view history, see an index of pages and read help. Some caveats: - Navigating back to a /_edit?<sed_command> URL will redo the edit, which is mostly not what you tried to do. This will probably be an issue on many gemini applications; browsers will need to consider it if applications become a thing. - The sed syntax is not fully POSIX even for the implemented parts: whitespace after commands is taken literally; regex syntax is the one from the Rust regex crate. The project page (git repo, mailing lists, ticket tracker) is at https://sr.ht/~dancek/twinwiki/ Any comments, contributions etc. are welcome. I hope this will give other people other ideas about possible user interfaces. -Hannu [1] A sed command containing newlines will probably work, too, as long as it's percent-encoded properly (ie. \n = %0A). However, the Gemini spec suggests that the input should not contain newlines: "The requested resource accepts a line of textual user input." Is it a bad sin to send multiple lines? -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.orbitalfox.eu/archives/gemini/attachments/20200706/b713 b8ec/attachment.htm>
On Sun Jul 5, 2020 at 9:49 PM EDT, Hannu Hartikainen wrote: > The general idea is that a single line of input[1] works for very few > text > editing interfaces, yet most of us know one: sed. Mostly people use a > very > small subset of sed. Here I've implemented a slightly larger subset and > I > feel you could actually edit pages quite well if the browser showed line > numbers. I really like the idea of using sed for a wiki interface. Nice work. int 80h
On 6/7/20 8:56 am, int 80h wrote: > On Sun Jul 5, 2020 at 9:49 PM EDT, Hannu Hartikainen wrote: >> The general idea is that a single line of input[1] works for very few >> text >> editing interfaces, yet most of us know one: sed. Mostly people use a >> very >> small subset of sed. Here I've implemented a slightly larger subset and >> I >> feel you could actually edit pages quite well if the browser showed line >> numbers. > > I really like the idea of using sed for a wiki interface. Nice work. > > int 80h > Same, what a beautiful idea!
On July 5, 2020 10:49:55 PM UTC, Hannu Hartikainen <hannu.hartikainen+gemini at gmail.com> wrote: >- Navigating back to a /_edit?<sed_command> URL will redo the edit, >which >is mostly not what you tried to do. This will probably be an issue on >many >gemini applications; browsers will need to consider it if applications >become a thing. Maybe we could try adding a volatile session token assigned to each edit request. Then, reject any other edit with the same (and other unauthorized) token. For example:
I tried opening the test instance, but none of my clients can handle it. Kristall says it violates protocol by using CRLF, Castor crashes, Alrisha shows an error, Moonlander error, asuka crashes, diohsc says the header is malformed, etc. I think I finally got it to open with AV98. AV98 don't care. :D -- gemini://kwiecien.us/
Oops! I didn't really read the spec thoroughly and just used println! for the header lines. I changed all header lines to use CRLF. It should work now. -Hannu -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.orbitalfox.eu/archives/gemini/attachments/20200706/1280 9d88/attachment.htm>
Ok with Geminaut. "Edit mode" should display the document with line number :-) freD. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.orbitalfox.eu/archives/gemini/attachments/20200706/094d de1b/attachment.htm>
and edit CGI should prevent multiple execution of the same command :-) freD. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.orbitalfox.eu/archives/gemini/attachments/20200706/85ce 323a/attachment.htm>
On 7/6/20 12:26 PM, Hannu Hartikainen wrote: > I changed all header lines to use CRLF. It should work now. Looks good! Works perfectly in Kristall now -- gemini://kwiecien.us/
On Mon Jul 6, 2020 at 12:49 AM CEST, Hannu Hartikainen wrote: > Hi! > > I'm announcing my first proper piece of Gemini software: twinwiki! > > The general idea is that a single line of input[1] works for very few > text > editing interfaces, yet most of us know one: sed. Mostly people use a > very > small subset of sed. Here I've implemented a slightly larger subset and > I > feel you could actually edit pages quite well if the browser showed line > numbers. Kiitos t??st?! Eritt?in kiva idee. Obviously this sed-based approach is viable for a narrow slice of people, but in general this is a mindset that I would like to see become part of "Gemini culture", i.e. embracing constraints and coming up with creative ways to work within them. I've added this to the software list, and while I was at it, broke all CGI applications (at least the ones I recognised as being CGI applications) out into their own section. If you've written a CGI tool for Gemini and I don't have it listed, please let me know. Cheers, Solderpunk
---