Menu

Tree [9d29f5] master /
 History

HTTPS access


File Date Author Commit
 common 2024-10-10 Kevin Zheng Kevin Zheng [9d29f5] Add null check
 doc 2024-05-20 Kevin Zheng Kevin Zheng [ac7c98] Add map labels
 include 2024-06-06 Kevin Zheng Kevin Zheng [5f2ce5] Remove custom map swap times
 lib 2024-06-11 Kevin Zheng Kevin Zheng [b63885] Add documentation for 'swap' command
 macros 2022-07-15 Nicolas Weeger Nicolas Weeger [a406b3] Add missing macro, adjust configure.ac
 make_win32 2023-11-19 Nicolas Weeger Nicolas Weeger [dd62d7] Fix macros
 plugins 2024-02-15 Kevin Zheng Kevin Zheng [0f5473] Do not log scripts by default
 random_maps 2024-05-19 Nicolas Weeger Nicolas Weeger [a57071] Add a random map settings to set the source map...
 server 2024-08-17 Kevin Zheng Kevin Zheng [a86982] Add removed object check to prevent crash
 socket 2024-09-02 Kevin Zheng Kevin Zheng [cf6698] Improve error message
 test 2024-05-19 Nicolas Weeger Nicolas Weeger [9c65db] Fix unit test
 types 2024-03-25 Kevin Zheng Kevin Zheng [52262e] Fix another unique map check
 utils 2024-10-09 Kevin Zheng Kevin Zheng [c68d98] Add startup error checks
 .gitignore 2023-01-20 ChristopherPH ChristopherPH [c0f601] Add additional git ignore directories
 AUTHORS 2021-12-31 Rick Tanner Rick Tanner [26bcfa] Update wiki url references to use cross-fire.or...
 COPYING 2002-09-07 mwedel mwedel [6fdb6a] Automake patch - all files.
 ChangeLog 2024-04-04 silvernexus silvernexus [bdda0e] Nerf death attacks again.
 Doxyfile 2022-11-01 Nicolas Weeger Nicolas Weeger [8d7c1e] Fix references
 INSTALL 2013-08-09 partmedia partmedia [c4c7c2] Update autoreconf-generated files.
 Makefile.am 2021-08-02 Kevin Zheng Kevin Zheng [d5aef7] Remove performance test from default build
 README.rst 2022-08-25 Kevin Zheng Kevin Zheng [c8d4b6] Update dependencies
 autogen.sh 2009-02-26 anmaster anmaster [a099ab] autogen.sh: Error out if the various programs c...
 check-fragment.am 2022-06-08 Kevin Zheng Kevin Zheng [8e4fc8] Replace bash substitutions with sed
 configure.ac 2023-04-16 silvernexus silvernexus [f5a0eb] Correct autoconf use of AC_ARG_ENABLE to handle...

Read Me

Crossfire Server

Author:Crossfire Development Team <crossfire@metalforge.org>
Website:http://crossfire.real-time.com/

Crossfire is a free, open-source, cooperative multi-player RPG and adventure game. Since its initial release, Crossfire has grown to encompass over 150 monsters, 3000 areas to explore, an elaborate magic system, 13 races, 15 character classes, and many powerful artifacts scattered far and wide. Set in a fantastical medieval world, it blends the style of Gauntlet, NetHack, Moria, and Angband.

Note

You do not need the server to play Crossfire. Crossfire Server is only for those who wish to run their own server.

Installation

Dependencies

Crossfire runs on most POSIX-compliant systems, including Linux and BSD. Compiling Crossfire requires:

  • A C compiler supporting at least C99
  • A C++ compiler
  • Crossfire archetypes (from a release tarball or Git)
  • Crossfire maps (from a release tarball or Git)

If you are building from Git, you also need:

  • autoconf/automake
  • pkgconf/pkg-config
  • libtool
  • flex

In addition, there are a number of optional dependencies that make the game even more fun. These include:

  • Support for dynamically loaded libraries. Most modern operating systems should have it. This is needed for server plugins.
  • Python 3 - this is needed for the Crossfire Python plugin (CFPython) and is highly recommended. Most maps, quests, and NPCs will not work without it. On some platforms, you will need the "development" package that comes with header files.
  • SQLite3 - for cflogger and cfnewspaper. These plugins are still under development and aren't very useful at the moment.
  • Check - for unit tests. This is only required for plugin developers.

Compiling

Symlink the Crossfire archetypes and maps in the source directory:

$ ln -s /path/to/crossfire-arch lib/arch
$ ln -s /path/to/crossfire-maps lib/maps

If you are building from Git, run autoconf:

$ autoreconf -i

Generic instructions for using autoconf/automake are in INSTALL. We recommend building with debugging symbols on (-g) and low optimization (-O0) to assist in debugging crashes. Briefly:

$ ./configure CFLAGS="-g -O0" CXXFLAGS="-g -O0"
$ make
$ make install

An older, step-by-step guide is available on the wiki: http://wiki.cross-fire.org/doku.php/server:server_compiling

To build the Crossfire Resource Editor (CRE), first build the server, and then run:

$ cd utils/cre && qmake && make

Final Steps

  • Configure your server (see $PREFIX/etc/crossfire/)
  • Make maps available in $PREFIX/share/crossfire/maps/

Usage

You should now be able to run the server:

$ crossfire-server

Getting Help

Website

Official Website: http://crossfire.real-time.com/

Crossfire Wiki: http://wiki.cross-fire.org/

SourceForge Downloads Page: http://sourceforge.net/projects/crossfire/files/

IRC

It's possible to link up with a small community of Crossfire players and developers on irc.libera.chat in the #crossfire channel. Though activity waxes and wanes, it's often possible to get live help there.

Mailing Lists

For the latest subscription for crossfire mailing lists, go to: http://crossfire.real-time.com/mailinglists/index.html

There you can subscribe/unsubscribe any of the mailing lists. Links to archives of the mailing lists can be found there, as well as at: https://www.mail-archive.com/crossfire@metalforge.org/

Contributing

Reporting Bugs

Bugs should be filed in the Crossfire bug tracker on SourceForge: http://sourceforge.net/p/crossfire/bugs/

When reporting bugs, make sure you include the following:

  • If you have a sourceforge login, make sure you are logged in. This way, if there are questions about the bug, you will be notified about the request for more information.
  • What version of crossfire did you use?
  • What type of computer did you use (CPU type)
  • What is the version of the OS?
  • What compiler (and its version) did you use (ie, gcc, icc, etc)?
  • Which flags did you give it?
  • If the bug happens when compiling crossfire, send an EXACT copy of the compiler line, as well as the errors it puts out. Sending bugs of the sort 'it failed with a line like ...' doesn't help at all.
  • If you are using any of the plugins, what version(s) of Python and SQLite do you have installed?
  • If the bug happened while running crossfire:
    • Include any output before to the bug.
    • Give a description of what you did before the bug occurred. The better detailed the description, the better chance we have of figuring out where the bug happened, or how we can recreate the bug.
    • If possible, a stack trace from gdb (or other debugger) is very helpful.

The more information provided, the better chance of the bug being fixed in a timely fashion.

Further debugging information can be found at http://crossfire.real-time.com/debugging_tips.html

Reporting Crashes

Your server must be compiled with debugging symbols enabled for your crash reports to be useful.

When your server crashes, look for a core dump file. Run the following command and include the output in your bug report:

$ gdb /path/to/crossfire-server /path/to/core_dump -batch -ex 'backtrace'

Submitting Patches

See the doc/style-guide.txt file.

Patches should be sent to the Crossfire patch tracker on SourceForge: http://sourceforge.net/p/crossfire/patches/