/majik3

Historical source code of an early text-based online RPG from 1998. Can be used as a base for creating new MUDs. Still works well.

Primary LanguageCGNU General Public License v2.0GPL-2.0

Foreword
--------

This repository contains legacy source code, but may be of historical
interest to someone. 

The code is written in LPC, which is a C-like scripting language. It
requires LPC driver to run it. Originally, Majik used MudOS v22.1b22 to
run it. Today, FluffOS is able to run it:

	https://github.com/fluffos/fluffos

Before compiling, copy 'local_options' file to fluffos's src directory.
For compiling FluffOS, the following cmake options were used:

	cd build && cmake .. \
		-DMARCH_NATIVE=OFF \
		-DSTATIC=ON \
		-DPACKAGE_MUDLIB_STATS=ON \
		-DPACKAGE_PARSER=OFF \
		-DPACKAGE_EXTERNAL=OFF \
		-DPACKAGE_DB=OFF \
		-DPACKAGE_SOCKETS=ON \
		-DPACKAGE_MATRIX=OFF \
		-DPACKAGE_MATH=ON \
		-DPACKAGE_DEVELOP=ON \
		-DPACKAGE_CONTRIB=ON \
		-DPACKAGE_UIDS=ON \
		-DPACKAGE_COMPRESS=OFF \
		-DPACKAGE_PCRE=OFF \
		-DPACKAGE_TRIM=OFF \
		-DPACKAGE_SHA1=OFF \
		-DPACKAGE_ASYNC=OFF

Please note, the majik.netti.fi or majik3d.org URLs no longer exist.
A new site has been set up for providing the old content:

	https://majik3d-legacy.org/

You can also use https://archive.org :

	https://web.archive.org/web/20000918015419/http://majik.netti.fi/majik3.html
	https://web.archive.org/web/19981212015504/http://majik.netti.fi/
	https://web.archive.org/web/20000603091141/http://majik.netti.fi/
	https://web.archive.org/web/20030725230727/http://www.majik3d.org/
	https://web.archive.org/web/20060424051359/http://www.majik3d.org/

Also, the e-mail addresses no longer work. For contacting the original
development team, you can try namhas at gmail . com.

The later open source versions of Majik are available from:

	https://github.com/tleino/majik4
	https://github.com/tleino/majik4-client
	https://github.com/tleino/majik4-client-drac
	https://github.com/tleino/majik3d-client
	https://github.com/tleino/majik3d-simple-server

The original open source final release tarballs are archived at:

	https://majik3d-legacy.org/attic/

What is Majik 3, this mud library?
----------------------------------

Majik 3 is the Majik Project's third incarnation which was up and
running within years 1997 and 1998. The purpose of Majik 3 and the
whole Majik project has always been to provide an actual, working
roleplaying enviroment that would be completely player-controlled
and self-sustaining, without the need of outside administration and
control. Majik 3 was a third try. It would have been a success as a
MUD, but we saw that a text-based model consisting of rooms instead
of grids was inadequate for our purposes. This copy of Majik 3 is
taken from a backup just before a big conversion to make the MUD
playable using telnet but would be a roguelike, a gridmap based
game anyways. The date of the backup is January or February, 1998
and the state of Majik at the time was alpha testing, not playable
at all, except you could grow carrots, make money and do some
exploring. See http://majik.netti.fi/majik3.html for an old web page
made for Majik 3 when it was up and running and still maintained by
Majik Development Team. There you'll find for example, a world map.

Why did you release the source code?
------------------------------------

We saw it more fun to release the source code than leaving it to stay
on our shelf without use. We hope that this would make Majik's ideas
and history more widely known and to give many MUD admins something
to play with and for some, possibly a base where to build a game on. We
would really like to see that our code would be useful for someone when
it is no longer of any use for us. It would be great to see Majik 3
up and running somewhere once again with active coders trying to make
it playable. You are allowed to do whatever you wish with the source,
this is our contribution to the Open Source community.

The Majik Development Team is now concentrating on making Majik's fifth
incarnation, the Majik 3D project, an online role-playing environment
using modern 3D-technology and thus doesn't have time to maintain its
predecessors anymore. If you want to find more about our current project,
or even join the project, you should see the webpage: http://majik.netti.fi,
you could also send some mail to majik@majik.netti.fi and tell us if you
are using parts of this pile of source code or even building a MUD on top
of it. We would really like to hear if our previous work is still useful
for someone.

So how to get started then?
---------------------------

First you need to compile a mud driver. The library is made for MudOS
but should be possible to convert to any other lpmud library, but it
would need work, a lot of work. To get a suitable MudOS driver you do
the following if /majik is the directory where you keep your copy of
Majik 3 and v22.1b22 is the current beta version of MudOS.

  $ cd /tmp
  $ ftp ftp.aragorn.uio.no
  ftp> cd pub/LPC/servers/MudOS/
  ftp> get beta.tar.gz
  ftp> quit
  $ tar zxf beta.tar.gz
  $ cd v22.1b22/
  $ cp /majik/local_options .
  $ ./build.MudOS
  $ make
  $ strip driver
  $ cp driver /majik/bin/
  $ rm -rf /tmp/v22.1b22
  $ cd /majik
  
At this point you need to edit "majik3.conf" file and replace the lines
"mudlib directory" and "binary directory" with a correct path and then:

  $ bin/driver majik3.conf &

The driver should be now up and running and you should be able to telnet
localhost 7600, if you didn't change the port in the configuration file.
It this didn't work you should double-check everything and if still you
have trouble and no clue, send mail to the Majik Development Team.

Admin character
--------------

To make an admin character for you, you need to make a mortal character
first, then log out and edit file /data/player/<first letter>/<your name>.o
and add a line "security 100" at the end of the file and then make a home
directory. For example if you name would be "Admin" you would do the
following after you have made a mortal character and logged it out using
"quit" command.

  $ echo >>/lib/data/player/a/admin.o "security 100"
  $ mkdir lib/home/admin

This same applies to all the other characters, except that for the others
you might not want to give security level 100, just start from 1 and give
more levels when you see it appropriate.

Extending the world
-------------------

To build new areas you might want to read all doc/lpc-tutorial files to
learn LPC programming and then read as many doc/majik files as you dare,
and files from doc/majik/handbook too. Build yourself a workroom and
then you might want to try "redit" command also, a nice room editor
which you can use actually for most of the tasks. Whether or not continuing
using the redit (there is also iedit, the item editor), you'll need to
make a new directory to /world and build your area there. Then just link
it to world using an exit from some already existing area and/or add a
link to your area directly from worldmap using a scenic location. Go
there using goto command for example: "goto /world/y200x200" and modify
the environment to your taste using "designate" command, you can see
the symbols using "describe" command and then finally transform one grid
to scenic location "?" and save the changes, "designate save". Then cd
to /world/virtual/ and list your area in AREAS file and copy some existing
y<n>x<n>.c to a new name with your coordinates (y200x200.c for example)
and edit it. So simple. If problems, the address is below.

-- 
Majik Development Team
majik@majik.netti.fi http://majik.netti.fi