Back to Contents


New Features of the Language

See also: FAQ List.


Version 2.11

New database drivers

The following database drivers are supported by Genero version 2.11:

Static SQL syntax extension

Derived tables and derived column list

Genero FGL static SQL syntax now supports derived tables and derived column lists in the FROM clause, for example:

   SELECT * FROM (SELECT * FROM customers ORDER BY cust_num) AS t(c1,c2,c3,...)

See database server documentation for more details about this SQL feature. Note that Informix 11 does not support the full ANSI SQL 92 specification for derived columns, while other databases like DB2 do. For this reason, fglcomp allows the ANSI standard syntax.

New transaction isolation levels of Informix 11

The SET ISOLATION statement now supports the new Informix 11 clauses for the COMMITTED READ option:

   SET ISOLATION TO COMMITTED READ [LAST COMMITTED] [RETAIN UPDATE LOCKS]

When connecting to a non-Informix database, the LAST COMMITTED and RETAIN UPDATE LOCKS are ignored; other databases do not support these options, and have the same behavior as when these options are used with Informix 11.

The CAST operator

The CAST operator can now be used in static SQL statements:

   CAST ( expression AS sql-data-type ) 

Note that only Informix data types are supported after the AS keyword.

New preprocessor option to remove line number information

You can now remove line number information with -p noln when preprocessing sources to get a readable output:

   fglcomp -E -p noln mymodule.4gl

Connecting to Oracle as SYSDBA or SYSOPER

In order to execute database administration tasks, you can now connect to Oracle as SYSDBA or SYSOPER with the CONNECT instruction:

   CONNECT TO "dbname" USER "scott/SYSDBA" USING "tiger"

New methods for ui.ComboBox

The ui.ComboBox class has been extended with new methods: getTextOf() and getIndexOf().

Make current row visible after sort in lists

A new FGLPROFILE entry has been added to force the current row to be automatically shown after a sort in a table:

   Dialog.currentRowVisibleAfterSort = 1

By default, the offset does not change and the current row may disappear from the window. When this new parameter is used, the current row will always be visible. For more details, see Runtime Configuration.

Reading pcode build information of older versions

The -b option of fglrun has been extended to recognize headers of pcode modules compiled with older versions of FGL. For more details, see Compiling Programs. Additionally, fglform now writes build information in the 42f files, to identify on the production site what FGL version was used to compile forms.


Version 2.10

Multiple Dialogs

A new DIALOG instruction handles different parts of a form simultaneously.  See also ui.Dialog class.

TRY/CATCH pseudo statement

The TRY/CATCH pseudo statement can handle exceptions raised by the runtime system.

WHENEVER .... RAISE

Instructs the DVM that an uncaught exception will be handled by the caller of the function. See Exceptions.

SQL Server Native Client driver

Support for SQL Server 2005 Native Client is now provided.

Support for SPLITTER attribute

HBox and VBox containers can now have a splitter.  See also Layout Tags.

Double-click in tables

With the new DOUBLECLICK table attribute, it is now possible to send a specific action when the user double-clicks on a row.

New X conversion code in fgldbsch

The fgldbsch tool now supports the X conversion code to ignore table columns of a specific type. This is useful for ROWID-like columns such as SQL Server's uniqueidentifier columns.

SQL Interruption in database drivers

Before version 2.10, SQL interruption was not supported well for Oracle, SQL Server, DB2 and Genero db databases. SQL interruption is now available with all databases providing an API to cancel a long-running query.

For more details, see SQL Programming.

NULL pointer exceptions can be trapped

Error -8083 will be raised if you try to call an object method with a variable that does not reference an object (that contains NULL):

DEFINE x ui.Dialog
-- x is NULL
CALL x.setFieldActive("fieldname",FALSE)  -- raises -8083

In previous versions, this raised a fatal NULL pointer error. This exception can now be trapped with  WHENEVER ERROR.

Client socket interface in Channels

The Channel class now provides a method to establish a client socket connection to a server, with the new openClientSocket() method.

Stack trace

For debugging purpose, you can now get the stack trace of the program with the Application.getStackTrace() method.

GUI Connection Timeout

It is now possible to define a timeout delay for front-end connections with the following FGLPROFILE entry:

gui.connection.timeout = seconds

See Dynamic User Interface for more details.

Assigning a value to a TEXT variable 

Before version 2.10, it was only possible to assign a TEXT to a TEXT variable. Now you can assign STRING, CHAR and VARCHAR values to a TEXT variable. For more details about data type conversions, see the Data Conversion Table.

New Presentation styles

Presentation Styles have been extended:

fglrun -s option now displays more information

The -s option of fglrun now reports more information about sizes. See Optimization for more details.

fglrun -e option takes list of extensions

The fglrun -e option now supports a comma-separated list of extensions, and -e can be specified multiple times:

fglrun -e ext1,ext2,ext3 -e ext4,ext5 myprogram

See C Extensions for more details.

Detecting data changes immediately

It is now possible to get an action event when the user modifies the value of a field, with the predefined dialogtouched action.

Controlling data validation for actions

You can now use the validate="no" action default attribute to prevent data validation when executing an action.

New MINWIDTH, MINHEIGHT attributes in forms

It is now possible to define a minimum width and height for forms with the MINWIDTH, MINHEIGHT attributes.

Avoid automatic temporary row in INPUT ARRAY

With the new AUTO APPEND attribute, you can now avoid the automatic creation of a temporary row in INPUT ARRAY.

New implicit navigation actions in INPUT ARRAY and DISPLAY ARRAY

When a DISPLAY ARRAY or INPUT ARRAY is executed, the runtime system now creates two more implicit actions to navigate in the list: firstrow and lastrow. In previous versions, only nextrow and prevrow actions were created. You can now bind four buttons to these actions to get a typical list navigation toolbar. Note that the default action views are hidden for these navigation actions.

New DOM methods to serialize or parse strings

The parse() and toString() methods are now available for a DomNode object, and a DomDocument object can be created with createFromString().

New I/O methods to read/write TEXT or BYTE from/to files

The TEXT and BYTE data types now support the methods readFile(fileName) and writeFile(fileName). 

Back to the top


Version 2.02

New Static SQL Commands

Some common SQL statements have been added to the static SQL syntax, such as TRUNCATE TABLE, RENAME INDEX, CREATE / ALTER / DROP / RENAME SEQUENCE. See Static SQL Commands.

Global Variables in C Extensions

You can now share global variables between the FGL source and the C Extension, by using the -G option of fglcomp. See Global variables in C Extensions.

Localization of runtime system error messages

It is now possible to customize the runtime system error messages according to the current locale. See Localization for more details.

Debugger enhancement

New debugger commands (ptype).

You can now avoid switching into debug mode with SIGTRAP (Unix) or CTRL-Break (Windows) with the new fglrun.ignoreDebuggerEvent FGLPROFILE entry.

Tab index can be zero

You can now specify a TABINDEX of zero to exclude the form item from the tagging list. See TABINDEX for more details.

New FGLPROFILE entry for Oracle driver

It is now possible to specify the SELECT statement producing the unique session identifier which is used for temporary table names.
See Database vendor specific parameters for more details.

New FGLPROFILE entry to define temporary table emulation type

To emulate Informix temporary tables, you can now set the temptables.emulation parameter to use GLOBAL TEMPORARY TABLES instead of permanent tables.
See temporary table emulation for more details.

Back to the top


Version 2.01

FESQLC compiler (V2)

ESQL/C Compiler. See FESQLC compiler (V2).

DB2 V9.x support

Support of DB2 V9.x. See DB2 V9.x support.

PostgreSQL V 8.2.x support

Support of PostgreSQL 8.2.x. See PostgreSQL V 8.2.x support.

Extension of the form layout tag syntax

The layout tag syntax in grids has been extended to support an ending tag to get better control of form layout.

Negative form of warning flags in fglcomp

The fglcomp compiler now supports a negative form for warning arguments.

Run supports ComSpec variable on Windows

When using the RUN command, the ComSpec environment variable is now used under Windows platforms.

Back to the top


Version 2.00

Dynamic Runner Architecture

Runner now uses shared libraries; you no longer need to link a runner. See Dynamic Runner Architecture.

User defined types

You can now define your own data type with records or arrays. See User defined types.

New Widgets

New widgets have been added: SLIDER, SPINEDIT, TIMEEDIT.

Extended Schema Files

Database Schema files have been extended for Genero (FIELD item type). See Extended Schema Files.

File Management Functions

File management function library provided as loadable extension. See File Management Functions.

Math Functions

Mathematical function library provided as loadable extension. See Math Functions.

Stored procedure calls

It is now possible to call stored procedures with output parameters. See Stored procedure calls.

Informix-like C API library

C extension support has been extended with Informix-like C API functions. See Informix-like C API library.

Memory usage optimization

The runtime system now shares several static elements among all processes, reducing the memory usage. The shared elements are: Data type definitions, string constants and debug information. For example, when a program defines a string containing a long SQL statement, all Genero processes will share the same string, which is allocated only once.

The IMPORT instruction

To declare a C extension module, you must now use the IMPORT instruction at the beginning of a module.

WIDTH and HEIGHT attributes in Images

You can now specify the WIDTH and HEIGHT attributes for IMAGE form items, as a replacement for PIXELWIDTH / PIXELHEIGHT.

New debugger commands

New commands have been added to the debugger (call, ignore).

Improved Presentation Styles

You can now specify pseudo selectors such as focus, active, inactive, input, display for fields and odd / even states for table rows.

Some new style attributes were added:

For more details, see Presentation Styles.

Compiler supports constraints in CREATE TABLE

It is now possible to specify primary key, foreign key and check constraints in static CREATE TABLE statements:

  CREATE TABLE t1 (
     col1 INTEGER PRIMARY KEY,
     col2 CHAR(2),
     col3 DATE,
     FOREIGN KEY (col2) REFERENCES t2(col1)
  )

Automatic front-end startup

In X11 or Windowse TSE environments, you can now automatically start up the front-end with FGLPROFILE entries. See Dynamic User Interface for more details.

New channel function to detect EOF

The Channel class now has an isEof() method to detect end of file.

Responding to CTRL_LOGOFF_EVENT on Windows

It is now possible to ignore the CTRL_LOGOFF_EVENT events on Windows platforms.

New compiler warning options

The fglcomp compiler has new warning flags: See fglcomp for more details.

Fourth accelerator definition

You can now define a fourth accelerator for an action in actions defaults or in the form files.

Conditional TTY attributes for all widgets

It is now possible to specify TTY attributes (COLOR, REVERSE) and conditional TTY attributes (COLOR WHERE) for all type of fields.
See Form Specification Files and COLOR WHERE attribute for more details.

New FGL_SETENV() built-in function

A new built-in function has been added to set an environment variable: FGL_SETENV().

Support for entities in XML reader and writer

The XML reader and writer classes have been extended to properly support markup language entities (like HTML's   ).

Schema extractor supports now Informix LVARCHAR

The fgldbsch tool can now extract database tables with LVARCHAR columns. The LVARCHAR type is converted to VARCHAR2(n>255) in the .sch file.

Back to the top


Version 1.33

TypeInfo class

A class to serialize program variables. See TypeInfo class.

Generic ODBC support

A generic ODBC database driver is now available (code is odc). See Generic ODBC support.

MySQL 5 support

MySQL version 5 is now supported. See MySQL 5. support.

Genero DB 3.4 support

Genero DB version 3.4 is now supported. See Genero DB support.

PostgreSQL 8.1 support

PostgreSQL version 8.1 is now supported. See PostgreSQL 8.1 support.

SQL Server 2005 support

Microsoft SQL Server 2005 is now supported. See SQL Server 2005 support.

New license manager

New license manager supporting strict licensing. See New license manager.

FESQLC compiler (V1)

ESQL/C compiler.

Binary mode in Channel class

The base.Channel class now supports a binary mode with the 'b' option, to control CR/LF translation when using DOS files.

New header files for C extensions

Distribution of Datetime.h, Interval.h, loc_t.h header files in FGLDIR/include/f2c.

Block fetch with SQL Server

You can now pre-fetch rows by block with SQL Server to get better performance. Use the following FGLPROFILE entry to specify the maximum number of rows the driver can pre-fetch:

dbi.database.<dbname>.msv.prefetch.rows = <count>

See "Database vendor specific parameters" in Connections for more details.

Third accelerator definition

You can now define a third accelerator for an action in actions defaults or in the form files.

Back to the top


Version 1.32

PostgreSQL 8.0 support

PostgreSQL version 8.0 is now supported (8.0.2 and higher). See PostgreSQL 8.0 support.

File transfer functions

Get/Put functions to transfer files from/to the front-end. See File transfer functions.

Debugger enhancement

New debugger commands (watch with condition, whatis).

Preprocessor is now integrated in compilers

The preprocessor is now part of the compilers and is always enabled. Preprocessing directives start with an ampersand character (&).

Back to the top


Version 1.31

Front-end Protocol Compression

Faster user interface communication. See Front-end Protocol Compression.

MySQL 4.1.x support

MySQL version 4.1.x is now supported, 3.23 is de-supported. See MySQL 4.1.x support.

Oracle 10g support

Oracle version 10g is now supported. See Oracle 10g support.

Dynamic C extensions

C extensions can be loaded dynamically, no need to re-link runner. See Dynamic C extensions.

New built-in functions

The FGL_WIDTH built-in function computes the number of print columns needed to represent a single or multi-byte character.

Interruption handling

Interruption handling with SSH port forwarding - only supported with GDC 1.31!

New Dialog method

New method ui.Form.setFieldStyle() to set a style for a field.

Front-end identification

Improved front-end identification when connecting to GUI client.

Back to the top


Version 1.30

Preprocessor

Integrated preprocessor allows use of #include and #define/#ifdef macros. See Preprocessor.

Layout Enhancements

New layout rules and form item attributes provide better control of form design. See Layout Enhancements.

Presentation Styles

Decoration attribute can be defined in a style file to set fonts and colors. See Presentation Styles.

Localization Support

Localization Support (multi-byte character sets). See Localization Support.

Action defaults in forms

Action defaults can be specified in forms. See Action defaults in forms.

Dialog Control

Dialog built-in class to provide better control over interactive instructions. See Dialog Control.

Sybase ASA Support

New drivers to connect to Sybase Adaptive Server Anywhere V7 and V8. See Sybase ASA Support

PostgreSQL 7.4 support

Support for PostgreSQL 7.4 with parameterized queries. See PostgreSQL 7.4 support.

Build information in 42m modules

The fglcomp compiler now adds build information in 42m modules. Compiler version of a 42m module can be checked on site by using the fglrun with the -b option:

$ fglrun -b module.42m
2004-05-17 10:42:05 1.30.2a-620.10 /devel/tests/module.4gl

MySQL 3.23 support for Windows platforms

A MySQL 3.23 driver is now provided for Windows platforms (was previously only provided on Linux).

Upshift/Downshift in Comboboxes

COMBOBOX fields now support UPSHIFT and DOWNSHIFT attributes, to force character case when QUERYEDITABLE is used.

Message compiler does not require output file any longer

The fglmkmsg tool now has the same behavior as other tools like fglcomp and fglform: If you give only the source file, the message compiler uses the same file name for the compiled output file, adding the .iem extension.

Breakpoint in source code

New BREAKPOINT instruction to stop a program at a given position when using the debugger. It is ignored when not running in debug mode.

Row highlighting in tables

New TABLE presentation style attribute highlightCurrentRow, to indicate if the current row must be highlighted in a specific mode. By default, the current row is highlighted during a DISPLAY ARRAY.

Method base.Array.appendElement()

New method base.Array.appendElement(), to append an element at the end of a dynamic array.

Compiled Localized String file extension = 42s

Compiled Localized String files now have the .42s extension. Previous extension was .4ls.

Assignment Operator

New assignment operator := has been added to the language. You can now assign variables in expressions:
IF ( i := (j+1) ) == 2 THEN

New fglcomp option for SQL

The fglcomp compiler now has a new option to detect non-standard SQL syntax:
fglcomp -W stdsql module.4gl

Compiler generates standard UPDATE syntax

The fglcomp compiler now converts static SQL updates like:

UPDATE tab SET (c1,c2)=(v1,c2) ...

to a standard syntax:

UPDATE tab SET c1=v1, c2=v2 ...

See also SQL Programming.

Defining color attributes for each table cell

The new method ui.Dialog.SetCellAttributes() lets you define colors for each cell of a table.

Form methods in ui.Window 

The ui.Window class provides new methods to create or get a form object.

Method base.StringBuffer.replace()

New method base.StringBuffer.replace(), to replace a sub-string in a string:

CALL s.replace("old","new",2)
Replaces two occurrences of "old" with "new"...

Methods base.Channel.readLine() and base.Channel.writeLine()

New methods to read/write complete lines in Channel built-in class: readLine() and writeLine().

Dynamic arrays used as data model in INPUT ARRAY / DISPLAY ARRAY

When using a dynamic array in INPUT ARRAY or DISPLAY ARRAY, the number of rows is defined by the size of the dynamic array. The SET_COUNT() or COUNT attributes are ignored.

TITLE attribute for fields

The new form field attribute TITLE can be used to specify a table column label with a localized string.

FGLLDPATH used during link

The FGLLDPATH variable is now used during link

Method ui.Dialog.setDefaultUnbuffered()

New class method ui.Dialog.setDefaultUnbuffered() to set the default for the UNBUFFERED mode.

Action Defaults applied by DVM

Action Defaults now applied at element creation by the runtime system. In previous versions this was done dynamically by the front-end. Now, changing an action default node at runtime has no effect on existing elements.

DATEEDIT supports DBDATE & FORMAT

The DATEEDIT field type now supports DBDATE/CENTURY settings and the FORMAT attribute.

New predefined action 'close'

New default action 'close' to control Window closing. You can now write the following to control window closing:

  ON ACTION close
See Windows and Forms.

Tabbing order in TABLEs during INPUT ARRAY

INPUT ARRAY using TABLE container now needs FIELD ORDER FORM attribute to keep tabbing order consistent with visual order of columns.

Preprocessor raises errors for invalid # macros

If enabled, the preprocessor now raises an error when # comments are used in the source. You must replace all # comments by -- comments before using the preprocessor.

ACCEPT xx instruction

New instructions ACCEPT INPUT / ACCEPT CONSTRUCT / ACCEPT DISPLAY to validate a dialog by program.

ON ACTION doit
   ACCEPT INPUT

ACCEPT / CANCEL dialog attribute

New dialog attribute ACCEPT / CANCEL to avoid creation of default actions 'accept' and 'cancel'.
See Record Input control instructions.

Preprocessor disabled by default

The Preprocessor is now disabled by default; there are no FGLPP / FGLPPOPTIONS environment variables, you must use the -p option of fglcomp/fglform.

INPUT ARRAY now has default 'append' action

New default action 'append' in INPUT ARRAY. Allows you to add a row at the end of the list.

Linker option -O removed

The linker option -O (optimize) is de-supported (was ignored before). You now get a warning if you use this option.

Method ui.Window.createForm()

New method ui.Window.createForm() to create an empty form object in order to build forms from scratch at runtime.

TopMenu attributes in .per

TopMenu definition in forms now allows attributes in parenthesis.

Specifying real field size in forms

The form layout syntax now allows you to specify the real width of form items. By default, BUTTONEDIT, COMBOBOX and DATEEDIT get a real width as follows:

  if nbchars>2 : width = nbchars - 2; otherwise width = nbchars
(Here nbchars is the number of characters used in the layout definition.)

Now you can specify the real width by using a dash '-' in the tag:

 1234567
[f01  - ]      width = 5, grid cells used = 7

This works also in hbox tags and screen arrays.

Version number in UI protocol

User interface protocol is now controlled with a version number, to check compatibility between the front end and runtime system.

C-like source preprocessor

New integrated preprocessor: The form and source compiler now integrates a preprocessor! You can use macros as in C, such as #include, #define, #ifdef, etc.

MENU node available in BEFORE MENU

Important remark: Before build 530 the MENU has attached the WINDOW when returning from the BEFORE MENU actions. Since build 530 the WINDOW must exist before the MENU statement. So now the MENU node is available in the BEFORE MENU block, but a WINDOW opened or made CURRENT in the BEFORE MENU block will NOT be used.

New HBox tags

Layout GRID now accepts HBox tags to group items horizontally.

Form layout extensions

New Table definition attributes

New ORIENTATION attribute for RADIOGROUPs

RADIOGROUP fields now support the attribute ORIENTATION = { VERTICAL | HORIZONTAL }.

Reviewed fglrun.setenv environment variables handling in FGLPROFILE

Now, on Windows platforms only, the ix drivers automatically set standard Informix environment variables with ifx_putenv(). Values are taken from the console environment with getenv(). Additional variables can be specified with:

dbi.stdifx.environment.count = n
dbi.stdifx.environment.xx = "variable"

MENU COMMAND generates lowercase action name

The MENU COMMAND clause now generates action names in lowercase. This means, when you define COMMAND "Open", it will bind to all actions views defined with the name 'open'.

Method ui.Interface.loadTopMenu()

New ui.Interface.loadTopMenu() method to load a global topmenu.

ON CHANGE fired on click

The ON CHANGE block is now fired when the user clicks on a checkbox, radiogroup, or changes the item in a combobox.

New ui.Dialog built-in class

New ui.Dialog built-in class available with the DIALOG keyword in all interactive instructions. You can now activate/deactivate fields and actions during a dialog:

INPUT ...
     AFTER FIELD field1
     CALL DIALOG.setFieldActive("field2",rec.field1 IS NOT NULL)
     CALL DIALOG.setActionActive("check",rec.field1 IS NOT NULL)

New ui.Form methods

The ui.Form built-in class has new methods to handle form elements. The hidden attribute is now also managed at the model level, this allows you to hide form fields by name, instead of using the decoration node.

CALL myform.setElementHidden("formonly.field1",2)
CALL myform.setFieldHidden("field1",2) -- prefix is optional

Array sub-script operator now returns the sub-array

The [] array sub-script operator now returns the sub-array:

DEFINE a2 DYNAMIC ARRAY WITH DIMENSION 2 OF INTEGER
LET a2[5,10] = 123
DISPLAY a2.getLength() -- displays 5
DISPLAY a2[5].getLength() -- displays 10

Dynamic arrays passed by reference to functions

Dynamic arrays are now passed by reference to functions. You can change a dynamic array in a function when it is passed as an argument.

Control MDI children with ui.Interface

New methods are provided in ui.Interface to control the MDI children.

CANCEL INSERT in AFTER INSERT

In INPUT ARRAY, CANCEL INSERT now supported in AFTER INSERT, to remove the new added line when needed.

Toolbar and Topmenu now have the hidden attribute

Toolbar and Topmenu elements now have the hidden attribute so you can create them and hide the options the user is not supposed to see.

Warning: Hiding a toolbar or topmenu option does not prevent the use of the accelerator of the action. Use ui.Dialog.setActionActive()!

NEXT FIELD CURRENT

New keyword for NEXT FIELD: NEXT FIELD CURRENT. Gives control back to the dialog instruction without moving to another field.

Back to the top


Version 1.20

Debugger

Integrated debugger with gdb syntax to interface with graphical tools like ddd. See Debugger.

Program Profiler

The Program Profiler can be used to generate statistics of program execution, to find the bottlenecks in the source code.

Localized Strings

Internationalizes your application in different languages with localized strings.

Localized Strings are now supported. You can identify strings to be localized, with the % notation:

 LAYOUT ( TEXT= %"custlist" )

See Localized Strings.

Unbuffered Dialogs

Interactive instructions support the UNBUFFERED mode, to synchronise data model and view automatically.  Dialogs can now use the UNBUFFERED attribute, that simplifies INPUT, DISPLAY ARRAY and INPUT ARRAY coding; input/display buffer is no longer used. When you set a variable, the value is automatically displayed to the field. See Unbuffered Dialogs.

Paged Display Array

DISPLAY ARRAY can now work in buffered mode, to avoid loading a big array when you have a lot of rows to display. The DISPLAY ARRAY instruction now has a new ON FILL BUFFER block that can be used with dynamic arrays to feed the dialog with data rows on demand. See Paged Display Array.

Action Defaults

Centralize default attributes for actions in Action Defaults files.

Client side settings saved for each program

Client side settings are now saved in registry according to the 'name' attribute of UserInterface, which can be set with ui.Interface.setName() method. By default UserInterface.name is not set to the name of the program.

APPEND ROW dialog attribute

New attribute APPEND ROW = TRUE/FALSE for INPUT ARRAY instruction. Defines if the user is allowed to add rows at the end of the list.

KEEP CURRENT ROW dialog attribute

New attribute KEEP CURRENT ROW = TRUE/FALSE for DISPLAY ARRAY and INPUT ARRAY instructions. Defines if the current row must remain highlighted when leaving the dialog. The default is FALSE.

UNHIDABLE attribute for image and labels

Image and labels now support the UNHIDABLE attribute for table columns.

TERMINATE REPORT / EXIT REPORT

New report instructions TERMINATE REPORT / EXIT REPORT. Use the EXIT REPORT statement to terminate a report within a REPORT definition. Both statements have the following effects:
- Terminate the processing of the current report.
- Delete any intermediate files or temporary tables that were created while processing the report.

TINYINT data type with SQL Server

SQL Server driver now supports the TINYINT data type.

Toolbars can be defined in forms

You can now define Toolbars in form specification files.

Topmenus can be defined in forms

You can now define Topmenus in form specification files.

Build version number

The FGL_GETVERSION() function returns the internal version number of the runtime system.

Get a help message text

The FGL_GETHELP() function returns the message text for a give help number.

Set the current row

The FGL_SET_ARR_CURR() function changes the current row in DISPLAY ARRAY or INPUT ARRAY.

Interruption handling

Users can now send an interruption request from the client to the program, to stop long running queries, reports and other BDL procedures, by testing the int_flag variable. The client is using an OOB signal.

StatusBar definition with style attribute

There is now a new window style attribute for statusbar layout specification. You can now set statusBarType attribute in the 4st style file for Windows, in order to control the display of status bars.

Field order form

New OPTIONS clause FIELD ORDER FORM provided to use the TABINDEX attribute to define the field tabbing order. FIELD ORDER FORM can also be used at the dialog level as dialog attribute.

Runtime system re-written in C

Runtime system has been re-written in pure C language, g++ 3.2 and corresponding gnu libs (libstdc++, libsupc++, ...) are no longer needed; a runner can be linked with a native cc compiler. See Installation and Setup.

Passing arrays as function parameter

Arrays can be passed as parameters, all elements are expanded.

Compiler supports now ANSI outer joins

You can now write static SQL statements using ANSI outer joins:

   SELECT .. FROM a LEFT OUTER JOIN b ON a.key=b.key

Methods for StringBuffer

New methods for StringBuffer class: base.StringBuffer.replaceAt() and base.StringBuffer.insertAt().

Default items created for COMBOBOX

For COMBOBOX form items, a default ITEMS list is created by fglform when an INCLUDE list is used.

ON IDLE clause in dialogs

The ON IDLE clause can be used to execute a block of instructions after a timeout.

Order of INPUT ARRAY trigger execution

New logical order of execution for INPUT ARRAY triggers:

  1. BEFORE INPUT
  2. BEFORE ROW
  3. BEFORE INSERT
  4. BEFORE FIELD

New ui.ComboBox class

New ui.ComboBox class has been added, to configure COMBOBOX fields at runtime.

Predefined actions in lists: nextrow / prevrow

DISPLAY ARRAY and INPUT ARRAY instructions now automatically use two predefined actions nextrow and prevrow, which allow binding action views for navigation.

FOREACH infinite loop

FOREACH that raises an error no longer loops infinitely.

Record comparison

Operators equal (= or ==) and not equal (<> or !=) now can be used with records. All members will be compared. If two members are NULL the result of this member comparison results in TRUE.

ON CHANGE trigger

ON CHANGE field trigger in INPUT and INPUT ARRAY. Same as AFTER FIELD, but only fired if the value has changed.

Program icon

New image attribute in UserInterface node, for the program icon. Can be set with ui.Interface.setImage().

Form compilation warnings

New option -W for fglform to show warnings.

FORMAT attribute in LABELs

LABELs can now have a FORMAT attribute.

SQLSTATE and SQLERRMESSAGE

New SQLSTATE and SQLERRMESSAGE operators, to give SQL execution information.

Front End Function calls

You can now call predefined functions in the front-end, by using the ui.Interface.frontCall()method.
See also Front End Functions.

New ui.Form built-in class

New ui.Form built-in class to handle forms.

TABINDEX for tabbing order

New TABINDEX field attribute to define the tabbing order in forms.

LSTR operator

New LSTR operator to get a localized string by name:

  DISPLAY LSTR("custno_comment")

SFMT operator

New SFMT operator to format strings with parameters:

  DISPLAY SFMT("Could not find %1 in %2.",filename,dirname)

ON ROW CHANGE trigger

New ON ROW CHANGE clause in INPUT ARRAY. This trigger will be executed if at least one value in the row has been modified. The ON ROW CHANGE code is be executed just before the AFTER ROW clause.

New StringTokenizer class

The StringTokenizer class can be used to parse strings for tokens.

Faster linker

Linker is now faster when having program modules with a huge number of functions.

Global constants

CONSTANTs can now be defined as GLOBALs.

ON ACTION in MENUs

MENU instruction now supports ON ACTION clause, to write abstract menus as simple action handlers.

New Application class

The base.Application class provides an interface to the program properties.

New Channel class

New definition of the interface for Channels, now based on objects:

 DEFINE c base.Channel
 LET c = base.Channel.create()
 CALL c.openFile("data.txt","r")

Predefined 'help' action

New 'help' predefined action, to start help viewer for HELP clauses in dialog instructions.

 INPUT BY NAME .... HELP 12423 -- Creates action 'help'

Back to the top


Version 1.10

Dynamic User Interface

The Dynamic User Interface is the major new concept in Genero. It is the basement for the new graphical user interface. See Dynamic User Interface.

Interactive Instruction Extensions

Classical interactive instructions such as INPUT, INPUT ARRAY, DISPLAY ARRAY, CONSTRUCT have been extended with new control blocks and control instructions. See Interactive Instruction Extensions.

Built-in Classes

The language supports now built-in classes, a new object-oriented way to program in BDL. See Built-in Classes.

Constant Definitions

It is now possible to define constants, as in other languages. See Constant Definitions.

Extended Form Files

You can now define complex layouts with the extended PER files. See Extended Form Files.

Dynamic Arrays

The language now supports dynamic arrays with automatic memory allocation. DISPLAY ARRAY can now work in buffered mode, to avoid to load a big array when you have a lot of rows to display. See Dynamic Arrays.

XML utilities

A set of XML Utilities are provided in the runtime library as built-in classes.

STRING data type

A new STRING data type is now available, to simplify utility function coding.

Defining MDI containers

Defining Window Containers (MDI) is a simple way to group programs.

SCHEMA instruction

The new SCHEMA instruction allows you to specific a database schema without having an implicit connection when the program executes.

Back to the top