I made a chat program in Visual Basic in college. It sucked as a program, but it had a neat feature I always wanted out of a chat client, which is multiple input windows. Here's an example:
____________________________________
CoolGal27: Hey how's it going?
SmooveDood69: Not bad.
____________________________________
Enter Message:
Actually, I was just getting done with my dissertation on bacteriophages. It's really quite fascinating, these virus-like agents actually attack bacteria, in a similar way to how viruses
...
____________________________________
CoolGal27: Hey how's it going?
SmooveDood69: Not bad.
CoolGal27: Want to meet up for dinner?
____________________________________
Enter Message:
Actually, I was just getting done with my dissertation on bacteriophages. It's really quite fascinating, these virus-like agents actually attack bacteria, in a similar way to how viruses dangerous to you and me would attack our cells. My personal thesis focused on
Goddammit! See, now I have to copy all this text, type in, "yeah sure, but I can't until 7", and paste my long discussion back into the input window.
I'd make a plugin that would give you two or more input windows, so you could have that long thing you were typing along side the quick thing you send over.
Another idea I had was the ability to send a message to multiple people at once. Not in a chat room, just a quick message or two privately. As it stands, if there's a kool link ^_^ that I need all my friendz 2 see, I need to paste it into all the different windows, etc. I'd like to make a plugin that gives the ability to multicast messages.
And dammit why did 2.2 get rid of the font sweep-away icon?!? The greatest thing Pidgin ever did.
Friday, September 28, 2007
Pidgin Gripes
I like Pidgin, it's straightforward, faster than AIM, etc. Last I checked (like 5 years ago or so) Trillian was slow as hell, though I don't use Windows at home anymore anyway. However there are a couple things that really annoy me about Pidgin, and sometimes IM clients in general, so I'm thinking of starting to make plugins to fix it. Kindof like I was going to make Tomboy plugins and still have yet to do. Here are my gripes:
1. Handling of Incorrect Passwords
First and FOREMOST, in any other interface I can think of, if I put in an incorrect password, the application informs me of the situation, and offers me another try. Not so with Pidgin. Maybe you never noticed because you save your password on your machine; that's not for me. (though a Keyring plugin would be super kosher).
No, what it does (if I remember correctly) is inform me that my password is wrong, and offers me to "change my account settings", "connect" (with the same wrong password, as if it'll work the second time), or just give up. Now, when I "modify my account", the bad password I just entered is in the password field. That password field is there for those that want to save the password on the disk. This worried me (since I don't want it on the disk) so I always deleted it from the field. Why was it trying to save my password when I told it not to, I wondered. Turns out that it wasn't actually going to save it, which is a bad interface choice.
Anyway, you go ahead and modify it. Then you disable and enable the account and for whatever reason it still prompts you for a password, so that's how you try logging in again. Lame.
Admittedly, with Pidgin 2.2 (which I just installed and which is strongly diffusing my argument here as I type it) it just says "Pidgin will not attempt to reconnect the account until you correct the error and re-enable the account.", and gives you a cancel button, which isn't much better but is less ironic at least. I still have to go to the menu and re-enable the account. That's much less annoying than it was before. But still, I shouldn't have to do even that, it's easy to make an immediate prompt.
So, a plugin I would make would fix this, and give me a prompt to put in my password again, if I want.
2. Sending messages while away
Remember when this was an optional feature, rather than the standard? I bet AIM still remembers this. I personally end up forgetting to take down my away message when I come back. People remind me. It makes the whole away message thing pointless, it should be up when I want people to think I'm away. Maybe some people don't forget, that's why it's a good option for them.
Though, I still like it in theory. What I would do, and this is something that would solve a gripe with all chat clients, not just Pidgin, is make a plugin that would remind me every X minutes that I was away, if I was typing while away. For convenience, the dialogue would give me the option of coming back from away, too, and probably "don't bug me about it again this time" as well. That way, I could go away, send those few messages I forgot to send, go to lunch, come back, message Cezar, and he wouldn't have to remind me that my message still says I'm at lunch.
3. Away Messages Don't Expire
Whereas the first gripe was with Pidgin and the second with IM clients in general, the third one is with myself. I forget or don't get around to changing my away message. I was apparently showering all day yesterday. What good does this sort of an away message paradigm do anybody? What I would make is the option to set an expiration time for an away message. I'd set an hour for the shower message. Then I would set a subsequent message. Like, work. Maybe I want another subsequent message (because when I get from work, I don't go and take myself off from away first I get home), this message would be a catch-all "At this point I'm not where I was when I last set my message, I can't tell you where I am, but I'm not at the computer, sorry" sort of message.
1. Handling of Incorrect Passwords
First and FOREMOST, in any other interface I can think of, if I put in an incorrect password, the application informs me of the situation, and offers me another try. Not so with Pidgin. Maybe you never noticed because you save your password on your machine; that's not for me. (though a Keyring plugin would be super kosher).
No, what it does (if I remember correctly) is inform me that my password is wrong, and offers me to "change my account settings", "connect" (with the same wrong password, as if it'll work the second time), or just give up. Now, when I "modify my account", the bad password I just entered is in the password field. That password field is there for those that want to save the password on the disk. This worried me (since I don't want it on the disk) so I always deleted it from the field. Why was it trying to save my password when I told it not to, I wondered. Turns out that it wasn't actually going to save it, which is a bad interface choice.
Anyway, you go ahead and modify it. Then you disable and enable the account and for whatever reason it still prompts you for a password, so that's how you try logging in again. Lame.
Admittedly, with Pidgin 2.2 (which I just installed and which is strongly diffusing my argument here as I type it) it just says "Pidgin will not attempt to reconnect the account until you correct the error and re-enable the account.", and gives you a cancel button, which isn't much better but is less ironic at least. I still have to go to the menu and re-enable the account. That's much less annoying than it was before. But still, I shouldn't have to do even that, it's easy to make an immediate prompt.
So, a plugin I would make would fix this, and give me a prompt to put in my password again, if I want.
2. Sending messages while away
Remember when this was an optional feature, rather than the standard? I bet AIM still remembers this. I personally end up forgetting to take down my away message when I come back. People remind me. It makes the whole away message thing pointless, it should be up when I want people to think I'm away. Maybe some people don't forget, that's why it's a good option for them.
Though, I still like it in theory. What I would do, and this is something that would solve a gripe with all chat clients, not just Pidgin, is make a plugin that would remind me every X minutes that I was away, if I was typing while away. For convenience, the dialogue would give me the option of coming back from away, too, and probably "don't bug me about it again this time" as well. That way, I could go away, send those few messages I forgot to send, go to lunch, come back, message Cezar, and he wouldn't have to remind me that my message still says I'm at lunch.
3. Away Messages Don't Expire
Whereas the first gripe was with Pidgin and the second with IM clients in general, the third one is with myself. I forget or don't get around to changing my away message. I was apparently showering all day yesterday. What good does this sort of an away message paradigm do anybody? What I would make is the option to set an expiration time for an away message. I'd set an hour for the shower message. Then I would set a subsequent message. Like, work. Maybe I want another subsequent message (because when I get from work, I don't go and take myself off from away first I get home), this message would be a catch-all "At this point I'm not where I was when I last set my message, I can't tell you where I am, but I'm not at the computer, sorry" sort of message.
Saturday, September 1, 2007
Game Demo Progress
I think I should post my progress as long as I have this Web Log and people are forced to listen by virtue of a feed associated with a certain User Group of a certain class of operating systems. I probably never mentioned this in the first place, but I've been commissioned (probably no money involved; I had a discussion with a friend, I'm pretty sure I can still technically say "commissioned") to make a 2D game engine.
I initially chose C, with Python for scripting. Then I decided that for a prototype I should just do it in Python. Then I figured, why the hell not just make most of the actual product in Python? I would just use C for anything time intensive, such as looking for collisions ( O(N^2), unless there's some industry trick there that I have to learn ) and image effects (generated fire, as opposed to pre-animated fire).
So far I've drafted up my requirements and cleared it with the guys planning the game itself. It was a decent sized doc too, I'm reasonably happy about getting that done. Next is code design, but it was pretty hard to think of how to design it without trying to code it first (a catch 22 of sorts), so I decided to make a prototype(/demo) to help give me the ideas. Turned out downright vital that I did this because things came up that I didn't anticipate at all, as I'm sure is always the case.
For starters, I'm working on the Actor framework. Everything in this game is an actor. They send messages to each other, they have actions every frame, and then they draw. I'm not even worried about them showing themselves at this point, I'm mainly worried about laying out the code and making everything communicate properly. Input isn't really pressing either. I'll probably make a curses output module for starters, just for the heck of it, and just to show off (to myself, I guess) the modular nature (I hope) the engine will have. Actually, I'd mainly do it because it would help demonstrate that everything's working properly, and it's faster to get working than SDL, I would imagine.
So I just got message passing going. I think next I'll put in a quick framework for input (but not bother implementing it yet), but soon go onto other important things like searching for collisions, etc.
After this thing is done, or at least showing enough interesting aspects of my engine, I hope to have a presentation for this user group about game programming and Python. This would probably be my first presentation; I'm not used to doing them and it might be a while before I get around to that.
In this post I'd also like to chime in and say I'm impressed that Gnash works on Youtube, at least on a rudimentary level. Not Google Video though, sadly. So now I won't have to bust my head, having a 64 bit system, until Gutsy comes out and I can easily use the nspluginwrapper (I went from a naive Windows user that would install programs in a semi-irresponsible manner to a naive Linux user that refuses to install anything not from an official repository). Heck I may just stick with gnash, I've heard that it uses Open GL, so it should be faster than Flash. I think it is, really, the load time for the YouTube app is damn near instantaneous, though my computer is fast. Maybe I'll run a little comparison.
I initially chose C, with Python for scripting. Then I decided that for a prototype I should just do it in Python. Then I figured, why the hell not just make most of the actual product in Python? I would just use C for anything time intensive, such as looking for collisions ( O(N^2), unless there's some industry trick there that I have to learn ) and image effects (generated fire, as opposed to pre-animated fire).
So far I've drafted up my requirements and cleared it with the guys planning the game itself. It was a decent sized doc too, I'm reasonably happy about getting that done. Next is code design, but it was pretty hard to think of how to design it without trying to code it first (a catch 22 of sorts), so I decided to make a prototype(/demo) to help give me the ideas. Turned out downright vital that I did this because things came up that I didn't anticipate at all, as I'm sure is always the case.
For starters, I'm working on the Actor framework. Everything in this game is an actor. They send messages to each other, they have actions every frame, and then they draw. I'm not even worried about them showing themselves at this point, I'm mainly worried about laying out the code and making everything communicate properly. Input isn't really pressing either. I'll probably make a curses output module for starters, just for the heck of it, and just to show off (to myself, I guess) the modular nature (I hope) the engine will have. Actually, I'd mainly do it because it would help demonstrate that everything's working properly, and it's faster to get working than SDL, I would imagine.
So I just got message passing going. I think next I'll put in a quick framework for input (but not bother implementing it yet), but soon go onto other important things like searching for collisions, etc.
After this thing is done, or at least showing enough interesting aspects of my engine, I hope to have a presentation for this user group about game programming and Python. This would probably be my first presentation; I'm not used to doing them and it might be a while before I get around to that.
In this post I'd also like to chime in and say I'm impressed that Gnash works on Youtube, at least on a rudimentary level. Not Google Video though, sadly. So now I won't have to bust my head, having a 64 bit system, until Gutsy comes out and I can easily use the nspluginwrapper (I went from a naive Windows user that would install programs in a semi-irresponsible manner to a naive Linux user that refuses to install anything not from an official repository). Heck I may just stick with gnash, I've heard that it uses Open GL, so it should be faster than Flash. I think it is, really, the load time for the YouTube app is damn near instantaneous, though my computer is fast. Maybe I'll run a little comparison.
Subscribe to:
Posts (Atom)