1
0
mirror of https://github.com/irssi/irssi.git synced 2024-12-04 14:46:39 -05:00
irssi/TODO
Timo Sirainen 89be21cf14 updated for .98.3
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@1406 dbcabf3a-b0e7-0310-adc4-f8d773084564
2001-03-17 03:29:55 +00:00

384 lines
19 KiB
Plaintext

- Irssi saves some setting strings to static const char * variables in
several places.. this works pretty well usually, except when /RELOADing
config and some "setup changed" signal handler goes and calls some
function that still uses the old saved string which points to free'd
memory.. this should somehow be fixed failsafe. maybe just g_strdup()
them everywhere or figure out something better..
- move /FORMATs to default.theme and remove /FORMAT command? or include
"default.formats" in default.theme would be better.. this way it could
have comments and /FORMATs shouldn't really be changed anyway anymore.
- netjoin doesn't always show @ before nick even if it should be there?..
- if there's two channels in one window and same nick netsplits out,
should it print the split message twice?
- when someone in notify list joins, should it be placed to start of
/MSG completion list?
- windows:
- /WINDOW SIZE -sticky, so f.e. /WINDOW BALANCE wouldn't affect it.
- /LAYOUT save|reset doesn't affect anything immediately, only after
restart
- Check that /LAYOUT SAVE works properly with all the different /SETs,
like reuse_unsued_windows, windows_auto_renumber and autoclose_windows.
What should it do if some channel is /PARTed with autoclose_windows
set?..
- /WINDOW scrollback_lines /WINDOW scrollback_hours
- Optionally always start the lines from bottom of the screen when
screen is empty (how would scrolling work?)
- /WINDOW SCROLL OFF - window wouldn't scroll down automatically
- Vertically split windows
- Keyboard handling:
- /BIND: key definitions should be changed to be more epic-like.. :
/bind ^[ key meta, /bind meta-O key meta2, /bind meta-[ key meta2
/bind meta2-c echo Ctrl-Left pressed
and maybe
/bind meta2-C key left, /bind meta-left echo meta-left pressed
- Some kind of state support for it, so it would be possible to make
support for vi keys easily.
- Editor-like (or bash-like) line editor - it would wrap to next line
instead of scrolling.
- When pasting text, irssi could notice it and ask "pasting 30 lines
of text, ok?" .. Could send some signal that sends the pasted lines
in GList which signal handlers could modify. Also the first pasted
line could be somehow buffered so that it isn't sent immediately
so these paste handlers could modify it too.
- Already existing / at start of line handler should use this
- Automatically remove empty space at the start/end of lines,
from start of line it would work so that if each line begins with
4 spaces but some more, it would only remove those 4 spaces from
each so pasting code wouldn't mess up indents etc.
- Skip all autoreplaces and completions, so that f.e. tabs are
printed as-is
- Should empty lines be pasted too? Maybe optionally
- Notify list:
- It's buggy. too buggy. -idle seems to work fine but other than that
it seems to have several problems, sometimes not saying if user has
quit.
- <tommik> hmm, I just did /notify nick, /unnotify nick, /notify nick OPN
and now /notify shows the nick in all networks I'm connected to
- /NOTIFY -away and -idle: support for wildcards in nicks (requires of
course that we're in same channel as nick)
- Automatically add queried nicks to notify list temporarily .. display
the notifys for the nick in the query window
- /NOTIFY -once - notify only once when the user comes to IRC, forget
this after it.
- /NOTIFY -comment xxx - add a comment to notify. print the comment when
user comes to irc.
- "Should we check people in notify list when you're away" option
Scrollback:
- Optionally show a "bookmark" (line mark actually, a line full of '-'
chars) in a window. It would be displayed at the position where you
were when the window was active last time. /MARK command to force
updating it to bottom of screen in active window.
- --more-- should be displayed *only* when there's new text at the
bottom of the screen, not when you scroll up a bit and go visit another
window for a while..
- /SCROLLBACK REDRAW doesn't do anything to non-format lines (should
redraw timestamp, etc.)
- /last 05032 ... didn't really do what I wanted :) maybe I should change
the syntax to have -max parameter instead? Or /LAST -public 1000 would
be ok, but /LAST 1000 would treat 1000 as word.. hmm..
- /LAST -since <timestamp>
- Formats / themes:
- Possibility to modify abstracts and replaces in themes from irssi.
- Document the different formats briefly :)
- /FORMATs don't have styling anymore, so translation to different
languages should be possible with still the ability to use different
themes easily. /SET formats <filename> could change the file where
to read all /FORMATs, but formats in theme file would override them.
- Logging:
- Autologging has some problems if we're printing to some target without
server. Happens at least with "starting query with xxx" when restoring
queries at startup (saved with /LAYOUT SAVE). Also those logs will
never be automatically closed..
- Server commands:
- Optionally wait for a while (0.5-1sec) before sending the message to
server, if arrow up key is pressed abort it. Also remove the line from
screen and put some notice about it being not sent.
- /FLUSHSERVER or something that would remove commands from transmit
queue. Maybe with optional parameter what kind of commands to remove
(/FLUSHSERVER mode would remove all modes). Useful for example if you
want to abort /OP *.
- If we receive "cannot send to channel" from server or "you're not
chanop" events, remove the privmsgs/notices or modes/kicks/etc. from
send queue automatically. Useful for aborting things when you get
kicked after pasting lots of text or deopped after doing /OP * or
something ;)
- Split PRIVMSGs and NOTICEs automatically to multiple commands if
their length exceeds the 512 bytes (or it should be shorter actually
so server won't split it when it adds your nick+host mask)
- server connecting:
- Don't try to restore user modes set by server automatically when
reconnecting to another server. Like when server sets +r mode to you
you won't get rid of it until you /disconnect.
- DNS problems may cause removal of i-line, irssi shouldn't stop
trying to reconnect the server if it happens.. Maybe it never should
stop reconnecting to servers that are in config.
- /RECONNECT <servertag> - If <servertag> belongs to some IRC network,
reconnect to next server in that ircnet, otherwise just reconnect
to the server.
- /SERVER <number> would connect to n'th server in list. Show the
numbers with /SERVER LIST
- /CONNECT <ircnet> could remove existing ircnet connection from
reconnect queue if it exists (only if there's only one?). Also if
we're already connected to the ircnet it could complain about it
and -yes would force it.
- Tab completion:
- Complete aliases
- Command completion doesn't work properly when -options are used.
- Possibility to complete -option parameters? Like -ircnet <tab>, also
/MSG -servertag<tab> and /LAST -level<tab> should work. All of these
require some command definition changes..
- bash-style (or whatever it shoulda be called) tab-completion
- key for reverse completion
- Statusbar:
- It now sometimes wraps to next line messing up screen
- Should be configurable. See http://irssi.org/files/statusbar.txt
for what it probably should look like.
- When starting to run out of space some items could be made smaller,
activity for example .. make some generic flag for items to use.
- Add user counts (ops/voices/normal/total)
- Modules:
- Figure out module vs. plugin wording, what is what ;)
- API for plugins which would be guaranteed not to change
(at least too much/too often :)
- "chat protocol modules" - they could be loaded at startup so they'd be
equal to IRC protocol (autoconnecting servers would work etc.)
- on-demand autoload modules (f.e. by /command or maybe some signal)
- Try to make them create only .so files instead of .a and all..
- perl scripting:
- /SCRIPT for listing scripts, /SCRIPT REMOVE <name>|ALL,
/SCRIPT PERL RELOAD == ex. /PERLFLUSH
- /PERL command - how does signal_add() work with it? probably not well.
How to remove those scripts? etc. /SCRIPT could show them as some
anonymous scripts, maybe list the whole script in the line..
- Possibility to modify entry line somehow
- Possibility to use "complete word" signal, needs GSList** handling
- Add structures: CHATNET_REC, MODULE_REC, THEME_REC, KEYINFO_REC,
CHAT_PROTOCOL_REC
- signal_emit() - if emitting unknown signal, it could automatically
save the types of sent parameters so another perl script could
signal_add() it.
- Perl module and the Irssi and Irssi::Irc libraries could have some
version checks so that if they don't match it would complain.
- Dependencies don't work with .xs files..
- Bigger code changes:
- Restructure code tree so that non-IRC chat protocols would be in
same places than IRC protocol. Something like:
- src/irc (like now)
- src/irc/fe-common, src/irc/fe-text
SILC could then make symlinks to src/silc to whereever the SILC
module was unpacked. Make it possible to build SILC support built-in.
- /SETs have now boolean/number/string types. Add more:
- Time: Allow to use s|m|h|d to specify the time, default to
seconds. When sending reply to user, use the time formatting too,
not just x seconds or minutes. "10d 5s" should also work.
- Level: Like "all -msgs -public". Complain about unknown strings.
- Reading configuration file should be changed somehow .. at least add
some helper functions for reading lists since comments inside them
now crash irssi. Also if setting wasn't expected type can cause
crashes so add proper error checkings everywhere. And is_node_list()
etc. should be in uppercase..
- Would this work..? : command_bind() could specify the parameters
it uses, then some generic command parser could parse the commands
and options and if all is ok, send the parsed parameters directly with
signal_emit() .. I'm just thinking some type checking problems but
if all commands would be in format SERVER_REC, WI_ITEM_REC,
GHashTable *options, char ** (NULL terminated parameters list) .. ?
- GLib's g_mem_chunks does some weird things which seem pretty useless
(keeping memory blocks in a tree), replace them with our own memory
block allocator. GLists and GSLists waste some memory, would be better
if I just made prev/next pointers to structures and used some #defines
to traverse back and forth.
- All there dynamic memory allocations are making lots of memory
fragmentation. Maybe creating our own memory manager would be good
idea? :) Separate allocator for temporary and non-temporary memory
allocations could help some. Use mmap() if possible so we could
actually free the memory with munmap() sometimes..
- /SET -reset?
- /SET awaylog_auto_clear (after setting yourself unaway)
- can't have multiple ignore -patterns with same nick
- /ignore -strip -pattern away * actions ..
- module_uniq_destroy() - those calls are probably wrong .. for CHANNEL and
QUERY at least?
- /ban -time <opt numeric>, /ban -ip?
/alias knockout kick $0 $1-;ban -time $0
- /HILIGHT: list doesn't print several options. Maybe some generic function
which could be used for printing those options for all these /ircnet,
/server add, etc. commands. /IGNORE -pattern isn't printed.
- /HILIGHT -mask <mask> <word>: not possible use both. Case sensitive
hilight checking.
- possibility to use $[123]0 in themes files. Like with $[9]0 in msgnick.
- hide_mirc_colors doesn't work properly, it hides also colors irssi tries
to print itself, like with /HILIGHT. They should be removed somewhere
earlier.. but where? Those should be removed from messages, quit/kick/etc.
reasons but not from at least usernames, bans and channels (maybe they
should be changed to actually print <invert>C</invert>number instead of
coloring it)
- -f configfile command line option. /SAVE should use that file too.
- nick completion shouldn't try completing nicks everywhere, like /SET <tab>
- File completion could guess when it's wanted, word beginning with / (not
at start of line of course, unless / isn't in cmdchars) or ~/ or ./ and
- utf8 support
- /connect -! : don't autojoin to channels
- /names without parameters should probably default to /names *, and add
the possibility to show all names with /names ** (just like /who works)
- printnickmsg() which would print nick changes and quit messages. And
export that function to perl so kills.pl could print kills with it too.
- /MSG a,b,#c,#d - it should print the message to #c and #d channel windows
and show only "a,b" as target when printing it to msg window.. Or if
autoquery is set, it should print them to those windows. Hmm. maybe some
multipeople query support? :) /query nick1,nick2 and sending text there
would send it to both. Seems to work already but receiving messages from
either nick1 or nick2 don't go to that window..
- /MSG =dcc_chat,#channel doesn't work, same for /CTCP.
- regexp host masks
- irssi proxy: when writing msg in proxy, send them to clients.
- /SAVE -all: save all /SETs and /FORMATs.
- dcc time left
- ban list prints "x seconds ago" .. should be x days, mins, hours, ..
- some script to handle ctcp floods, like doing /IGNORE * CTCPS when it
happens.
- netsplit quit isn't printed if quit -> join -> quit -> join happens fast
*** New stuff in TODO, try to get rid of these :)
- /ignore -activity .. would ignore it just in window activity list,
not hide the text.
- when dcc chat is accepted and query exists from the same nick, replace
the query window with the dcc chat window.
- try profiling the code with /cat filewith10000lines
- automatically switch to status window when using commands that always
print their output to status window, like /whois.
- automatic whowas if whois wasn't found should be moved to fe-common.
it could also print something like "nick $0 not in IRC, but this user
WAS in IRC:"
- Add command for changing automatic replaces (/replace)
- commands to move channels and servers in the config list, to set the
join/connect order of them.
- Make /SET HOLD_MODE
- /CAT should pause on every screenful of text, this should be some kind of
printtext_multiline_paused() function which would use some callback to
ask for new text.
- /ON and /TIMER commands
- All those options to /WHO and /LIST commands that EPIC has
- /SCROLLBACK FIND ?
- nick/channel lists at right side of the text version of irssi. Ctrl-N
for example could hide/show them. add mouse support for it.
- /password command that asks you to type the password to entry line and
would hide it with asterisks, good if people spy on you :)
- CTCP #channel HISTORY # - give # last lines of history from channel
*** Bugs
- still some problems in detecting floods right? not sure, couldn't
reproduce the problem again..
- match_wildcards(), mask="*a?c*", data="abdabc"
*** GTK UI
- %| doesn't work with irssi text widget
- some problems when using multiple windows with focus being all the time in
one of the windows and it can't be changed to different window?! Probably
has something to do with click to focus.
- split windows are buggy, destroying them doesn't really work well..
- mirc ctcp togglemenuitem isn't updated right
*** Big things
- some sort of address book? our own irssi ctcp to ask for other irssi users
for their information (of course not without asking (except optionally))..
could be nice also to automatically update it, keep track of all seen
users gathered when joining channels, whois, who, etc. commands.
automatically updating information could be host masks, nicks, ips, seen in
channels, operator in channels, .. user specified checks like last topic or
mode changes or even msgs to you/some channel/with some keyword. great for
spying people ;) maybe even useful sometimes..
.. but what database would be best for this?
- GTK (non-GNOME) version: icons to toolbars, accelerators to menus
- Windows style MDI windows are possible with GtkFixed .. Some people would
like this.. too much job for me, it would need building the MDI windows
ourself (title bar, borders, resizing, etc.)
- online help, documentation, ...
- plugins:
- scheme, tcl, python scripting? eggdrop/epic compatible scripting?
- IRC bot, eggdrop is too old, needs a replacement ;) (started)
- DCC file server (xdcc, fserver), I'm not too excited about these,
maybe someone else wants to do it..
- Multiplayer games! :) Chess, tic-tac-toe, othello, battleship, tetris,
etc. Existing games should probably be used .. though there doesn't
seem to be any of these (except tetris) for gnome right now..
- audio / video chat :)
*** Needs rethinking ..
* Notify list GUI
- _one_ popup dialog could open which lists all nicks in notifylist, maybe
sorted by arrival time, display the dates, latest joined could be with
different color? etc.
- nick-specific options:
- pop up the dialog
- run some command (like /exec as soon as I get that done :)
* common api for statusbar handling
- it should work just as well in text mode and gui, colors could be done
with the normal % formats. GUI just ignores the colors..
- display number of ops, voices, normals and ircops in statusbar
* API for creating/modifying menus and toolbar, especially from plugins
- at least one configurable menu ("usermenu"), or maybe make the whole
menubar user configurable
*** Stuff to do
- you could configure which events (whois, notify, etc.) to show in what
windows (all, current, status, msgs)
- implement requesting files with DCC GET from remote client for dcc file
servers. good for people behind firewalls.
- /CLONES command (with script)
- {}|~ are same as []\^ (not in all irc networks) - does this really affect
irssi at all..?
*** ..in GTK UI .. just some things to remember if i'll rewrite it again.
- itext:
- save/find text
- text selection draws the entire selection every time you move the
mouse...
- if some other window has got much text, switching to it first time
takes some time..?
- editor in setup for ~/.irssi/startup
- dcc floods could pop up lots of dialogs..
- gui help
- change signal handling in gui-gnome so that the actual drawing and
functionality are in different signals, so that plugin could change the
whole look and feel of irssi.
- currently irssi sends USERHOST commands every now and then to find out
who are away and who are not.. optionally it could instead just watch if
someone hasn't written anything to channel in n minutes and mark it "away"
to nicklist.
- check new irssi versions with http rather than with irssibot..
- gnome statubar:
- clock?
- dcc transfer meter (gtk progressbar)
- dcc send: allow selection of multiple files to send (also for dnd from
gmc!) Allow dropping files to anywhere in irssi.