@Tempest said in UX: It's time for The Talk:
As somebody who knows 0 about code, I assume MUSH code is archaic and sort of hack-jobbed, since it varies wildly from game to game, and outside of the copy/paste WoD games or FS3 games, etc, MUs flat out have 'custom code' that somebody just made in their free time.
MUSHcode is a Lisp written by someone who took a Lisp course and didn't really understand it. (He probably got a C+ in his course.) It's a functional language in which user-supplied functions are second-class citizens. (What do I mean by this? Using the results of a built-in function in look like [function(parameter1, parameter2)]
where user-supplied functions have to be stored on some object somewhere like this &SOME_POINTLESS_NAME object=FUNCTION CODE GOES HERE
and is called like this (using its results): [u(object/SOME_POINTLESS_NAME, parameter1, parameter2)]
. What's that? You want lambdas? Closures? BWAAAAAAAAAAAAAAAAHAHAHAHAHAHAHA! He'd have had to have understood those from his Lisp course to have thought of implementing them!
And that's only the lowest level of the problems with the language. The larger scale issues are that MUSHcode resists modularization, so it's actually hard to make shareable code that someone who isn't steeped in the language can use in a "plug and play" fashion. Some attempts have been made at this--heroic attempts whose champions are honoured as they reside in Happy Dale Sanitorium charging up staircases and blowing trumpets--but they really don't work well because out of the box they're pretty vanilla and bland, and customizing them requires, you guessed it, someone steeped in the language. (And because of that resisting modularization thing, using code from more than one source starts exponentially increasing the risk of brought-in code clashing in unexpected and surprising ways.)
Factor into this the added problems that there are three major dialects of the language (Penn, MUX, Rhost) with incompatibilities both subtle and grotesque, that the language was built on a today-bizarre foundation of queued resource management, that the servers all have weird limitations (often based on that queuing system) in unexpected places that requires baffling code to work around, and that until recently code was jealously guarded instead of shared (Rhost once had an NDA you had to sign if you wanted to use it!) and you have a perfect storm of ... well, random hackery and "NIH"-based clusterfucks.
Not to insult anybody or anything, but I'm going to go out on a limb and just say MUD coders are probably better coders, or at least have way more time to code.
Nah. MUD coders just have more access to better tooling for their code bases beginning with the fact that most MUDs are coded in languages for which there are a myriad of resources for learning and a myriad of ways of finding code (that won't break existing code!) to bring in for reuse.
Personally, I find culture variances between muds/MUSHes pretty curious. Little things like how a huge chunk of the MUSH population can't be fucking assed to read the bboard even once a week, where MUDs have forums/etc dedicated to the game and people are commenting about things on the game hourly, nevermind in-game noteboards that get checked p.much every time you log in.
See, that, to me, is one of the turn-offs of MUDding: if you want to play a MUD you pretty much have to dedicate your life to the fucker or get left behind. (By which I mean "killed" of course.)
Well, that and the endless grinding that MUDs seemed to always demand. There was a MUD I tried that advertised itself as "RPI" and bragged about how it was SO ROLE-PLAYING-ONLY! And it was. Even the in-game help was mostly IC. When I made my character I had to interact IC with one of the "helper staff" types (actual IC counsellor positions!) who did a commendable job of guiding me through how to get into the game. Only one problem: here was a typical segment of that help session:
Helper (H): So what kinds of things did you have in mind for your future in our city?
Me (M): Well, I was thinking of learning to be some kind of healer or maybe an apothecary.
H: Commendable choices! Laudable, really!
H (OOC): We really do need more healers. You should get to the sewers and kill rats.
M: (OOC): What?
H (OOC): To get enough experience that you can train as a healer.
M (OOC): <hangs up>
OK, I wasn't quite that abrupt, but that was a serious "wut" followed by a "LOL" moment for me. In this game that prided itself on how IC everything was, beginning characters, each man, woman, or child of them, had to basically start off by going to the sewers to kill automated rats to get experience and money so that they could do the things they ICly (and OOCly, obviously) actually wanted to do.
And that was one of the better MUDs I tried. Bad ones like that Sciorsiecieasceaisareas one (that actually wanted money at one point!) made you micromanage eating. If you didn't make enough money (by grinding, natch!) to buy food or, alternatively, hunt (by grinding, natch!) enough food you died. Travel times were enforced, so if you had to go somewhere to do the grinding you needed to do to live, you could (and I did) die along the way trying to get the food. And this was lauded as "true role-playing" by its advocates when I did the "WTF!?" thing on channels.
So, you know, all that culture shock you had at MUSHes? Guess what happens a lot when people go the other way...