Go to file
Ahmad Fatoum 6ffc8cb799
raymath.h: Use C99 inline semantics
RAYMATH_EXTERN_INLINE was renamed to RAYMATH_HEADER_ONLY, which user code
may define if they want to use it as header-only library. If multiple
files in the same project define RAYMATH_HEADER_ONLY, they might each
have duplicate out-of-line definitions of the same functions.

By default, raymath.h exposes inline definitions, which instructs the
compiler _not_ to generate out-of-line definitons, if out-of-line
definitions are required, those of the file defined with
RAYLIB_IMPLEMENTATION are used instead. There may be only one such file.

In C++ mode, the compiler will select only one out-of-line definition
automatically, so no need to define a RAYLIB_IMPLEMENTATION.

Unfortunately, we have to remove raymath function declaration from
raylib.h as those declarations would lead to duplicate out-of-line
definitions which would yield linker errors. This problem didn't
exist with GNU89 or C++, because there multiple defintions are ok,
but in C99 they aren't.
2018-02-24 15:37:37 +01:00
examples raymath.h: Use C99 inline semantics 2018-02-24 15:37:37 +01:00
games Removed flag -fgnu89-inline 2018-02-21 23:28:34 +01:00
logo Renamed iconography 2018-02-10 23:29:40 +01:00
project Add note about glfw3 and openAL 2018-02-16 11:53:04 +01:00
release Update README.md 2018-02-03 11:33:05 +01:00
src raymath.h: Use C99 inline semantics 2018-02-24 15:37:37 +01:00
templates Removed flag -fgnu89-inline 2018-02-21 23:28:34 +01:00
.gitignore Do not ignore Makefiles! 2018-01-29 14:01:06 +01:00
.travis.yml CI: Build artifacts for master, not develop tags 2018-02-19 13:56:55 +01:00
appveyor.yml CI: Build artifacts for master, not develop tags 2018-02-19 13:56:55 +01:00
CHANGELOG Update CHANGELOG 2017-10-17 13:37:07 +02:00
CMakeLists.txt Make function calls without prior declaration an error 2018-01-25 22:34:29 +01:00
CONTRIBUTING.md Docs: Replace references to raylib develop branch 2018-02-19 13:58:25 +01:00
HELPME.md Update HELPME.md 2017-09-18 01:22:24 +02:00
HISTORY.md Update HISTORY.md 2017-10-02 23:46:57 +02:00
LICENSE.md Docs: Replace references to raylib develop branch 2018-02-19 13:58:25 +01:00
raylib.pc.in pkg-config: Empty Requires.private on shared-only build 2018-02-11 20:10:50 +01:00
README.md Update README.md 2018-02-20 11:04:02 +01:00
ROADMAP.md Docs: Replace references to raylib develop branch 2018-02-19 13:58:25 +01:00
utils.cmake pkg-config: Empty Requires.private on shared-only build 2018-02-11 20:10:50 +01:00

raylib is a simple and easy-to-use library to learn videogames programming.

raylib is highly inspired by Borland BGI graphics lib and by XNA framework.

raylib could be useful for prototyping, tools development, graphic applications, embedded systems and education.

NOTE for ADVENTURERS: raylib is a programming library to learn videogames programming; no fancy interface, no visual helpers, no auto-debugging... just coding in the most pure spartan-programmers way. Are you ready to learn? Jump to code examples!

Build Status https://ci.appveyor.com/api/projects/status/github/raysan5/raylib?svg=true Gitter License Twitter URL

features

  • Written in plain C code (C99) in PascalCase/camelCase notation
  • Hardware accelerated with OpenGL (1.1, 2.1, 3.3 or ES2 - choose at compile)
  • Unique OpenGL abstraction layer (usable as standalone module): rlgl
  • Powerful fonts module with SpriteFonts support (XNA fonts, AngelCode fonts, TTF)
  • Outstanding texture formats support, including compressed formats (DXT, ETC, ASTC)
  • Full 3d support for 3d Shapes, Models, Billboards, Heightmaps and more!
  • Flexible Materials system, supporting classic maps and PBR maps
  • Shaders support, including Model shaders and Postprocessing shaders
  • Powerful math module for Vector, Matrix and Quaternion operations: raymath
  • Audio loading and playing with streaming support (WAV, OGG, FLAC, XM, MOD)
  • Multiple platforms support: Windows, Linux, FreeBSD, MacOS, UWP, Android, Raspberry Pi, HTML5.
  • VR stereo rendering with configurable HMD device parameters
  • NO external dependencies, all required libraries included with raylib
  • Complete bindings to LUA (raylib-lua) and Go (raylib-go)

raylib uses on its core module the outstanding GLFW3 library, embedded inside raylib in the form of rglfw module, avoiding that way external dependencies.

raylib uses on its audio module, the amazing mini_al audio library, single-file header-only and supporting multiple platforms and multiple audio backends.

raylib uses internally multiple single-file header-only libraries to support multiple fileformats loading and saving, all those libraries are embedded with raylib and available in src/external directory.

On Android, native_app_glue module (provided by Android NDK) and native Android libraries are used to manage window/context, inputs and activity life cycle.

On Raspberry Pi, Videocore API and EGL libraries are used for window/context management and raw inputs reading.

build and installation

Binary releases for Windows, Linux and macOS are available at the Github Releases page. raylib is also available via multiple package managers on multiple OS distributions. For more info check raylib Wiki.

To build raylib yourself, check out also the raylib Wiki for detailed instructions.

raylib has been developed using exclusively two tools:

Those are the tools recommended to develop with raylib, in fact, those are the tools my students use.

contact

If you are using raylib and you enjoy it, please, let me know.

If you feel you can help, then, helpme!

license

raylib is licensed under an unmodified zlib/libpng license, which is an OSI-certified, BSD-like license that allows static linking with closed source software. Check LICENSE for further details.