Skip to content

Thoughtrights/donjonrp

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fork Change Summary

  • Resolved several compiler fatal and warning errors.
  • Added commandline options
  • Re-added stdout
  • Made the commandline input and GIF stdout a compiler option. gcc -D ARGS_AND_STDOUT -O3 worldgen.c -lm -o gengif

Why fork?

  • Code currenly hasn't been touched in 10 years.
  • The original code is over 25 years.
  • I am not going to send in a PR.

Extraneous info

  • I adapted a CGI front-end to an earlier version back in 1996.
  • That version stopped working when I moved off of the SPARC architecture ... a long while ago.
  • I decided to fix it. It lives over in a dusty "Functional Relics" section at https://dungeoneer.com/ which I'm rejuvinating.

Originally from http://donjon.bin.sh/code/ , ©2009-2015 "drow"

Four separate tools: A name generator, a random generator, a fractal world generator and a random dungeon generator.

#Name Generator ##How it Works

This name generator constructs and uses Markov chains. Given a list of sample names, it analyzes each name to construct frequency tables for name length and letter pairs. It then uses these tables to construct a new name in the style of the sample set.

##Source Code

The following source code provides a JavaScript random name generator, and some example data. The name generator is released to the public domain. The example data is drawn from Kate Monk's Onomastikon, © 1997 Kate Monk.

##Using the Generator

First, you'll need to create a JavaScript data file. This file defines an array list of sample names as a named element of the name_set object (which is declared in name_generator.js).

Then, include both the name_generator.js file and your data file in your HTML page. A clever person might note that you could easily create and include more than one data file here.

<script type="text/javascript" src="name_generator.js"></script>
<script type="text/javascript" src="egyptian_set.js"></script>

The generate_name() function accepts a single argument, the name of your name set, and returns a text string. You can simply write this text string to the HTML page...

<script type="text/javascript">
  document.write(generate_name('egyptian'));
</script>

Nerkho

Or assign it to a variable in your own JavaScript code. You may also be interested in the name_list() function, which accepts the name of a name set and a number, and returns an array of generated names. ##tl;dr

#Random Generator

##Source Code

The following source code provides a simple yet flexible JavaScript random text generator, and some example data. Both are released to the public domain.

##Using the Generator

First, you'll need to create a JavaScript data file. This file defines tables as named elements of the gen_data object (which is declared in generator.js). Typically, the first or main table in the file contains text patterns, which may include phrases or words from other tables indicated by {name}. Note that table names can only contain the letters a-z, digits 0-9, and the underscore. A table may be defined as a simple array list, or as a indexed object (see the warrior_data.js file for examples of both).

Then, include both the generator.js file and your data file in your HTML page. A clever person might note that you could easily create and include more than one data file here.

<script type="text/javascript" src="generator.js"></script>
<script type="text/javascript" src="warrior_data.js"></script>

The generate_text() function accepts a single argument, the name of your main table, and returns a text string. You can simply write this text string to the HTML page...

<script type="text/javascript">
  document.write(generate_text('warrior'));
</script>

A female human warrior, wearing plate armor and wielding a longbow and arrows.

Or assign it to a variable in your own JavaScript code. You may also be interested in the generate_list() function, which accepts the name of a table and a number, and returns an array of generated text strings. ##tl;dr

#Fractal World Generator ##A Brief History

The fractal world generator is based on code by John Olsson. The donjon version was completely rewritten in Nov 2009, and includes changes to the faulting algorithm and support for alternate color palettes. It also supports additional map projections; icosahedral was added in Sept 2010, and sinusoidal, Mollweide, and transverse Mercator in Aug 2011. ##How it Works

A sphere is bisected along a random great circle, and one half elevated above the other. Repeating this process thousands of times produces a faulted terrain. Next, the elevation values are sorted into a histogram to determine sea level. Finally, the elevation map is scaled into a color map, and transformed into the desired projection. ##Source Code

The original code has a few minor errors which can cause a segmentation fault and crash. Version 2.2a fixes these problems. Both versions are provided under the GNU General Public License, version 2. (See git repository history for older versions)

##The World of Tumult

The World of Tumult

#Random Dungeon Generator ##A Brief History

Drow began work on his dungeon generator sometime around 1999. It was originally hosted on the demonweb (his personal home page), moved to the Dire Press website in May 2006, and then to the donjon website in Sept 2009. Early versions included basic dungeon layout and size options, and generated maps as HTML tables of black and white cells. Code to generate images for dungeon maps was added in March 2009, and for cavernous dungeons in Sept 2010. ##How it Works

A dungeon is constructed as a two-dimensional matrix of integers, each representing one cell. Within an integer, each bit indicates a different state, such as 0x01 for blocked cells, 0x02 for cells in rooms, and 0x04 for cells in corridors. Rooms and corridors always fall along odd-numbered columns and rows, and rooms are always odd numbers in width and height.

Rooms are placed randomly or by algorithm. If a room does not collide with a blocked cell, another room, etc. then the room and its perimeter are marked out in the matrix. Next, the generator calculates a reasonable number of entrances based on the room size, and attempts to open that number of entrances in the room perimeter.

The corridor generator is a simple recursive algorithm with a few quirks. Labyrinth corridors are generated by shuffling the list of directions randomly, errant corridors continue in the current direction 50% of the time, and straight corridors continue 90% of the time.

Caverns are generated using cellular automata, inspired by Jim Babcock's article at RogueBasin. If the algorithm results in multiple cavern systems, a simple search finds the shortest cuts required to join them. The cavern is refined from cell to display resolution by iteratively dividing each cell into smaller cells and re-running the cellular automata algoritm. ##Source Code

The following source code is a simplified implementation of the donjon random dungeon generator. It is provided under the Creative Commons Attribution-NonCommercial 3.0 Unported License.

##The Dungeon of Random Death

The Dungeon of Random Death

Packages

No packages published

Languages

  • Perl 44.0%
  • C 30.0%
  • JavaScript 13.9%
  • HTML 12.1%