A MUD server written in Java which aspires to be something of a general purpose framework for such games. For example, I have adopted the MUSH/MUCK convention of allowing exit names to be arbitrary text (rather than n/s/e/w), although there may be some support for reliably using the latter in the future (nothing explicity prevents creating exits with those names). Also, there is a fairly limited internal scripting system highly reminiscent of MPI from Fuzzball MUCK (http://www.belfry.com/fuzzball/mpihelp.html). Which is to say that it allows setting, modifying, and checking properties on each object. In general, though the code sticks closer to the hardcode end (at the moment) regard game systems and mechanics.
This code is very much in an unfinished state, despite the fact that it is fairly stable and usable. As such, there may occasionally be radical shifts in the inner workings in the future. It would be wise to regularly backup the database if you use this code as, despite the above, it may have occasional stability problems and attempting to switch to a newer version may result in corrupted data and/or the server may someday utilize an alternate approach for data storage.
This code requires at least Java 8 (1.8) due to use of streams and predicates.
Google-gson is used for handling JSON files in certain places.
Usage: java -jar mud_server.jar [ parameters ]
--port <port number> Specify the port for the server to listen on, default is 4000
--db <database> Specifies the database file to load (databases directory)
--debug Enable debugging messages
--enable-logging Enable logging of various things
--enable-testing Enable certain code that's being tested
--int-login Use an interactive login (as opposed to simple 'connect <name> <password>')
--magic Use the magic stuff for games with magic
--module <identifier> Specifies one of a set of pre-existing modules to use (these are object Classes)
--setup Run first time setup
--telnet Indicate that you'd like the server to handle pure telnet
--theme <theme> Specifies a theme file to use (theme directory)
--use-accounts Use the account system instead of one-to-one login/player
* generally speaking, you will only use setup once, and can run the server with just that
* parameter if you just want to generate the necessary files and don't need anything else set
* telnet connections here just means a raw connection sending one character at a time
See Installation and Setup for more details.
For help using the code and miscellaneous documentation, see the Wiki for this project.
Pay attention to the following Trello board for future plans and progress info: MUDServer Dev
Copyright (c) 2012-2019 Jeremy Harton. See LICENSE.txt for further details.
The license given basically applies to all files in the source (MUDServer/src) directory unless otherwise specified here or in a file (license-exclusions.txt) within the package/folder in question. It does not apply to any data files that might be included.