123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 |
- _____ _
- | ___| | |
- | |__ _ __ _ _| |_ __ _
- | __| '__| | | | __/ _` |
- | |__| | | |_| | || (_| |
- \____/_| \__,_|\__\__,_|
- Eruta is a futuristic Japanese style RPG under development.
- Requirements:
- * OS: Linux for now. Windows port is under development. OSX may work too.
- * Allegro 5.1.9 or later.
- Earlier versions won't be found by the build script.
- * libxml2 (www.xmlsoft.org)
- * mruby (latest gitub version). To install globally in /usr/local
- use
- `cd <directory_where_mruby_is> ; make ; sudo bin/install_mruby`
- to compile and install mruby into /usr/local
- * For compilation: cmake 2.8.10.2 or later (see vendor directory), make or ninja.
- * For testing and debugging: gdb, ddd, valgrind.
- * For map editing: tiled (www.mapeditor.org)
- * For some of the tools and continuous testing: Ruby, watchr.
- Installation:
- You have to make sure that you have all the requirements. On Linux
- distributitions like Ubuntu, make sure that the development packages for all
- requirements are installed. Then do on the command line:
- cmake . ; make
- Or if you want to build with Ninja, use the latest version of cmake and go
- cmake -G Ninja . ; ninja
- Please note that cmake and the word "Ninja" is case-sensitive!
- How to try it:
- Run bin/eruta from the project's main directory.
- Expect to be underwhelmed for now. :-)
- How to develop using the contious testing script:
- Use the supplied watchr script like this:
- watchr tool/watchr/eruta_watchr.rb
- Every time you change a c file or header, the matching
- test will be compiled though cmake and make, and
- will be run. This does compile all C files of eruta,
- so it may be a bit slow at times.
- How to generate developer's documentation:
- Use naturaldocs.
- License:
- Eruta is copyright (C)
- 2007-2015 Beoran beoran@rubyforge.org.
- 2012 com64 (music files in data/music/*_com64.ogg)
- Redistribution and use in source and binary forms, with or without modification,
- are permitted provided that the following conditions are met:
- 1. Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice,
- this list of conditions and the following disclaimer in the documentation
- and/or other materials provided with the distribution.
- 3. Redistributions in any form must be accompanied by information on how to
- obtain complete source code for the Eruta software and any accompanying
- software that uses the Eruta software. The source code must either be
- included in the distribution or be available for no more than the cost of
- distribution plus a nominal fee, and must be freely redistributable under
- reasonable conditions. For an executable file, complete source code means
- the source code for all modules it contains. It does not include source code
- for modules or files that typically accompany the major components of the
- operating system on which the executable file runs.
- THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR IMPLIED
- WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT, ARE
- DISCLAIMED. IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
- INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
- OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
- OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
- ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- As you can see, above, Eruta is licenced under a "Sleepycat license", which is
- GPL compatible, but much shorter and easier to read. Basically you're allowed
- to use the Eruta as you like. However, if you make your own game with Eruta's
- sources, you'll have to make the sources of your program freely available and
- redistributable as well. If you don't like these terms, contact me for making
- different arrangments. :)
- Credits and third party licenses:
- json-parser (src/json.c and include/json.h):
- Copyright (C) 2012 James McLaughlin, Alex Gartrell, Peter Scott,
- Mathias Kaerlev, Emiel Mols, Czarek Tomczak, Nicholas Braden,
- Ivan Kozub, Árpád Goretity. All rights reserved.
- https://github.com/udp/json-parser
- Redistribution and use in source and binary forms, with or without
- modification, are permitted provided that the following conditions
- are met:
- 1. Redistributions of source code must retain the above copyright
- notice, this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
- ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
- FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- SUCH DAMAGE.
- ext/gari/test/test_music.ogg, data/music/musictest.ogg
- Original title: : Town in ruins loop
- Artist: Brandon Morris
- License: CC-BY 3.0
- data/font/Tuffy.ttf
- - Thatcher Ulrich <tu@tulrich.com> http://tulrich.com
- Tuffy fonts License:
- I have placed these fonts in the Public Domain. This is all 100% my
- own work. Usage is totally unrestricted. If you want to make
- derivative works for any purpose, please go ahead.
- data/font/GranaPadano.ttf
- Daniel Johnson (font maintainer)
- il.basso.buffo at gmail dot com
- http://io.debian.net/~danielj/
- Licensed under the Open Font License (OFL).
- data/image/ulpcss/*
- See README and AUTHORS in that directory.
- These images are temporary open source placeholders for the game sprites.
- data/image/ui/icon/gin/*
- Icons made by Lorc, Delapoite and John Colbutn.
- Icons provided under the Creative Commons 3.0 BY license.
- See licence.txt in that directory for more details.
- data/music/nethis-the_writer.ogg
- License: CC-BY 3.0
- Artists: Nethis, based on vocals by myvanillaworld.
- http://ccmixter.org/files/Nethis/38405
- data/music/ramblinglibrarian_how_do_i_make_you_see.ogg
- License: CC-BY 3.0
- Artists: ramblinglibrarian, based on vocals by myvanillaworld.
- http://ccmixter.org/files/ramblinglibrarian/25641
- data/music/admiralbob77_in_peace_now.ogg
- License: CC-BY 3.0
- Artists: Admiralbob77, based on vocals by SackJo22
- http://ccmixter.org/files/admiralbob77/40555
- http://incompetech.com/music/royalty-free/index.html?isrc=USUAN1100875
- data/music/*_com64.ogg
- By Com64 under CC-BY 3.0 license.
- data/music/*_joclemons.ogg
- By Jo Clemons under CC-BY 3.0 license.
- Thanks to the following people for their suggestions:
- Alexbond45, LunarKnite, Mikka, Sagephoenix.
- Remarks for developers:
- bin/mkproto is an automatic function prototype extraction tool that is
- no longer used due to it being more hassle than help.
- When a new .c file is needed, use the bin/newmodule tool like this
- bin/newmodule bar
- and automatically, empty src/bar.c and include/bar.h will be generated.
- As for why I use plain C and not, say C++: it's to keep the code simple, tight
- and focused, and easy to interface with the Ruby scripts. C is a very simple
- language, but it can do anything and it does it fast. And to save time, quite
- a bit of the programming will happen on the mruby side.
- An overview of the C files andwhat they are about:
- src/area.c : In-game areas or levels.
- src/bad.c : Beoran's Algorithms and datastructures.
- src/base64.c : Base64 implementation, currently unused.
- src/brex.c : Reular expressions ,currently unused.
- src/bxml.c : My own XML parser, currently not in use.
- src/bxmlparser.c : My own XML parser, currently not in use.
- src/camera.c : Camera models a view port over an in-game level.
- src/castor.c : Cache and in memory storage for resources. Needs work.
- src/ch.c : Chipmunk Helper functions.
- src/cocell.c : Cons cell, currenly not used.
- src/draw.c : Additional drawing functions.
- src/dynar.c : Dynamic arrays in C. Used everywhere.
- src/effect.c : Effects and particle engine. Needs a lot of work.
- src/event.c : Additional event functions.
- src/every.c : Iterators and iteration in C.
- src/ezxml.c : XML parser based on Aaron Voisine's work.
- src/fifi.c : Find Files. Helps find game data and eases resource loading.
- src/flags.c : Simple integer bitflag setting and getting helpers.
- src/glh.c : OpenGL helper functions. Currently not in use.
- src/hatab.c : Hash table. Needs work, so not in use yet.
- src/ifa.c : Generic interfaces for C. Currently not used.
- src/inli.c : Intrusive linked ist, currently not used.
- src/json.c : JSON support.
- src/main.c : Main function and many helpers and tests.
- src/mem.c : Memory handling helpers.
- src/miniz.c : Minimalistic zip library for later use.
- src/mobile.c : Autonomously moving game entities.
- src/mode.c : Game mode switching functions.
- src/obj.c : OOP in C playground. Currently not in use.
- src/pachi.c : Parent child tree. Currently not in use.
- src/pointergrid.c : Two dimensional grid, used for the tile map.
- src/react.c : Input handling system. Needs to be merged with UI and mode.
- src/rebl.c : Red black tree, under construction, unused.
- src/rebox.c : Rectangular boxes. Used in UI, camera etc.
- src/rh.c : MRuby helper functions.
- src/scegra.c : Scene graph idea, may be discared, currently unused.
- src/silut.c : Simple string lookup table.
- src/sound.c : Sound and music helper functions.
- src/sprite.c : Sprite functions, in use but needs work.
- src/spritelayout.c: Sprite Layouts used for loading sprite sheets.
- src/spritelist.c : List of sprite functions, split off from sprite.c
- src/spritestate.c : Sprite state functions, split off from sprite.c
- src/state.c : Manages all state data of the engine.
- src/str.c : USTR and String helper functions.
- src/tarray.c : XMacro template matrix. Currently unused.
- src/tile.c : Tile map tile functionality.
- src/tileio.c : Tile map reading and later perhaps writing for ingame edit.
- src/tilemap.c : Tile map functonality.
- src/tilepane.c : Tile pane, a layer in a tile map.
- src/tinfl.c : Tiny inflater, uncompression, currently unused.
- src/tlilis.c : Templated linked list, currently unused.
- src/tmatrix.c : Templated matrix currently unused.
- src/toruby.c : Functions that are exposed to the mruby scripting.
- src/tr_audio.c : MRuby script bindings for audio functionality.
- src/tr_path.c : MRuby script bindings for path functionality.
- src/tr_store.c : MRuby script bindings for data storage functionality.
- src/tr_graph.c : MRuby script bindings for 2D scene graph functionality.
- src/tr_sprite.c : MRuby script bindings for sprite functionality.
- src/tr_thing.c : MRuby script bindings for physical thing functionality.
- src/ui.c : User interface functionality.
- src/widget.c : UI widgets, currently only script console.
- src/xml.c : Libxml helper functions.
- src/zori.c : UI functions, currently empty.
- Since I try out a lot of things, ther are quite a few unused C fils in
- the project. Perhaps I will clean them out some day.. :)
|