istereo2
changeset 8:661bf09db398
- replaced Quartz timer with cross-platform timer code
- protected goatkit builtin theme function from being optimized out
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Thu, 24 Sep 2015 07:09:37 +0300 (2015-09-24) |
parents | a3c4fcc9f8f3 |
children | 64e15874f3bd |
files | istereo.xcodeproj/project.pbxproj src/istereo.c src/timer.c src/timer.h src/uitheme.cc |
diffstat | 5 files changed, 92 insertions(+), 27 deletions(-) [+] |
line diff
1.1 --- a/istereo.xcodeproj/project.pbxproj Thu Sep 24 06:49:25 2015 +0300 1.2 +++ b/istereo.xcodeproj/project.pbxproj Thu Sep 24 07:09:37 2015 +0300 1.3 @@ -30,6 +30,7 @@ 1.4 060ECB071BB36FD800CE9B80 /* linux-libertine_s24.glyphmap in Resources */ = {isa = PBXBuildFile; fileRef = 060ECB061BB36FD800CE9B80 /* linux-libertine_s24.glyphmap */; settings = {ASSET_TAGS = (); }; }; 1.5 060ECB091BB3989500CE9B80 /* uitheme.cc in Sources */ = {isa = PBXBuildFile; fileRef = 060ECB081BB3989500CE9B80 /* uitheme.cc */; settings = {ASSET_TAGS = (); }; }; 1.6 060ECB0B1BB3A8DB00CE9B80 /* font.p.glsl in Resources */ = {isa = PBXBuildFile; fileRef = 060ECB0A1BB3A8DB00CE9B80 /* font.p.glsl */; settings = {ASSET_TAGS = (); }; }; 1.7 + 060ECB0E1BB3AC0D00CE9B80 /* timer.c in Sources */ = {isa = PBXBuildFile; fileRef = 060ECB0C1BB3AC0D00CE9B80 /* timer.c */; settings = {ASSET_TAGS = (); }; }; 1.8 0669D67F1BA85DDE00611CFA /* app_delegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 0669D67B1BA85DDE00611CFA /* app_delegate.m */; }; 1.9 0669D6801BA85DDE00611CFA /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 0669D67C1BA85DDE00611CFA /* main.m */; }; 1.10 0669D6811BA85DDE00611CFA /* viewctl.m in Sources */ = {isa = PBXBuildFile; fileRef = 0669D67E1BA85DDE00611CFA /* viewctl.m */; }; 1.11 @@ -180,6 +181,8 @@ 1.12 060ECB061BB36FD800CE9B80 /* linux-libertine_s24.glyphmap */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = "linux-libertine_s24.glyphmap"; path = "data/linux-libertine_s24.glyphmap"; sourceTree = "<group>"; }; 1.13 060ECB081BB3989500CE9B80 /* uitheme.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = uitheme.cc; path = src/uitheme.cc; sourceTree = "<group>"; }; 1.14 060ECB0A1BB3A8DB00CE9B80 /* font.p.glsl */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = font.p.glsl; path = sdr/font.p.glsl; sourceTree = "<group>"; }; 1.15 + 060ECB0C1BB3AC0D00CE9B80 /* timer.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = timer.c; path = src/timer.c; sourceTree = "<group>"; }; 1.16 + 060ECB0D1BB3AC0D00CE9B80 /* timer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = timer.h; path = src/timer.h; sourceTree = "<group>"; }; 1.17 0669D6471BA851BE00611CFA /* istereo.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = istereo.app; sourceTree = BUILT_PRODUCTS_DIR; }; 1.18 0669D6741BA858BF00611CFA /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = ios/Info.plist; sourceTree = "<group>"; }; 1.19 0669D67A1BA85DDE00611CFA /* app_delegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = app_delegate.h; path = src/ios/app_delegate.h; sourceTree = "<group>"; }; 1.20 @@ -419,6 +422,8 @@ 1.21 0669D6761BA858D600611CFA /* src */ = { 1.22 isa = PBXGroup; 1.23 children = ( 1.24 + 060ECB0C1BB3AC0D00CE9B80 /* timer.c */, 1.25 + 060ECB0D1BB3AC0D00CE9B80 /* timer.h */, 1.26 060ECB011BB361C300CE9B80 /* assman.c */, 1.27 060ECB021BB361C300CE9B80 /* assman.h */, 1.28 060ECAED1BB22A4400CE9B80 /* ui.cc */, 1.29 @@ -751,6 +756,7 @@ 1.30 files = ( 1.31 060ECB001BB2BD5C00CE9B80 /* utf8.c in Sources */, 1.32 0669D7121BAD024700611CFA /* jcparam.c in Sources */, 1.33 + 060ECB0E1BB3AC0D00CE9B80 /* timer.c in Sources */, 1.34 0669D7551BAD025B00611CFA /* pngwio.c in Sources */, 1.35 0669D70F1BAD024700611CFA /* jcmarker.c in Sources */, 1.36 0669D6CB1BAD022C00611CFA /* imago2.c in Sources */, 1.37 @@ -958,6 +964,7 @@ 1.38 ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 1.39 ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1.40 CODE_SIGN_IDENTITY = "iPhone Developer"; 1.41 + COMPRESS_PNG_FILES = NO; 1.42 GCC_PREPROCESSOR_DEFINITIONS = ( 1.43 "DEBUG=1", 1.44 HAVE_OPENGL_H, 1.45 @@ -979,6 +986,7 @@ 1.46 ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 1.47 ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1.48 CODE_SIGN_IDENTITY = "iPhone Developer"; 1.49 + COMPRESS_PNG_FILES = NO; 1.50 GCC_PREPROCESSOR_DEFINITIONS = ( 1.51 HAVE_OPENGL_H, 1.52 HAVE_CONFIG_H,
2.1 --- a/src/istereo.c Thu Sep 24 06:49:25 2015 +0300 2.2 +++ b/src/istereo.c Thu Sep 24 07:09:37 2015 +0300 2.3 @@ -32,6 +32,7 @@ 2.4 #include "config.h" 2.5 #include "ui.h" 2.6 #include "drawtext.h" 2.7 +#include "timer.h" 2.8 2.9 static void render(float t); 2.10 static void draw_tunnel(float t); 2.11 @@ -40,7 +41,6 @@ 2.12 static void draw_text(float idx, vec3_t tpos, float alpha); 2.13 static void worm(float t, float z, float *tx, float *ty); 2.14 static unsigned int get_shader_program(const char *vfile, const char *pfile); 2.15 -static float get_sec(void); 2.16 2.17 unsigned int prog, prog_simple, prog_tunnel, prog_text, prog_color, prog_ui, prog_font; 2.18 unsigned int tex, tex_stones, tex_normal, tex_text; 2.19 @@ -133,7 +133,7 @@ 2.20 void redraw(void) 2.21 { 2.22 float pan_x, pan_y, z; 2.23 - float tsec = get_sec(); 2.24 + float tsec = get_time_sec(); 2.25 2.26 z = ring_height * segm; 2.27 worm(tsec, z, &pan_x, &pan_y); 2.28 @@ -442,28 +442,3 @@ 2.29 } 2.30 return prog; 2.31 } 2.32 - 2.33 - 2.34 -#ifdef IPHONE 2.35 -#include <QuartzCore/QuartzCore.h> 2.36 - 2.37 -static float get_sec(void) 2.38 -{ 2.39 - static float first; 2.40 - static int init; 2.41 - 2.42 - if(!init) { 2.43 - init = 1; 2.44 - first = CACurrentMediaTime(); 2.45 - return 0.0f; 2.46 - } 2.47 - return CACurrentMediaTime() - first; 2.48 -} 2.49 - 2.50 -#else 2.51 - 2.52 -static float get_sec(void) 2.53 -{ 2.54 - return (float)glutGet(GLUT_ELAPSED_TIME) / 1000.0f; 2.55 -} 2.56 -#endif
3.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 3.2 +++ b/src/timer.c Thu Sep 24 07:09:37 2015 +0300 3.3 @@ -0,0 +1,71 @@ 3.4 +#include "timer.h" 3.5 + 3.6 +#if defined(__APPLE__) && !defined(__unix__) 3.7 +#define __unix__ 3.8 +#endif 3.9 + 3.10 +#ifdef __unix__ 3.11 +#include <time.h> 3.12 +#include <unistd.h> 3.13 +#include <sys/time.h> 3.14 + 3.15 +#ifdef CLOCK_MONOTONIC 3.16 +unsigned long get_time_msec(void) 3.17 +{ 3.18 + struct timespec ts; 3.19 + static struct timespec ts0; 3.20 + 3.21 + clock_gettime(CLOCK_MONOTONIC, &ts); 3.22 + if(ts0.tv_sec == 0 && ts0.tv_nsec == 0) { 3.23 + ts0 = ts; 3.24 + return 0; 3.25 + } 3.26 + return (ts.tv_sec - ts0.tv_sec) * 1000 + (ts.tv_nsec - ts0.tv_nsec) / 1000000; 3.27 +} 3.28 +#else /* no fancy POSIX clocks, fallback to good'ol gettimeofday */ 3.29 +unsigned long get_time_msec(void) 3.30 +{ 3.31 + struct timeval tv; 3.32 + static struct timeval tv0; 3.33 + 3.34 + gettimeofday(&tv, 0); 3.35 + if(tv0.tv_sec == 0 && tv0.tv_usec == 0) { 3.36 + tv0 = tv; 3.37 + return 0; 3.38 + } 3.39 + return (tv.tv_sec - tv0.tv_sec) * 1000 + (tv.tv_usec - tv0.tv_usec) / 1000; 3.40 +} 3.41 +#endif /* !posix clock */ 3.42 + 3.43 +void sleep_msec(unsigned long msec) 3.44 +{ 3.45 + usleep(msec * 1000); 3.46 +} 3.47 +#endif 3.48 + 3.49 +#ifdef WIN32 3.50 +#include <windows.h> 3.51 +#pragma comment(lib, "winmm.lib") 3.52 + 3.53 +unsigned long get_time_msec(void) 3.54 +{ 3.55 + return timeGetTime(); 3.56 +} 3.57 + 3.58 +void sleep_msec(unsigned long msec) 3.59 +{ 3.60 + Sleep(msec); 3.61 +} 3.62 +#endif 3.63 + 3.64 +double get_time_sec(void) 3.65 +{ 3.66 + return get_time_msec() / 1000.0f; 3.67 +} 3.68 + 3.69 +void sleep_sec(double sec) 3.70 +{ 3.71 + if(sec > 0.0f) { 3.72 + sleep_msec(sec * 1000.0f); 3.73 + } 3.74 +}
4.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 4.2 +++ b/src/timer.h Thu Sep 24 07:09:37 2015 +0300 4.3 @@ -0,0 +1,10 @@ 4.4 +#ifndef TIMER_H_ 4.5 +#define TIMER_H_ 4.6 + 4.7 +unsigned long get_time_msec(void); 4.8 +void sleep_msec(unsigned long msec); 4.9 + 4.10 +double get_time_sec(void); 4.11 +void sleep_sec(double sec); 4.12 + 4.13 +#endif /* TIMER_H_ */
5.1 --- a/src/uitheme.cc Thu Sep 24 06:49:25 2015 +0300 5.2 +++ b/src/uitheme.cc Thu Sep 24 07:09:37 2015 +0300 5.3 @@ -26,6 +26,7 @@ 5.4 5.5 static std::map<std::string, WidgetDrawFunc> funcmap; 5.6 5.7 +__attribute__ ((used)) 5.8 extern "C" WidgetDrawFunc get_widget_func(const char *name) 5.9 { 5.10 static bool initialized;