From 39d13b375a2fed63f1d07bdea8153dd0cdab3c7c Mon Sep 17 00:00:00 2001 From: batt Date: Tue, 5 Feb 2008 08:43:33 +0000 Subject: [PATCH] Restore previous BeRTOS demo. git-svn-id: https://src.develer.com/svnoss/bertos/trunk@1088 38d2e660-2303-0410-9eaa-f027e97ec537 --- app/demo/appconfig.h | 259 +++++++++++++++++++++++++++++++++ app/demo/demo.c | 333 +++++++++++++++++++++++++++++++++++++++++++ app/demo/demo.mk | 115 +++++++++++++++ app/demo/verstag.h | 94 ++++++++++++ 4 files changed, 801 insertions(+) create mode 100644 app/demo/appconfig.h create mode 100644 app/demo/demo.c create mode 100644 app/demo/demo.mk create mode 100644 app/demo/verstag.h diff --git a/app/demo/appconfig.h b/app/demo/appconfig.h new file mode 100644 index 00000000..f9ff031f --- /dev/null +++ b/app/demo/appconfig.h @@ -0,0 +1,259 @@ +/** + * \file + * + * + * \brief DevLib configuration options + * + * You should copy this header in your project and rename it to + * "config.h" and delete the CONFIG_ macros for the modules + * you're not using. + * + *

Working with multiple applications

+ * + * If your project is made of multiple DevLib-based applications, + * create a custom "config.h" file in each application subdirectory + * and play with the compiler include path to get the desired result. + * You can share common options by creationg a "config_common.h" header + * and including it from all your "config.h" copies. + * + *

Configuration style

+ * + * For improved compile-time checking of configuration options, + * the preferred way to use a \c CONFIG_ symbol is keeping it + * always defined with a value of either 0 or 1. This lets + * you write tests like this: + * + * \code + * #if CONFIG_FOO + * void foo(void) + * { + * if (CONFIG_BAR) + * bar(); + * } + * #endif // CONFIG_FOO + * \endcode + * + * In most cases, we rely on the optimizer to discard checks + * on constant values and performing dead-code elimination. + * + * \version $Id: appconfig.h 18242 2007-10-08 17:35:23Z marco $ + * \author Bernardo Innocenti + * \author Stefano Fedrigo + */ + +/*#* + *#* $Log$ + *#* Revision 1.5 2006/09/20 19:55:01 marco + *#* Added CONFIG_LCD_4BIT. + *#* + *#* Revision 1.4 2006/09/13 18:29:22 bernie + *#* Add a few missing CONFIG_ definitions. + *#* + *#* Revision 1.3 2006/07/19 12:56:24 bernie + *#* Convert to new Doxygen style. + *#* + *#* Revision 1.2 2006/05/28 12:18:12 bernie + *#* Disable menu timeout. + *#* + *#* Revision 1.1 2006/05/27 22:31:57 bernie + *#* Add appconfig.h for demo app. + *#* + *#* Revision 1.1 2006/05/18 00:40:43 bernie + *#* Rename appconfig.h to appconfig_common.h. + *#* + *#* Revision 1.11 2006/04/11 00:08:53 bernie + *#* Add smooth scrolling for menus. + *#* + *#* Revision 1.10 2006/03/22 09:48:51 bernie + *#* Add a few more config options. + *#* + *#* Revision 1.9 2006/02/24 00:27:35 bernie + *#* Enable kernel and fix Doxygen markup. + *#* + *#* Revision 1.8 2006/02/21 16:06:05 bernie + *#* Update copyright info. + *#* + *#* Revision 1.7 2006/02/17 22:28:19 bernie + *#* Add missing UART definitions. + *#* + *#* Revision 1.6 2006/02/15 09:12:56 bernie + *#* Switch to BITMAP_FMT_PLANAR_V_LSB. + *#* + *#* Revision 1.5 2006/02/10 12:34:33 bernie + *#* Add missing config options for gfx and kbd. + *#* + *#* Revision 1.4 2006/01/23 23:12:27 bernie + *#* Enable CONFIG_GFX_VCOORDS. + *#* + *#* Revision 1.3 2006/01/17 02:30:06 bernie + *#* Add new config vars. + *#* + *#* Revision 1.2 2005/11/27 03:04:57 bernie + *#* CONFIG_WATCHDOG: New config option. + *#* + *#* Revision 1.1 2005/11/04 17:42:12 bernie + *#* Move cfg/config.h to appconfig.h. + *#*/ + +#ifndef APPCONFIG_H +#define APPCONFIG_H + +/** Baud-rate for the kdebug console */ +#define CONFIG_KDEBUG_BAUDRATE 19200 + +/** + * printf()-style formatter configuration. + * + * \sa PRINTF_DISABLED + * \sa PRINTF_NOMODIFIERS + * \sa PRINTF_REDUCED + * \sa PRINTF_NOFLOAT + * \sa PRINTF_FULL + */ +#define CONFIG_PRINTF PRINTF_FULL + +/** + * Multithreading kernel. + * + * \sa config_kern.h + */ +#define CONFIG_KERNEL 1 + +/** + * \name Serial driver parameters + * \{ + */ + /** [bytes] Size of the outbound FIFO buffer for port 0. */ + #define CONFIG_UART0_TXBUFSIZE 32 + + /** [bytes] Size of the inbound FIFO buffer for port 0. */ + #define CONFIG_UART0_RXBUFSIZE 64 + + /** [bytes] Size of the outbound FIFO buffer for port 1. */ + #define CONFIG_UART1_TXBUFSIZE 32 + + /** [bytes] Size of the inbound FIFO buffer for port 1. */ + #define CONFIG_UART1_RXBUFSIZE 64 + + /** [bytes] Size of the outbound FIFO buffer for SPI port (AVR only). */ + #define CONFIG_SPI_TXBUFSIZE 16 + + /** [bytes] Size of the inbound FIFO buffer for SPI port (AVR only). */ + #define CONFIG_SPI_RXBUFSIZE 32 + + /** Default transmit timeout (ms). Set to -1 to disable timeout support */ + #define CONFIG_SER_TXTIMEOUT -1 + + /** Default receive timeout (ms). Set to -1 to disable timeout support */ + #define CONFIG_SER_RXTIMEOUT -1 + + /** Use RTS/CTS handshake */ + #define CONFIG_SER_HWHANDSHAKE 0 + + /** Default baud rate (set to 0 to disable) */ + #define CONFIG_SER_DEFBAUDRATE 0 + + /** Enable ser_gets() and ser_gets_echo() */ + #define CONFIG_SER_GETS 0 + + /** Enable second serial port in emulator. */ + #define CONFIG_EMUL_UART1 0 + + /** + * Transmit always something on serial port 0 TX + * to avoid interference when sending burst of data, + * using AVR multiprocessor serial mode + */ + #define CONFIG_SER_TXFILL 0 + + #define CONFIG_SER_STROBE 0 +/*\}*/ + +/// Hardware timer selection for drv/timer.c +#define CONFIG_TIMER TIMER_ON_OUTPUT_COMPARE2 + +/// Debug timer interrupt using a strobe pin. +#define CONFIG_TIMER_STROBE 0 + +/// Enable watchdog timer. +#define CONFIG_WATCHDOG 1 + +/// EEPROM type for drv/eeprom.c +#define CONFIG_EEPROM_TYPE EEPROM_24XX256 + +/// Select bitmap pixel format. +#define CONFIG_BITMAP_FMT BITMAP_FMT_PLANAR_V_LSB + +/// Enable line clipping algorithm. +#define CONFIG_GFX_CLIPPING 1 + +/// Enable text rendering in bitmaps. +#define CONFIG_GFX_TEXT 1 + +/// Enable virtual coordinate system. +#define CONFIG_GFX_VCOORDS 1 + +/// Keyboard polling method +#define CONFIG_KBD_POLL KBD_POLL_SOFTINT + +/// Enable keyboard event delivery to observers +#define CONFIG_KBD_OBSERVER 0 + +/// Enable key beeps. +#define CONFIG_KBD_BEEP 1 + +/// Enable long pression handler for keys +#define CONFIG_KBD_LONGPRESS 0 + +/** + * \name Type for the chart dataset + * \{ + */ +#define CONFIG_CHART_TYPE_X uint8_t +#define CONFIG_CHART_TYPE_Y uint8_t +/*\}*/ + +/// Enable button bar behind menus +#define CONFIG_MENU_MENUBAR 0 + +/// Enable smooth scrolling in menus. +#define CONFIG_MENU_SMOOTH 1 + +/// Abort menu after this amount of time. +#define CONFIG_MENU_TIMEOUT 0 /* ms */ + +/// Accept input implicitly after this amount of time. +#define CONFIG_LEVELEDIT_TIMEOUT 3000 /* ms */ + +/// LCD bus size. If 0 use 8bit bus. +#define CONFIG_LCD_4BIT 0 + +#endif /* APPCONFIG_H */ diff --git a/app/demo/demo.c b/app/demo/demo.c new file mode 100644 index 00000000..c088aa2b --- /dev/null +++ b/app/demo/demo.c @@ -0,0 +1,333 @@ +/** + * \file + * + * + * \version $Id: demo.c 18242 2007-10-08 17:35:23Z marco $ + * + * \author Bernardo Innocenti + * + * \brief Windowing system test. + */ + +/*#* + *#* $Log$ + *#* Revision 1.10 2007/09/29 16:30:37 bernie + *#* RASTER_SIZE(): Remove obsolete macro. + *#* + *#* Revision 1.9 2006/09/20 14:29:34 marco + *#* Add proc demo (not yet working). + *#* + *#* Revision 1.8 2006/06/02 12:27:36 bernie + *#* Tweak apparence; enable assertions. + *#* + *#* Revision 1.7 2006/05/27 22:31:18 bernie + *#* Clean it up a bit more. + *#* + *#* Revision 1.6 2006/05/27 17:16:38 bernie + *#* Make demos a bit more interesting. + *#* + *#* Revision 1.5 2006/05/15 07:25:29 bernie + *#* Move menu to gui/. + *#* + *#* Revision 1.4 2006/04/27 05:43:07 bernie + *#* Fix naming conventions. + *#* + *#* Revision 1.3 2006/04/11 00:07:32 bernie + *#* Implemenent MF_SAVESEL flag. + *#* + *#* Revision 1.2 2006/03/27 04:49:50 bernie + *#* Add bouncing logo demo. + *#* + *#* Revision 1.1 2006/03/22 09:52:13 bernie + *#* Add demo application. + *#* + *#* Revision 1.1 2006/01/23 23:14:29 bernie + *#* Implement simple, but impressive windowing system. + *#* + *#*/ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/** + * Draw a pentacle in the provided bitmap. + */ +void schedule(void) +{ + lcd_blitBitmap(&lcd_bitmap); + emul_idle(); +} + +/** + * Draw a pentacle in the provided bitmap. + */ +static void magic(struct Bitmap *bitmap, coord_t x, coord_t y) +{ + static const coord_t coords[] = { 120, 34, 90, 90, 30, 90, 0, 34, 60, 0, 90, 90, 0, 34, 120, 34, 30, 90, 60, 0 }; + unsigned int i; + + gfx_moveTo(bitmap, coords[countof(coords)-2]/2 + x, coords[countof(coords)-1]/3 + y); + for (i = 0; i < countof(coords); i += 2) + gfx_lineTo(bitmap, coords[i]/2 + x, coords[i+1]/3 + y); +} + +static void hello_world(Bitmap *bm) +{ + extern const Font font_ncenB18; + const Font *old_font = bm->font; + + gfx_bitmapClear(bm); + + /* Set big font */ + gfx_setFont(bm, &font_ncenB18); + + text_xprintf(bm, 1, 0, STYLEF_BOLD | TEXT_FILL | TEXT_CENTER, + "Hello, world!"); + + lcd_blitBitmap(bm); + timer_delay(1000); + + /* Restore old font */ + gfx_setFont(bm, old_font); +} + +/** + * Show the splash screen + */ +static void bouncing_logo(Bitmap *bm) +{ + const long SPEED_SCALE = 1000; + const long GRAVITY_ACCEL = 10; + const long BOUNCE_ELASTICITY = 2; + long h = (long)(-project_grl_logo.height) * SPEED_SCALE; + long speed = 1000; + + /* Repeat until logo stands still on the bottom edge */ + while (!((speed == 0) && (h == 0))) + { + /* Move */ + h += speed; + + /* Gravity acceleration */ + speed += GRAVITY_ACCEL; + + if (h > 0 && speed > 0) + { + /* Bounce */ + speed = - (speed / BOUNCE_ELASTICITY); + + } + + /* Update graphics */ + gfx_bitmapClear(bm); + gfx_blitImage(bm, + (bm->width - project_grl_logo.width) / 2, + h / SPEED_SCALE, + &project_grl_logo); + lcd_blitBitmap(bm); + + timer_delay(10); + } +} + +void win_demo(Bitmap *bm) +{ + const coord_t small_left = 45, small_top = 30, small_width = 50, small_height = 30; + const coord_t large_left = -10, large_top = 10, large_width = 85, large_height = 41; + + Window root_win, small_win, large_win; + Bitmap small_bm, large_bm; + uint8_t small_raster[RAST_SIZE(small_width, small_height)]; + uint8_t large_raster[RAST_SIZE(large_width, large_height)]; + + win_create(&root_win, bm); + + gfx_bitmapInit(&large_bm, large_raster, large_width, large_height); + win_create(&large_win, &large_bm); + win_open(&large_win, &root_win); + win_move(&large_win, large_left, large_top); + + gfx_bitmapInit(&small_bm, small_raster, small_width, small_height); + win_create(&small_win, &small_bm); + win_open(&small_win, &root_win); + win_move(&small_win, small_left, small_top); + + + coord_t x = 0, y = LCD_WIDTH / 2; + coord_t xdir = +1, ydir = -1; + coord_t xdir_large = +1; + coord_t ydir_small = +1; + int raise_counter = 0; + int i; + + for(;;) + { + /* Background animation */ + bm = root_win.bitmap; + gfx_bitmapClear(bm); +// gfx_setClipRect(bm, 0, 0, bm->width, bm->height); +// gfx_rectDraw(bm, 10, 10, bm->width-10, bm->height-10); +// gfx_setClipRect(bm, 11, 11, bm->width-11, bm->height-11); + magic(bm, x, y); + x += xdir; + y += ydir; + if (x >= bm->width) xdir = -1; + if (x <= -50) xdir = +1; + if (y >= bm->height) ydir = -1; + if (y <= -50) ydir = +1; + + /* Large window animation */ + bm = large_win.bitmap; + gfx_bitmapClear(bm); + for (i = 0; i < bm->height / 2; i += 2) + gfx_rectDraw(bm, 0 + i, 0 + i, bm->width - i, bm->height - i); + + + /* Small window animation */ + bm = small_win.bitmap; + gfx_bitmapClear(bm); + gfx_rectDraw(bm, 0, 0, bm->width, bm->height); + gfx_line(bm, 0, 0, bm->width, bm->height); + gfx_line(bm, bm->width, 0, 0, bm->height); + + /* Move windows around */ + win_move(&large_win, large_win.geom.xmin + xdir_large, large_top); + if (large_win.geom.xmin < -20) xdir_large = +1; + if (large_win.geom.xmin > RECT_WIDTH(&root_win.geom) - 5) xdir_large = -1; + + win_move(&small_win, small_left, small_win.geom.ymin + ydir_small); + if (small_win.geom.ymin < -20) ydir_small = +1; + if (small_win.geom.ymin > RECT_HEIGHT(&root_win.geom) - 5) ydir_small = -1; + + ++raise_counter; + if (raise_counter % 997 == 0) + win_raise(&small_win); + else if (raise_counter % 731 == 0) + win_raise(&large_win); + + win_compose(&root_win); + + /* Also does LCD refresh, etc. */ + if (kbd_peek()) + break; + } +} + +void proc_demo(void) +{ + extern void proc_test(void); +// FIXME: proc_test() cause segmentation fault. + proc_test(); +} + + +/* SETTINGS SUBMENU */ + +static struct MenuItem settings_items[] = +{ + { (const_iptr_t)"System", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Language", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Networking", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Date & Time",0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Power Saving", MIF_TOGGLE, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)0, 0, NULL, (iptr_t)0 } +}; +static struct Menu settings_menu = { settings_items, "Settings Menu", MF_STICKY | MF_SAVESEL, &lcd_bitmap, 0 }; + + +/* MX SUBMENU */ + +static struct MenuItem mx_items[] = +{ + { (const_iptr_t)"Mouse", MIF_CHECKIT | MIF_EXCLUDE_1 | MIF_EXCLUDE_2, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Keyboard", MIF_CHECKED | MIF_CHECKIT | MIF_EXCLUDE_0 | MIF_EXCLUDE_2, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Joystick", MIF_CHECKIT | MIF_EXCLUDE_0 | MIF_EXCLUDE_1, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Autosave", MIF_CHECKED | MIF_CHECKIT | MIF_TOGGLE, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)0, 0, NULL, (iptr_t)0 } +}; + +static struct Menu mx_menu = { mx_items, (const_iptr_t)0, MF_STICKY | MF_SAVESEL, &lcd_bitmap, 0 }; + + +/* DISPLAY SUBMENU */ + +static struct MenuItem display_items[] = +{ + { (const_iptr_t)"Background", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Colors", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Style", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)"Icon Theme", 0, (MenuHook)0, (iptr_t)0 }, + { (const_iptr_t)0, 0, NULL, (iptr_t)0 } +}; +static struct Menu display_menu = { display_items, "Display Menu", MF_SAVESEL, &lcd_bitmap, 0 }; + + +/* MAIN MENU */ + +static struct MenuItem main_items[] = +{ + { (const_iptr_t)"Win Fly", 0, (MenuHook)win_demo, (iptr_t)&lcd_bitmap }, + { (const_iptr_t)"Bounce!", 0, (MenuHook)bouncing_logo,(iptr_t)&lcd_bitmap }, + { (const_iptr_t)"Hello World", 0, (MenuHook)hello_world, (iptr_t)&lcd_bitmap }, + { (const_iptr_t)"Scheduling", 0, (MenuHook)proc_demo, (iptr_t)&lcd_bitmap }, + { (const_iptr_t)"Menu MX", 0, (MenuHook)menu_handle, (iptr_t)&mx_menu }, + { (const_iptr_t)"Display", 0, (MenuHook)menu_handle, (iptr_t)&display_menu }, + { (const_iptr_t)"Settings", 0, (MenuHook)menu_handle, (iptr_t)&settings_menu }, + { (const_iptr_t)0, 0, NULL, (iptr_t)0 } +}; +static struct Menu main_menu = { main_items, "Main Menu", MF_STICKY, &lcd_bitmap, 0 }; + + +int main(int argc, char *argv[]) +{ + emul_init(&argc, argv); + timer_init(); + buz_init(); + kbd_init(); + lcd_init(); + proc_init(); + + menu_handle(&main_menu); + + emul_cleanup(); + return 0; +} diff --git a/app/demo/demo.mk b/app/demo/demo.mk new file mode 100644 index 00000000..afa42c1d --- /dev/null +++ b/app/demo/demo.mk @@ -0,0 +1,115 @@ +# +# $Id: demo.mk 18234 2007-10-08 13:39:48Z rasky $ +# Copyright 2003, 2004, 2005, 2006 Develer S.r.l. (http://www.develer.com/) +# All rights reserved. +# +# Makefile fragment for DevLib demo application. +# +# Author: Bernardo Innocenti +# +# $Log$ +# Revision 1.9 2007/09/29 15:54:14 bernie +# Make demo Qt emulator compile again. +# +# Revision 1.8 2006/09/20 14:27:22 marco +# Added fonts, switch.S; fixed moc +# +# Revision 1.7 2006/09/19 17:48:45 bernie +# Remove artwork.c +# +# Revision 1.6 2006/06/02 12:27:36 bernie +# Tweak apparence; enable assertions. +# +# Revision 1.5 2006/05/27 22:42:02 bernie +# Add verstag. +# +# Revision 1.4 2006/05/27 17:16:38 bernie +# Make demos a bit more interesting. +# +# Revision 1.3 2006/05/15 07:21:24 bernie +# Use pkg-config. +# +# Revision 1.2 2006/03/27 04:49:50 bernie +# Add bouncing logo demo. +# +# Revision 1.1 2006/03/22 09:52:13 bernie +# Add demo application. +# + +include fonts/fonts.mk +include emul/emul.mk + +# Set to 1 for debug builds +demo_DEBUG = 1 + +# Our target application +TRG += demo + +# FIXME: we want to use g++ for C source too +CC = g++ + +demo_CXXSRC = \ + emul/emul.cpp \ + emul/emulwin.cpp \ + emul/emulkbd.cpp \ + drv/lcd_gfx_qt.cpp + +demo_CSRC = \ + app/demo/demo.c \ + os/hptime.c \ + gfx/bitmap.c \ + gfx/line.c \ + gfx/win.c \ + gfx/text.c \ + gfx/text_format.c \ + gui/menu.c \ + fonts/helvB10.c \ + fonts/luBS14.c \ + fonts/ncenB18.c \ + icons/logo.c \ + drv/kbd.c \ + drv/timer.c \ + drv/buzzer.c \ + drv/ser.c \ + drv/ser_posix.c \ + mware/formatwr.c \ + mware/hex.c \ + mware/event.c \ + mware/observer.c \ + mware/resource.c \ + mware/sprintf.c \ + kern/proc.c \ + kern/sem.c \ + kern/signal.c \ + kern/monitor.c \ + kern/proc_test.c \ + verstag.c + +demo_CPPASRC = \ + kern/switch.S + +# FIXME: maybe this junk should go in emul/emul.mk? +$(OBJDIR)/demo/emul/emulwin.o: emul/emulwin_moc.cpp +$(OBJDIR)/demo/drv/lcd_gfx_qt.o: drv/lcd_gfx_qt_moc.cpp +$(OBJDIR)/demo/drv/timer.o: drv/timer_qt_moc.cpp +$(OBJDIR)/demo/emul/emulkbd.o: emul/emulkbd_moc.cpp + +#FIXME: isn't there a way to avoid repeating the pattern rule? +drv/timer_qt_moc.cpp: drv/timer_qt.c + $(QT_MOC) -o $@ $< + + +demo_CFLAGS = -D_QT=4 -D'ARCH=ARCH_EMUL' -Iapp/demo -Ihw $(EMUL_CFLAGS) +demo_CXXFLAGS = -D_QT=4 -D'ARCH=ARCH_EMUL' -Iapp/demo -Ihw $(EMUL_CFLAGS) +demo_LDFLAGS = $(EMUL_LDFLAGS) + +# Debug stuff +ifeq ($(demo_DEBUG),1) + demo_CFLAGS += -D_DEBUG + demo_CXXFLAGS += -D_DEBUG +# demo_PCSRC += drv/kdebug.c +else + demo_CFLAGS += -Os + demo_CXXFLAGS += -Os +endif + diff --git a/app/demo/verstag.h b/app/demo/verstag.h new file mode 100644 index 00000000..3a20c6fe --- /dev/null +++ b/app/demo/verstag.h @@ -0,0 +1,94 @@ +/** + * \file + * + * + * \version $Id: verstag.h 18242 2007-10-08 17:35:23Z marco $ + * + * \author Bernardo Innocenti + * + * \brief Declare application version strings + */ +#ifndef DEVLIB_VERSTAG_H +#define DEVLIB_VERSTAG_H + +#ifndef ARCH_CONFIG_H + #include "cfg/arch_config.h" +#endif + +#define APP_NAME "Devlib Demo" +#define APP_DESCRIPTION "DevLib Multidemo Application" +#define APP_AUTHOR "Develer" +#define APP_COPYRIGHT "Copyright 2006 Develer (http://www.develer.com/)" + +#define VERS_MAJOR 0 +#define VERS_MINOR 1 +#define VERS_REV 0 +#define VERS_LETTER "" + +/** + * If _SNAPSHOT is defined, \c VERS_TAG contains the build date + * date instead of a numeric version string. + */ +#define _SNAPSHOT + +#ifdef _DEBUG + #define VERS_DBG "D" +#else + #define VERS_DBG "" +#endif + +#define __STRINGIZE(x) #x +#define _STRINGIZE(x) __STRINGIZE(x) + +/** Build application version string (i.e.: "1.7.0") */ +#define MAKE_VERS(maj,min,rev) _STRINGIZE(maj) "." _STRINGIZE(min) "." _STRINGIZE(rev) VERS_LETTER VERS_DBG +#ifdef _SNAPSHOT + #define VERS_TAG "snapshot" " " __DATE__ " " __TIME__ " " VERS_LETTER " " VERS_DBG +#else + #define VERS_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV) +#endif + +/** Build application version string suitable for MS windows resource files (i.e.: "1, 7, 0, 1") */ +#define MAKE_RCVERS(maj,min,rev,bld) _STRINGIZE(maj) ", " _STRINGIZE(min) ", " _STRINGIZE(rev) ", " _STRINGIZE(bld) +#define RCVERSION_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV) + +/** The revision string (contains VERS_TAG) */ +extern const char vers_tag[]; + +/** Sequential build number (contains VERS_BUILD) */ +extern const int vers_build_nr; +//extern const char vers_build_str[]; + +/** Hostname of the machine used to build this binary (contains VERS_HOST) */ +extern const char vers_host[]; + +#endif /* DEVLIB_VERSTAG_H */ -- 2.25.1