Menu

Tree [46c040] master /
 History

HTTPS access


File Date Author Commit
 common 2022-01-08 Nicolas Weeger Nicolas Weeger [67f73e] Process .artifacts and .formulae files like art...
 doc 2021-12-31 Rick Tanner Rick Tanner [26bcfa] Update wiki url references to use cross-fire.or...
 include 2022-01-09 Nicolas Weeger Nicolas Weeger [0030f6] Remove redundant 'command_prepare' function, ad...
 lib 2022-01-23 Kevin Zheng Kevin Zheng [89f21e] Document 'report' command
 macros 2019-11-27 partmedia partmedia [83a391] Use pkg-config to find Python
 make_win32 2021-12-30 Nicolas Weeger Nicolas Weeger [de6163] Add (basic) help to CRE, with some contextual t...
 plugins 2021-12-04 brian w naasz brian w naasz [46c040] Fix incorrect read/seek usage.
 random_maps 2021-09-29 Nicolas Weeger Nicolas Weeger [16bffa] Remove useless 'break'
 server 2022-01-22 Nicolas Weeger Nicolas Weeger [f0df4b] Remove superfluous space, since 'buf2' always s...
 socket 2022-01-05 Kevin Zheng Kevin Zheng [0c7158] Move todtick to header and document
 test 2022-01-10 Nicolas Weeger Nicolas Weeger [df10b6] Fix symbol duplication issue with GCC 11.2
 types 2022-01-05 Kevin Zheng Kevin Zheng [6b8585] Adjust food when applying existing lanterns
 utils 2022-01-09 Nicolas Weeger Nicolas Weeger [24d0f6] Use 'changes.html' from the help system, don't ...
 .gitignore 2022-01-09 Kevin Zheng Kevin Zheng [c008b6] Update gitignore
 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 2021-11-17 SilverNexus SilverNexus [58c55f] Fix server segfault when spell effects would ki...
 Doxyfile 2022-01-06 Nicolas Weeger Nicolas Weeger [5ef4f1] Display generation date of doxygen-generated do...
 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 2021-12-31 Rick Tanner Rick Tanner [c842fa] Email archives at gmane.org are no longer avaia...
 autogen.sh 2009-02-26 anmaster anmaster [a099ab] autogen.sh: Error out if the various programs c...
 check-fragment.am 2009-02-10 anmaster anmaster [2060ee] test/templates/logresult.xsl: Fix case of tag, ...
 configure.ac 2021-08-18 Nicolas Weeger Nicolas Weeger [8017bc] Move mapper to its own subdirectory

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
  • 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.
  • 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/

MongoDB Logo MongoDB