You are not logged in.

I forked cliwiki to make some improvements, and the result is a simple curses UI for accessing MediaWiki wikis.
- Curses UI
- Basic Vi-like key bindings including ex commands
- Table of contents to skip through article
- Enter page name as a parameter or open page through search box
- Basic support for bookmarks
- Supports multiple wikis (including the Arch Linux wiki)
- Zsh completion
- Basic support for editing pages
- Browse links on page with :links and :iwlinks for inter-wiki links
- Go back and forward in history
Github
AUR Package
AUR git Package
Last edited by ids1024 (2015-04-13 23:11:53)
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

I have added support for other MediaWiki-powered wikis, such as the Arch Wiki:
wikicurses --wiki https://wiki.archlinux.org/api.php Dwm"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Oh, that's nice! I'll use it for a while and get back at you if I find anything.
Offline
Awesome sir... will check it out and let you know.
"First learn computer science and all the theory. Next develop a programming style. Then forget all that and just hack." ~ George Carrette
Offline
Looks nice so far.
wikicurses.conf(5) says:
SYNOPSIS
       /etc/wikicurses.conf
       ~/.conf/wikicurses/configBut the second should be ~/.config/wikicurses/config
Last edited by null (2014-10-12 10:43:13)
Offline

Looks nice so far.
wikicurses.conf(5) says:
SYNOPSIS /etc/wikicurses.conf ~/.conf/wikicurses/configBut the second should be ~/.config/wikicurses/config
I've fixed that now.
Edit: I also fixed some incorrect spellings.
Last edited by ids1024 (2014-10-12 15:05:12)
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Update: Wikicurses now supports editing pages.
I have added the command ":edit", which opens the page in $EDITOR (defaulting to vim), asks for a commit message, and uploads it. To use this feature, username and password must be added to the section of the configuration file for the wiki to be edited.
Edit: Feature requests are welcome.
Last edited by ids1024 (2014-10-26 15:03:03)
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

I have released version 1.0 and created a wikicurses package in the AUR.
Also, I have added the ability to go back and forward in history (i.e. a back button), a :links command to browse the internal links on a page, and an :iwlinks command to browse interwiki links. Various other minor or less user facing changes have been made since my last post.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Version 1.1 with bug fixes and some small features:
https://github.com/ids1024/wikicurses/releases/tag/v1.1
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline
Is there a way to search within a page, like / in less or vim?
Offline

Search functionality is on the todo list but is not yet possible.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

@hagabaka I have just pushed rudimentary search functionality to the git repository. It is incomplete, but could be useful. Use it with the / key just like in vi.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Released version 1.2. The main addition is the search feature, though it is somewhat limited.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Nice project. Any plans to add colour options in the config?
Having different colours for titles and links could be neat
Offline

Nice project. Any plans to add colour options in the config?
Having different colours for titles and links could be neat
Good idea. I have added it to TODO and will implement it when I have time.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

I have added support for custom colors to the customcolors branch. I still have to add support for colorizing various other things, and to consider if there is a better way to configure the colors than what I have set up.
Other than colors, I have also added a :langs command to see a page in different languages, as well as some bug fixes and other small changes.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline
Nice! Added a short note on the wiki (of course feel free to modify as you think).
The usability is already pretty high, there is just one thing that struck me: the spacing of the blocks on the page is IMHO wrong. Consider the following example (from the Beginners' guide):
Connect automatically to known networks
 Warning: This method cannot be used with explicitely enabled profiles, i.e. through netctl enable profile.
Install wpa_actiond, which is required for netctl-auto:
# pacman -S wpa_actiond
Enable the netctl-auto service, which will connect to known networks and gracefully handle roaming and disconnects:
# systemctl enable netctl-auto@interface_name.service
 Tip: netctl also provides netctl-ifplugd, which can be used to handle wired profiles in conjunction with netctl-auto.Here, the first line is the section title and it appears as bright white, underlined in the terminal, but the rest appears quite unreadable. The code lines starting with '#' blend with the text followed, there is a blank line before but not after the code line. Also the Warning and Tip notes, which can be identified by <div> tags in the HTML, could be spaced from the surrounding text to make them more outstanding.
I'd suggest to try to detect the blocks the page is made of and insert a (single) blank line between them to make the result more readable. The code (inside <pre> tags) could also be indented. It may be hard to implement consistently for various wikis, but I think it's worth a try. What do you say?
I'll surely take a look at the code when I find some time, I could potentially make use of it to implement some interactive features planned for wiki-scripts.
Offline

Also the Warning and Tip notes, which can be identified by <div> tags in the HTML, could be spaced from the surrounding text to make them more outstanding.
Obviously that can't be done do every <div> tag, since modern html code has divs everywhere. I guess the solution would be to parse the style attribute and add padding when padding is included. It might be possible to also respect the css border and add a border around it as well. I think that will work, and it will probably be useful for some other wikis as well.
I'd suggest to try to detect the blocks the page is made of and insert a (single) blank line between them to make the result more readable. The code (inside <pre> tags) could also be indented. It may be hard to implement consistently for various wikis, but I think it's worth a try. What do you say?
The code currently adds a blank line after </p> tags. I can make it do the same for other block-level elements like <pre>. As for indenting <pre> tags, do you know if that would cause issues with other wikis?
Edit: Indenting/padding certain blocks of text will require some somewhat complicated changes to how text is displayed in wikicurses. Not to say I won't do that, but for now I have just made <pre> tags green (by default, colors are customizable). Not perfect, but the code stands out well.
Last edited by ids1024 (2015-04-13 23:56:38)
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

Wikicurses now by default adds 3 spaces of padding to <pre> tags.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

With the latest commit, the Warning and Tip boxes have borders and are padded.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline

I see I never got around to releasing the last changes, so I just released 1.3.
"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline
Wikicurses is really neat - Thank you ids102!
I'd like to save the output to text instead of displaying it. I've tried piping it to tee with no luck. I came across instructions on how to output a man page to text:
man wikicurses | col -bx > output.txt
This doesn't work either. Is there any way pipe the output to a file? If this is not possible from a curses application like this, do you plan on adding a "print" type function? My goal is to script a list of ~50 wikipedia articles and save them for offline terminal reading.
Kind of like this but not on such a large scale - http://www.evanjones.ca/software/wikipedia2text.html
Offline

It could be good to add such a feature, but it would lose the formatting, such as boldfacing, color, underline, centering, etc. You can use a python script and import the module directly to get the unformatted text.
from wikicurses.wiki import Wiki
wiki = Wiki.fromPageUrl('http://en.wikipedia.org')
article = wiki.search('Linux')
print(''.join(i[1] for i in article.content))"Only wimps use tape backup: _real_ men just upload their important stuff on ftp, and let the rest of the world mirror it."—Linus Torvalds
s/ftp/git/
https://iandouglasscott.com | https://github.org/ids1024 | https://keybase.io/ids1024
Offline
That works great. Thanks!
Offline