aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRay <raysan5@gmail.com>2015-01-10 13:28:45 +0100
committerRay <raysan5@gmail.com>2015-01-10 13:28:45 +0100
commitcae6f3c613794e5e02233aa1590eb1ea9a8239cd (patch)
tree762e1968f407c420021aa43a044c03179b56e0d5
parent274921cd353cf64f124bfc9b986bf793c72d4ffa (diff)
parentbb8c1826d3d3c02cc8e91d6187cd5035a440a6ac (diff)
downloadraylib-1.2.2-installer.tar.gz
raylib-1.2.2-installer.zip
Merge pull request #16 from raysan5/develop1.2.2-installer
Integration from develop branch to master
-rw-r--r--examples/core_basic_window_web.c89
-rw-r--r--examples/makefile55
-rw-r--r--external/glew/lib/win32/libglew32.a (renamed from external/glew/lib/libglew32.a)bin720918 -> 720918 bytes
-rw-r--r--external/glew/lib/win32/libglew32dll.a (renamed from external/glew/lib/libglew32dll.a)bin1886236 -> 1886236 bytes
l---------external/glfw3/lib/libglfw.3.dylib1
l---------external/glfw3/lib/libglfw.dylib1
-rw-r--r--[-rwxr-xr-x]external/glfw3/lib/osx/libglfw.3.0.dylib (renamed from external/glfw3/lib/libglfw.3.0.dylib)bin127856 -> 127856 bytes
-rw-r--r--external/glfw3/lib/osx/libglfw.3.dylib1
-rw-r--r--external/glfw3/lib/osx/libglfw.dylib1
-rw-r--r--external/glfw3/lib/win32/libglfw3.a (renamed from external/glfw3/lib/libglfw3.a)bin83006 -> 83006 bytes
-rw-r--r--external/glfw3/lib/win32/libglfw3dll.a (renamed from external/glfw3/lib/libglfw3dll.a)bin48318 -> 48318 bytes
-rw-r--r--external/openal_soft/lib/win32/libopenal32.a (renamed from external/openal_soft/lib/libopenal32.a)bin95688 -> 95688 bytes
-rw-r--r--src/makefile21
13 files changed, 149 insertions, 20 deletions
diff --git a/examples/core_basic_window_web.c b/examples/core_basic_window_web.c
new file mode 100644
index 00000000..b35c07e6
--- /dev/null
+++ b/examples/core_basic_window_web.c
@@ -0,0 +1,89 @@
+/*******************************************************************************************
+*
+* raylib [core] example - Basic window
+*
+* Welcome to raylib!
+*
+* To test examples, just press F6 and execute raylib_compile_execute script
+* Note that compiled executable is placed in the same folder as .c file
+*
+* You can find all basic examples on C:\raylib\raylib\examples folder or
+* raylib official webpage: www.raylib.com
+*
+* Enjoy using raylib. :)
+*
+* This example has been created using raylib 1.0 (www.raylib.com)
+* raylib is licensed under an unmodified zlib/libpng license (View raylib.h for details)
+*
+* Copyright (c) 2014 Ramon Santamaria (Ray San - raysan@raysanweb.com)
+*
+********************************************************************************************/
+
+#include "raylib.h"
+
+#if defined(PLATFORM_WEB)
+ #include <emscripten/emscripten.h>
+#endif
+
+//----------------------------------------------------------------------------------
+// Global Variables Definition
+//----------------------------------------------------------------------------------
+int screenWidth = 800;
+int screenHeight = 450;
+
+//----------------------------------------------------------------------------------
+// Module Functions Declaration
+//----------------------------------------------------------------------------------
+void UpdateDrawFrame(void); // Update and Draw one frame
+
+//----------------------------------------------------------------------------------
+// Main Enry Point
+//----------------------------------------------------------------------------------
+int main()
+{
+ // Initialization
+ //--------------------------------------------------------------------------------------
+ InitWindow(screenWidth, screenHeight, "raylib [core] example - basic window");
+
+#if defined(PLATFORM_WEB)
+ emscripten_set_main_loop(UpdateDrawFrame, 0, 1);
+#else
+ SetTargetFPS(60); // Set our game to run at 60 frames-per-second
+ //--------------------------------------------------------------------------------------
+
+ // Main game loop
+ while (!WindowShouldClose()) // Detect window close button or ESC key
+ {
+ UpdateDrawFrame();
+ }
+#endif
+
+ // De-Initialization
+ //--------------------------------------------------------------------------------------
+ CloseWindow(); // Close window and OpenGL context
+ //--------------------------------------------------------------------------------------
+
+ return 0;
+}
+
+//----------------------------------------------------------------------------------
+// Module Functions Definition
+//----------------------------------------------------------------------------------
+void UpdateDrawFrame(void)
+{
+ // Update
+ //----------------------------------------------------------------------------------
+ // TODO: Update your variables here
+ //----------------------------------------------------------------------------------
+
+ // Draw
+ //----------------------------------------------------------------------------------
+ BeginDrawing();
+
+ ClearBackground(RAYWHITE);
+
+ DrawText("Congrats! You created your first window!", 190, 200, 20, LIGHTGRAY);
+
+ EndDrawing();
+ //----------------------------------------------------------------------------------
+} \ No newline at end of file
diff --git a/examples/makefile b/examples/makefile
index 9763b233..b4d7bfa3 100644
--- a/examples/makefile
+++ b/examples/makefile
@@ -26,18 +26,21 @@
# WARNING: To compile examples to HTML5, they must be redesigned to use emscripten.h and emscripten_set_main_loop()
PLATFORM ?= PLATFORM_DESKTOP
-# determine SUBPLATFORM in case PLATFORM_DESKTOP selected
+# determine PLATFORM_OS in case PLATFORM_DESKTOP selected
ifeq ($(PLATFORM),PLATFORM_DESKTOP)
# No uname.exe on MinGW!, but OS=Windows_NT on Windows! ifeq ($(UNAME),Msys) -> Windows
ifeq ($(OS),Windows_NT)
- SUBPLATFORM=WINDOWS
+ PLATFORM_OS=WINDOWS
+ LIBPATH=win32
else
UNAMEOS:=$(shell uname)
ifeq ($(UNAMEOS),Linux)
- SUBPLATFORM=LINUX
+ PLATFORM_OS=LINUX
+ LIBPATH=linux
else
ifeq ($(UNAMEOS),Darwin)
- SUBPLATFORM=OSX
+ PLATFORM_OS=OSX
+ LIBPATH=osx
endif
endif
endif
@@ -48,9 +51,14 @@ ifeq ($(PLATFORM),PLATFORM_WEB)
# define emscripten compiler
CC = emcc
else
+ifeq ($(PLATFORM_OS),OSX)
+ # define llvm compiler for mac
+ CC = clang
+else
# define default gcc compiler
CC = gcc
endif
+endif
# define compiler flags:
# -O2 defines optimization level
@@ -74,25 +82,41 @@ ifeq ($(PLATFORM),PLATFORM_RPI)
INCLUDES = -I. -I../src -I/opt/vc/include -I/opt/vc/include/interface/vcos/pthreads
else
INCLUDES = -I. -I../src
+# external libraries headers
+# GLFW3
+ INCLUDES += -I../external/glfw3/include
+# GLEW
+ INCLUDES += -I../external/glew/include
+# OpenAL Soft
+ INCLUDES += -I../external/openal_soft/include
endif
# define library paths containing required libs
ifeq ($(PLATFORM),PLATFORM_RPI)
LFLAGS = -L. -L../src -L/opt/vc/lib
else
- LFLAGS = -L. -L../src -L../external/glfw3/lib/ -I../external/openal_soft/lib/
+ LFLAGS = -L. -L../src
+# external libraries to link with
+# GLFW3
+ LFLAGS += -L../external/glfw3/lib/$(LIBPATH)
+ ifneq ($(PLATFORM_OS),OSX)
+ # OpenAL Soft
+ LFLAGS += -L../external/openal_soft/lib/$(LIBPATH)
+ # GLEW
+ LFLAGS += -L../external/glew/lib/$(LIBPATH)
+ endif
endif
# define any libraries to link into executable
# if you want to link libraries (libname.so or libname.a), use the -lname
ifeq ($(PLATFORM),PLATFORM_DESKTOP)
- ifeq ($(SUBPLATFORM),LINUX)
+ ifeq ($(PLATFORM_OS),LINUX)
# libraries for Debian GNU/Linux desktop compiling
# requires the following packages:
# libglfw3-dev libopenal-dev libglew-dev libegl1-mesa-dev
LIBS = -lraylib -lglfw -lGLEW -lGL -lopenal
endif
- ifeq ($(SUBPLATFORM),OSX)
+ ifeq ($(PLATFORM_OS),OSX)
# libraries for OS X 10.9 desktop compiling
# requires the following packages:
# libglfw3-dev libopenal-dev libglew-dev libegl1-mesa-dev
@@ -101,7 +125,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP)
else
# libraries for Windows desktop compiling
# NOTE: GLFW3 and OpenAL Soft libraries should be installed
- LIBS = -lraylib -lglfw3 -lglew32 -lopengl32 -lopenal32 -lgdi32
+ LIBS = -lraylib -lglfw3 -lglew32 -lopengl32 -lopenal32 -lgdi32
endif
endif
ifeq ($(PLATFORM),PLATFORM_RPI)
@@ -114,7 +138,7 @@ ifeq ($(PLATFORM),PLATFORM_WEB)
endif
# define additional parameters and flags for windows
-ifeq ($(PLATFORM),PLATFORM_DESKTOP)
+ifeq ($(PLATFORM_OS),WINDOWS)
# resources file contains windows exe icon
# -Wl,--subsystem,windows hides the console window
WINFLAGS = ../src/resources -Wl,--subsystem,windows
@@ -155,6 +179,8 @@ EXAMPLES = \
models_cubicmap \
audio_sound_loading \
audio_music_stream \
+ fix_dylib \
+
#core_input_gamepad \
@@ -287,13 +313,20 @@ audio_sound_loading: audio_sound_loading.c
audio_music_stream: audio_music_stream.c
$(CC) -o $@$(EXT) $< $(CFLAGS) $(INCLUDES) $(LFLAGS) $(LIBS) -D$(PLATFORM) $(WINFLAGS)
+# fix dylib install path name for each executable (MAC)
+fix_dylib:
+ifeq ($(PLATFORM_OS),OSX)
+ find . -type f -perm +ugo+x -print0 | xargs -t -0 -R 1 -I file install_name_tool -change libglfw.3.0.dylib ../external/glfw3/lib/osx/libglfw.3.0.dylib file
+endif
+
# clean everything
clean:
ifeq ($(PLATFORM),PLATFORM_DESKTOP)
- ifeq ($(SUBPLATFORM),OSX)
+ ifeq ($(PLATFORM_OS),OSX)
+ find . -type f -perm +ugo+x -delete
rm -f *.o
else
- ifeq ($(SUBPLATFORM),LINUX)
+ ifeq ($(PLATFORM_OS),LINUX)
find . -type f -executable -delete
rm -f *.o
else
diff --git a/external/glew/lib/libglew32.a b/external/glew/lib/win32/libglew32.a
index 363c424b..363c424b 100644
--- a/external/glew/lib/libglew32.a
+++ b/external/glew/lib/win32/libglew32.a
Binary files differ
diff --git a/external/glew/lib/libglew32dll.a b/external/glew/lib/win32/libglew32dll.a
index 5d84782c..5d84782c 100644
--- a/external/glew/lib/libglew32dll.a
+++ b/external/glew/lib/win32/libglew32dll.a
Binary files differ
diff --git a/external/glfw3/lib/libglfw.3.dylib b/external/glfw3/lib/libglfw.3.dylib
deleted file mode 120000
index cd20112e..00000000
--- a/external/glfw3/lib/libglfw.3.dylib
+++ /dev/null
@@ -1 +0,0 @@
-libglfw.3.0.dylib \ No newline at end of file
diff --git a/external/glfw3/lib/libglfw.dylib b/external/glfw3/lib/libglfw.dylib
deleted file mode 120000
index d4bd51e1..00000000
--- a/external/glfw3/lib/libglfw.dylib
+++ /dev/null
@@ -1 +0,0 @@
-libglfw.3.dylib \ No newline at end of file
diff --git a/external/glfw3/lib/libglfw.3.0.dylib b/external/glfw3/lib/osx/libglfw.3.0.dylib
index 963d716d..15674573 100755..100644
--- a/external/glfw3/lib/libglfw.3.0.dylib
+++ b/external/glfw3/lib/osx/libglfw.3.0.dylib
Binary files differ
diff --git a/external/glfw3/lib/osx/libglfw.3.dylib b/external/glfw3/lib/osx/libglfw.3.dylib
new file mode 100644
index 00000000..cd20112e
--- /dev/null
+++ b/external/glfw3/lib/osx/libglfw.3.dylib
@@ -0,0 +1 @@
+libglfw.3.0.dylib \ No newline at end of file
diff --git a/external/glfw3/lib/osx/libglfw.dylib b/external/glfw3/lib/osx/libglfw.dylib
new file mode 100644
index 00000000..d4bd51e1
--- /dev/null
+++ b/external/glfw3/lib/osx/libglfw.dylib
@@ -0,0 +1 @@
+libglfw.3.dylib \ No newline at end of file
diff --git a/external/glfw3/lib/libglfw3.a b/external/glfw3/lib/win32/libglfw3.a
index 7138ee9b..7138ee9b 100644
--- a/external/glfw3/lib/libglfw3.a
+++ b/external/glfw3/lib/win32/libglfw3.a
Binary files differ
diff --git a/external/glfw3/lib/libglfw3dll.a b/external/glfw3/lib/win32/libglfw3dll.a
index 415d8563..415d8563 100644
--- a/external/glfw3/lib/libglfw3dll.a
+++ b/external/glfw3/lib/win32/libglfw3dll.a
Binary files differ
diff --git a/external/openal_soft/lib/libopenal32.a b/external/openal_soft/lib/win32/libopenal32.a
index 5f7352ac..5f7352ac 100644
--- a/external/openal_soft/lib/libopenal32.a
+++ b/external/openal_soft/lib/win32/libopenal32.a
Binary files differ
diff --git a/src/makefile b/src/makefile
index 8566abe4..a726b92e 100644
--- a/src/makefile
+++ b/src/makefile
@@ -25,18 +25,18 @@
# possible platforms: PLATFORM_DESKTOP PLATFORM_RPI PLATFORM_WEB
PLATFORM ?= PLATFORM_DESKTOP
-# determine SUBPLATFORM in case PLATFORM_DESKTOP selected
+# determine PLATFORM_OS in case PLATFORM_DESKTOP selected
ifeq ($(PLATFORM),PLATFORM_DESKTOP)
# No uname.exe on MinGW!, but OS=Windows_NT on Windows! ifeq ($(UNAME),Msys) -> Windows
ifeq ($(OS),Windows_NT)
- SUBPLATFORM=WINDOWS
+ PLATFORM_OS=WINDOWS
else
UNAMEOS:=$(shell uname)
ifeq ($(UNAMEOS),Linux)
- SUBPLATFORM=LINUX
+ PLATFORM_OS=LINUX
else
ifeq ($(UNAMEOS),Darwin)
- SUBPLATFORM=OSX
+ PLATFORM_OS=OSX
endif
endif
endif
@@ -82,7 +82,14 @@ endif
ifeq ($(PLATFORM),PLATFORM_RPI)
INCLUDES = -I. -I/opt/vc/include -I/opt/vc/include/interface/vcos/pthreads
else
- INCLUDES = -I. -I../external/glfw3/include/ -I../external/openal_soft/include/
+ INCLUDES = -I. -I../src
+# external libraries headers
+# GLFW3
+ INCLUDES += -I../external/glfw3/include
+# GLEW
+ INCLUDES += -I../external/glew/include
+# OpenAL Soft
+ INCLUDES += -I../external/openal_soft/include
endif
# define all object files required
@@ -144,10 +151,10 @@ stb_vorbis.o: stb_vorbis.c
# clean everything
clean:
ifeq ($(PLATFORM),PLATFORM_DESKTOP)
- ifeq ($(SUBPLATFORM),OSX)
+ ifeq ($(PLATFORM_OS),OSX)
rm -f *.o libraylib.a
else
- ifeq ($(SUBPLATFORM),LINUX)
+ ifeq ($(PLATFORM_OS),LINUX)
find . -type f -executable -delete
rm -f *.o libraylib.a
else